构建Android时会忽略make -j(jobs)选项(默认为所有核心)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了构建Android时会忽略make -j(jobs)选项(默认为所有核心)相关的知识,希望对你有一定的参考价值。

我正在用这一系列命令构建android-x86(nougat-x86分支):

repo init -u git://git.osdn.net/gitroot/android-x86/manifest -b nougat-x86

repo sync --no-tags --no-clone-bundle

virtualenv2 venv

. venv/bin/activate

. build/envsetup.sh

lunch android_x86_64-userdebug

export ANDROID_JACK_VM_ARGS="-Xmx4g -XX:+TieredCompilation -Dfile.encoding=UTF-8"
export JACK_SERVER_VM_ARGUMENT=$ANDROID_JACK_VM_ARGS
export SERVER_NB_COMPILE=1
export USE_CCACHE=1

LANG=C LC_ALL=C make -j2 iso_img

请注意我是如何在最后一行使用选项-j2指定两个make作业。

无论如何,构建实际上产生了clang / clang++ / javac的8个进程以及其他任何东西。

这会导致构建失败:

超出了GC开销限制 尝试使用java选项'-Xmx'增加堆大小 警告:这可能会产生部分或损坏的输出。 忍者:构建停止:子命令失败。 make:*** [ninja_wrapper]错误1

make failed to build some targets

如何强制执行-j2选项以确保我的CPU和RAM没有达到最大值?

答案

原因:JACK服务器是邪恶的。

以下解决了out-of-ram问题:

./prebuilts/sdk/tools/jack-admin kill-server
rm -rf ~/.jack*    
export ANDROID_JACK_VM_ARGS="-Xmx4g -XX:+TieredCompilation -Dfile.encoding=UTF-8"
export SERVER_NB_COMPILE=2
export JACK_SERVER_VM_ARGUMENT=$ANDROID_JACK_VM_ARGS
./prebuilts/sdk/tools/jack-admin install-server prebuilts/sdk/tools/jack-launcher.jar prebuilts/sdk/tools/jack-server-4.*.ALPHA.jar
./prebuilts/sdk/tools/jack-admin start-server

非常感谢the FUCK JACK! project。修改过的脚本,包含issue #2PR 5的更改。


不明显的是,构建失败并不是因为MACHINE内存不足,而是因为JACK服务器已经用完了。的确,错误信息说......

尝试使用java选项'-Xmx'增加堆大小

(强调我的)。

http://www.2net.co.uk/blog/jack-server.html的这个网页解释了......

(...)让我们看看两台不同机器上的默认堆大小。默认堆大小根据所安装的内存总量进行缩放,忽略交换空间。在16 GiB机器上,它超过3 GiB:

$ java -XshowSettings 2>&1  | grep Heap
    Max. Heap Size (Estimated): 3.47G

但是,在8 GiB机器上,它小于2 GiB:

$ java -XshowSettings 2>&1  | grep Heap
    Max. Heap Size (Estimated): 1.71G

事实证明,jack-server需要大约3 GiB来构建典型的AOSP Nougat目标,因此如果机器没有足够的RAM,它就会失败。增加交换空间没有区别。

好的。因此,使用上面的命令我能够将堆大小增加到4GiB并且编译没有错误。


现在...

如何强制执行-j2选项以确保我的CPU和RAM没有达到最大值?

https://android.googlesource.com/platform/prebuilts/sdk/+/master/tools/README-jack-server.md)的页面说

config.properties文件

它包含Jack服务器配置属性。重新启动服务器后会考虑对这些设置的修改。具有默认值的描述如下:

jack.server.max-service=<number>最大并发Jack任务数。默认值为4。

(...)

如果您的计算机在编译期间无响应:

您可以通过编辑$HOME/.jack-server/config.properties并将jack.server.max-service更改为较低的值然后重新启动服务器来减少插孔同时编译的数量,从而改善这种情况。

TL; DR:

jack.server.max-service=2$HOME/.jack-server/config.properties并重新启动JACK服务器。

以上是关于构建Android时会忽略make -j(jobs)选项(默认为所有核心)的主要内容,如果未能解决你的问题,请参考以下文章

Android AOSP 构建所用的总时间

“指定的 Android SDK 构建工具版本 (26.0.0) 被忽略...”

Android studio - Proguard 似乎忽略了规则,导致构建错误

Android Uri 构建忽略参数,除非至少存在一个参数

Android make 期间编译 libusbx 失败

Android make 基础