本文分享自华为云社区《为什么需要对 jvm 进行优化,jvm 运行参数之标准参数》,作者:共饮一杯无。
我们为什么要对 jvm 做优化?
在本地开发环境中我们很少会遇到需要对 jvm 进行优化的需求,但是到了生产环境,我们可能将有下面的需求:
运行的应用 “卡住了”,日志不输出,程序没有反应服务器的 CPU 负载突然升高
在多线程应用下,如何分配线程的数量?
……
说明:使用的 jdk 版本为 1.8。
jvm 的运行参数
在 jvm 中有很多的参数可以进行设置,这样可以让 jvm 在各种环境中都能够高效的运行。绝大部分的参数保持默认即可。
三种参数类型
jvm 的参数类型分为三类,分别是:
-help-version
-Xint-Xcomp
-XX:newSize-XX:+UseSerialGC
标准参数
jvm 的标准参数,一般都是很稳定的,在未来的 JVM 版本中不会改变,可以使用 java -help 检索出所有的标准参数。
C:\Users\zjq>java -help
用法: java [-options] class [args...]
(执行类)
或 java [-options] -jar jarfile [args...]
(执行 jar 文件)
其中选项包括:
-d32 使用 32 位数据模型 (如果可用)
-d64 使用 64 位数据模型 (如果可用)
-server 选择 "server" VM
默认 VM 是 server.
-cp <目录和 zip/jar 文件的类搜索路径>
-classpath <目录和 zip/jar 文件的类搜索路径>
用 ; 分隔的目录, JAR 档案
和 ZIP 档案列表, 用于搜索类文件。
-D<名称>=<值>
设置系统属性
-verbose:[class|gc|jni]
启用详细输出
-version 输出产品版本并退出
-version:<值>
警告: 此功能已过时, 将在
未来发行版中删除。
需要指定的版本才能运行
-showversion 输出产品版本并继续
-jre-restrict-search | -no-jre-restrict-search
警告: 此功能已过时, 将在
未来发行版中删除。
在版本搜索中包括/排除用户专用 JRE
-? -help 输出此帮助消息
-X 输出非标准选项的帮助
-ea[:<packagename>...|:<classname>]
-enableassertions[:<packagename>...|:<classname>]
按指定的粒度启用断言
-da[:<packagename>...|:<classname>]
-disableassertions[:<packagename>...|:<classname>]
禁用具有指定粒度的断言
-esa | -enablesystemassertions
启用系统断言
-dsa | -disablesystemassertions
禁用系统断言
-agentlib:<libname>[=<选项>]
加载本机代理库 <libname>, 例如 -agentlib:hprof
另请参阅 -agentlib:jdwp=help 和 -agentlib:hprof=help
-agentpath:<pathname>[=<选项>]
按完整路径名加载本机代理库
-javaagent:<jarpath>[=<选项>]
加载 Java 编程语言代理, 请参阅 java.lang.instrument
-splash:<imagepath>
使用指定的图像显示启动屏幕
有关详细信息, 请参阅 http://www.oracle.com/technetwork/java/javase/documentation/index.html。
复制代码
实战
实战 1:查看 jvm 版本
C:\Users\zjq>java -version
java version "1.8.0_171"
Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)
复制代码
实战 2:通过 **-D** 设置系统属性参数
public class TestJVM {
public static void main(String[] args) {
String str = System.getProperty("str");
if(str == null){
System.out.println("zjqzjq");
}else{
System.out.println(str);
}
System.gc();
}
}
复制代码
进行编译、测试:
E:\jvm>javac TestJVM.java
E:\jvm>java TestJVM
zjqzjq
E:\jvm>java -Dstr=hello-D TestJVM
hello-D
复制代码
-server 与 - client 参数
可以通过 - server 或 - client 设置 jvm 的运行参数。
它们的区别是 Server VM 的初始堆空间会大一些,默认使用的是并行垃圾回收器,启动慢运行快。
如果是 Windows 系统,不论硬件配置如何,都默认使用 Client 类型的 JVM。如果是其他操作系统上,机器配置有 2GB 以上的内存同时有 2 个以上 CPU 的话默认使用 server 模式,否则使用 client 模式。
只有 server 类型,不支持 client 类型。
测试:
E:\jvm>java -client -showversion TestJVM
java version "1.8.0_171"
Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)
zjqzjq
E:\jvm>java -server -showversion TestJVM
java version "1.8.0_171"
Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)
zjqzjq
#由于机器是64位系统,所以不支持client模式
复制代码
点击关注,第一时间了解华为云新鲜技术~
评论