写点什么

为啥要对 jvm 做优化

  • 2023-02-03
    中国香港
  • 本文字数:2043 字

    阅读完需:约 7 分钟

为啥要对jvm做优化

本文分享自华为云社区《为什么需要对 jvm 进行优化,jvm 运行参数之标准参数》,作者:共饮一杯无。

我们为什么要对 jvm 做优化?


在本地开发环境中我们很少会遇到需要对 jvm 进行优化的需求,但是到了生产环境,我们可能将有下面的需求:


运行的应用 “卡住了”,日志不输出,程序没有反应服务器的 CPU 负载突然升高


在多线程应用下,如何分配线程的数量?


……


说明:使用的 jdk 版本为 1.8。

jvm 的运行参数


在 jvm 中有很多的参数可以进行设置,这样可以让 jvm 在各种环境中都能够高效的运行。绝大部分的参数保持默认即可。

三种参数类型


jvm 的参数类型分为三类,分别是:


  • 标准参数


-help-version


  • -X 参数(非标准参数,相对变化较少的)


-Xint-Xcomp


  • -XX 参数(使用率较高,JVM 调优的主要部分)


-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 -versionjava 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.javaE:\jvm>java TestJVMzjqzjqE:\jvm>java -Dstr=hello-D TestJVMhello-D
复制代码

-server 与 - client 参数


可以通过 - server 或 - client 设置 jvm 的运行参数。


它们的区别是 Server VM 的初始堆空间会大一些,默认使用的是并行垃圾回收器,启动慢运行快。


  • Client VM 相对来讲会保守一些,初始堆空间会小一些,使用串行的垃圾回收器,它的目标是为了让 JVM 的启动速度更快,但运行速度会比 Serverm 模式慢些。

  • JVM 在启动的时候会根据硬件和操作系统自动选择使用 Server 还是 Client 类型的 JVM。

  • 32 位操作系统


如果是 Windows 系统,不论硬件配置如何,都默认使用 Client 类型的 JVM。如果是其他操作系统上,机器配置有 2GB 以上的内存同时有 2 个以上 CPU 的话默认使用 server 模式,否则使用 client 模式。


  • 64 位操作系统


只有 server 类型,不支持 client 类型。


测试:


E:\jvm>java -client -showversion TestJVMjava 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)zjqzjqE:\jvm>java -server -showversion TestJVMjava 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模式
复制代码


点击关注,第一时间了解华为云新鲜技术~

发布于: 刚刚阅读数: 3
用户头像

提供全面深入的云计算技术干货 2020-07-14 加入

生于云,长于云,让开发者成为决定性力量

评论

发布
暂无评论
为啥要对jvm做优化_开发_华为云开发者联盟_InfoQ写作社区