Ubuntu 15.10でAndroidソースコードをビルドしようとしていますが、エラーが発生しました。Androidソースコード.
including ./tools/external/fat32lib/Android.mk ...
Starting build with ninja
ninja: Entering directory `.'
[ 0% 1/21542] Ensure Jack server is installed and started
Jack server already installed in "/home/smile/.jack-server"
Server is already running
[ 0% 2/21542] Building with Jack: out/target/common/obj/Java_LIBRARIES/core-all_intermediates/with-local/classes.dex
FAILED: /bin/bash out/target/common/obj/Java_LIBRARIES/core-all_intermediates/with-local/classes.dex.rsp
Java heap space
Try increasing heap size with Java option '-Xmx<size>'
Warning: This may have produced partial or corrupted output.
ninja: build stopped: subcommand failed.
build/core/ninja.mk:146: recipe for target 'ninja_wrapper' failed
make: *** [ninja_wrapper] Error 1
#### make failed to build some targets (08:25 (mm:ss)) ####
次に、「$ Java -Xmx2048m」コマンドを実行し、次の行を取得します。
smile@smile:~/Android$ Java -Xmx2048m
Usage: Java [-options] class [args...]
(to execute a class)
or Java [-options] -jar jarfile [args...]
(to execute a jar file)
where options include:
-d32 use a 32-bit data model if available
-d64 use a 64-bit data model if available
-server to select the "server" VM
-zero to select the "zero" VM
-jamvm to select the "jamvm" VM
-avian to select the "avian" VM
-dcevm to select the "dcevm" VM
The default VM is server.
-cp <class search path of directories and Zip/jar files>
-classpath <class search path of directories and Zip/jar files>
A : separated list of directories, JAR archives,
and Zip archives to search for class files.
-D<name>=<value>
set a system property
-verbose:[class|gc|jni]
enable verbose output
-version print product version and exit
-version:<value>
require the specified version to run
-showversion print product version and continue
-jre-restrict-search | -no-jre-restrict-search
include/exclude user private JREs in the version search
-? -help print this help message
-X print help on non-standard options
-ea[:<packagename>...|:<classname>]
-enableassertions[:<packagename>...|:<classname>]
enable assertions with specified granularity
-da[:<packagename>...|:<classname>]
-disableassertions[:<packagename>...|:<classname>]
disable assertions with specified granularity
-esa | -enablesystemassertions
enable system assertions
-dsa | -disablesystemassertions
disable system assertions
-agentlib:<libname>[=<options>]
load native agent library <libname>, e.g. -agentlib:hprof
see also, -agentlib:jdwp=help and -agentlib:hprof=help
-agentpath:<pathname>[=<options>]
load native agent library by full pathname
-javaagent:<jarpath>[=<options>]
load Java programming language agent, see Java.lang.instrument
-splash:<imagepath>
show splash screen with specified image
See http://www.Oracle.com/technetwork/Java/javase/documentation/index.html for more details.
ヒープサイズを増やす方法を教えてください。
あなたの助けは私に非常に感謝されます
前もって感謝します。
smile@smile:~/Android$ Java -version
Java version "1.7.0_91"
OpenJDK Runtime Environment (IcedTea 2.6.3) (7u91-2.6.3-0ubuntu0.15.10.1)
OpenJDK 64-Bit Server VM (build 24.91-b01, mixed mode)
私はちょうど同じ問題に遭遇しました。
問題は、jackを実行する仮想マシンに十分なメモリがないことです。
Jvmコマンドを編集してみてください:
JACK_VM_COMMAND=${JACK_VM_COMMAND:="Java -Xmx4096m"}
または、パラレルジャックのコンパイル数を減らす
SERVER_NB_COMPILE=2
in〜/ .jackファイル.
詳細については jack documentation を参照してください。
編集:.jackファイルを変更しても機能しませんでした。少し掘り下げた後、ジャックサーバーはout/Host/linux-x86/bin/jack-adminスクリプトで起動され、そのパラメーターはJACK_SERVER_VM_ARGUMENTS環境変数で渡すことができることがわかりました。
私の解決策は、aospをビルドする前に、それを設定し、ジャックサーバーを再起動することでした。
export JACK_SERVER_VM_ARGUMENTS="-Dfile.encoding=UTF-8 -XX:+TieredCompilation -Xmx4096m"
out/Host/linux-x86/bin/jack-admin kill-server
out/Host/linux-x86/bin/jack-admin start-server
Android Nを構築している場合、Jack構成ファイルが変更されます。移行ガイドに従って上記の推奨構成を適用します。
変更したい設定を見つけ、$HOME/.jack
から移動した場所を見つけて、そこで変更します。
サーバー1.1(例:Marshmallow)からサーバー1.3(例:N)への移行
古いJackサーバーは
$HOME/.jack
構成ファイルを使用していました。現在は、$HOME/.jack-settings
と$HOME/.jack-server/config.properties
に置き換えられています。
それらの新しいファイルが存在しない場合、
jack-admin start-server
を実行すると作成されます。
$HOME/.jack
にカスタム設定がある場合、それらを調整する方法は次のとおりです。
ステップ1
SERVER_PORT_SERVICE=XXXX
をSERVER_PORT_SERVICE=XXXX
の$HOME/.jack-settings
およびjack.server.service.port=XXXX
の$HOME/.jack-server/config.properties
に置き換えます。
ステップ2
SERVER_PORT_ADMIN=YYYY
をSERVER_PORT_ADMIN=YYYY
の$HOME/.jack-settings
およびjack.server.admin.port=YYYY
の$HOME/.jack-server/config.properties
に置き換えます。
ステップ3
SERVER_NB_COMPILE=N
でjack.server.max-service=N
の$HOME/.jack-server/config.properties
に置き換えます。
追加設定
SERVER_TIMEOUT=ZZ
はjack.server.time-out=ZZ
に置き換えることができますが、デフォルト設定の「7200」(2時間)を維持することをお勧めします。
$HOME/.jack
構成ファイルの他の設定をコピーする必要はありません。両方のバージョンのサーバーを同時に実行できるため、古いJackサーバーの$HOME/.jack
構成ファイルを保持する必要があります。
Jackサーバー から取得、詳細は Jackでコンパイル
prebuilts\sdk\toolsの下のjack_server_setup.mk
ifneq ($(Android_JACK_VM_ARGS),)
jack_vm_args := $(Android_JACK_VM_ARGS)
else
jack_vm_args := -Dfile.encoding=UTF-8 -XX:+TieredCompilation
endif
.....
ifneq ($(dist_goal),)
$(hide) mkdir -p "$(DIST_DIR)/logs/jack/"
$(hide) JACK_SERVER_VM_ARGUMENTS="$(jack_vm_args) -Dcom.Android.jack.server.log.file=$(abspath $(DIST_DIR))/logs/jack/jack-server-%u-%g.log" $(PRIVATE_JACK_ADMIN) start-server 2>&1 || exit 0
else
$(hide) JACK_SERVER_VM_ARGUMENTS="$(jack_vm_args)" $(PRIVATE_JACK_ADMIN) start-server 2>&1 || exit 0
endif
だからエクスポートできます
Android_JACK_VM_ARGS="-Dfile.encoding=UTF-8 -XX:+TieredCompilation -Xmx4g"
ジャック引数を設定します。そして、これを以下で実行します:
./prebuilts/sdk/tools/jack-admin kill-server
./prebuilts/sdk/tools/jack-admin start-server
build/core/config.mkに移動して、ヒープサイズを変更します
APICHECK_COMMAND:= $(APICHECK)-JXmx8g -J "classpath $(APICHECK_CLASSPATH)"
その後、正常に動作します。
他の解決策は役に立たなかった。
追加するだけです
export Android_JACK_VM_ARGS="-Xmx8192m -Xms512m -Dfile.encoding=UTF-8 -XX:+TieredCompilation"
。bashrcの最後までLinuxを再起動します