如何通过环境变量设置Java的最小和最大堆大小?
-
03-07-2019 - |
题
如何通过环境变量设置Java的最小和最大堆大小?
我知道在启动java时可以设置堆大小,但我希望在服务器上通过环境变量进行调整。
解决方案
您无法直接使用环境变量。您需要使用“非标准”组合。传递给java命令的选项。运行:java -X了解详细信息。你正在寻找的选项是-Xmx和-Xms(这是“初始”堆大小,所以你可能正在寻找它。)
某些产品(如Ant或Tomcat)可能会附带一个查找JAVA_OPTS环境变量的批处理脚本,但它不是Java运行时的一部分。如果您使用其中一种产品,则可以将变量设置为:
set JAVA_OPTS="-Xms128m -Xmx256m"
您也可以使用自己的命令行来实现此方法,如:
set JAVA_OPTS="-Xms128m -Xmx256m"
java ${JAVA_OPTS} MyClass
其他提示
如果你想要任何 java
进程,而不仅仅是ant或Tomcat,要选择 -Xmx
这样的选项,请使用环境变量 _JAVA_OPTIONS
。
在bash中: export _JAVA_OPTIONS =" -Xmx1g"
实际上,有一种方法可以通过环境变量为Sun的JVM设置全局默认值。
使用环境变量无法做到这一点。它是通过“非标准”完成的。选项。运行: java -X
了解详细信息。您正在寻找的选项是 -Xmx
和 -Xms
(这是“初始”堆大小,所以可能正是您正在寻找的。)
我认为您唯一的选择是将java包装在一个脚本中,该脚本将环境变量替换为命令行
几点说明:
-
Apache ant对JAVA_OPTS一无所知,而Tomcat的启动脚本也是如此。对于Apache ant,使用ANT_OPTS来影响运行/ ant /的JVM的环境,但不能影响ant可能启动的东西。
-
您可以设置的最大堆大小完全取决于环境:对于大多数32位系统,无论可用内存如何,您可以请求的最大堆空间量都在2GiB范围内。 64位系统上最大的堆是“非常大”。此外,您实际上也受到物理内存的限制,因为堆由JVM管理,您不希望大量交换进入磁盘。
-
对于服务器环境,您通常希望将-Xms和-Xmx设置为相同的值:这将以一定大小修复堆的大小,并且垃圾回收器的工作量较少,因为堆将永远不必重新调整大小。
醇>