make -j 8 g ++:内部编译器错误:被杀(程序cc1plus)

时间:2015-06-17 09:11:41

标签: linux ubuntu gcc g++ mesos

当我在Ubuntu12.04上部署Apache Mesos时,我按照官方文档,在步骤“make -j 8”中我在控制台中收到此错误:

g++: internal compiler error: Killed (program cc1plus)
Please submit a full bug report,
with preprocessed source if appropriate.
See <file:///usr/share/doc/gcc-4.9/README.Bugs> for instructions.
make[2]: *** [slave/containerizer/mesos/libmesos_no_3rdparty_la-containerizer.lo] Error 1
make[2]: *** Waiting for unfinished jobs....
mv -f log/.deps/liblog_la-log.Tpo log/.deps/liblog_la-log.Plo
mv -f slave/containerizer/.deps/libmesos_no_3rdparty_la-docker.Tpo slave/containerizer/.deps/libmesos_no_3rdparty_la-docker.Plo
mv -f log/.deps/liblog_la-consensus.Tpo log/.deps/liblog_la-consensus.Plo

mv -f slave/containerizer/.deps/libmesos_no_3rdparty_la-external_containerizer.Tpo slave/containerizer/.deps/libmesos_no_3rdparty_la-external_containerizer.Plo
mv -f log/.deps/liblog_la-coordinator.Tpo log/.deps/liblog_la-coordinator.Plo
mv -f slave/.deps/libmesos_no_3rdparty_la-slave.Tpo slave/.deps/libmesos_no_3rdparty_la-slave.Plo
mv -f master/.deps/libmesos_no_3rdparty_la-master.Tpo master/.deps/libmesos_no_3rdparty_la-master.Plo
make[2]: Leaving directory `/root/Mesos/mesos/build/src'
make[1]: *** [all] Error 2
make[1]: Leaving directory `/root/Mesos/mesos/build/src'
make: *** [all-recursive] Error 1

我该怎么办?

4 个答案:

答案 0 :(得分:48)

尝试运行(在失败之后)dmesg。

你看到这样的一条线吗?

Out of memory: Kill process 23747 (cc1plus) score 15 or sacrifice child
Killed process 23747, UID 2243, (cc1plus) total-vm:214456kB, anon-rss:178936kB, file-rss:5908kB

最有可能的是你的问题。运行make -j 8会运行大量使用更多内存的进程。当您的系统内存不足时,会出现上述问题。在这种情况下,而不是整个系统崩溃,操作系统运行一个过程来评估系统上的每个进程。得分最高的那个被操作系统杀死以释放内存。如果被杀死的进程是cc1plus,gcc(可能不正确)会将此解释为进程崩溃,因此假定它必须是编译器错误。但事实并非如此,问题是操作系统杀死了cc1plus,而不是它崩溃了。

如果是这种情况,则表示内存不足。所以运行也许make -j 4代替。这将意味着更少的并行作业,并且意味着编译将花费更长时间,但希望不会耗尽系统内存。

答案 1 :(得分:11)

(可能是内存问题)

对于任何仍在努力解决此问题的人(在提出问题后超过2年),CryptoCurrencyTalk上的this trick似乎可以使其发挥作用。

为方便起见,我在这里粘贴它:

运行这些

  • sudo dd if=/dev/zero of=/swapfile bs=64M count=16
  • sudo mkswap /swapfile
  • sudo swapon /swapfile

这应该让你编译你的代码。 但是请确保您在编译后还原swapon,并使用以下内容:

  • sudo swapoff /swapfile
  • sudo rm /swapfile

答案 2 :(得分:1)

这是我的场景(在CentOS 7上编译mesos)在AWS EC2实例上的线索。

我通过将内存和CPU增加到至少4GiB和2个vCPU来修复它。

答案 3 :(得分:1)

通过键入以下内容检查您的CentOS安装是否已启用交换功能:

sudo swapon --show

如果输出为空,则意味着您的系统未启用交换空间。

创建交换文件

1。创建一个将用作交换空间的文件。计数意味着1024M * 1024 = 1G

sudo dd if=/dev/zero of=/swapfile bs=1024 count=1048576

2。确保只有root用户才能读写交换文件:

sudo chmod 600 /swapfile

3。在文件上设置Linux交换区域

sudo mkswap /swapfile

4。激活交换

sudo swapon /swapfile

5。“ sudo swapon --show”或“ sudo free -h”,您将看到交换空间。