为啥要对jvm做优化?

为啥,jvm,优化 · 浏览次数 : 154

小编点评

**jvm运行参数** 在jvm中有很多参数可以进行设置,这样可以让jvm在各种环境中都能够高效的运行。绝大部分的参数保持默认即可。 **三种参数类型** * **标准参数**:这些参数与jvm版本无关,并且在未来的JVM版本中不会改变。 * **非标准参数**:这些参数与jvm版本相关,并且在未来的JVM版本中可能会改变。 * **系统属性**:这些参数设置系统全局属性,并影响所有jvm实例。 **常见参数** * **-d32**:使用32位数据模型。 * **-d64**:使用64位数据模型。 * **-server**:选择\"server\" VM。 * **-cp**:指定类搜索路径。 * **-D**:设置系统属性。 * **-verbose**:启用详细输出。 * **-version**:输出产品版本并退出。 **实战** * **查看jvm版本**:`java -version` * **设置系统属性**:`public class TestJVM { public static void main(String[] args) { String str = System.getProperty("str"); ... } }` * **启动Server和Client模式**:`-server`或`-client`指定jvm运行模式。

正文

摘要:在jvm中有很多的参数可以进行设置,这样可以让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 -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的初始堆空间会大一些,默认使用的是并行垃圾回收器,启动慢运行快。

  • 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 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模式

 

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

与为啥要对jvm做优化?相似的内容:

为啥要对jvm做优化?

摘要:在jvm中有很多的参数可以进行设置,这样可以让jvm在各种环境中都能够高效的运行。绝大部分的参数保持默认即可。 本文分享自华为云社区《为什么需要对jvm进行优化,jvm运行参数之标准参数》,作者:共饮一杯无。 我们为什么要对jvm做优化? 在本地开发环境中我们很少会遇到需要对jvm进行优化的需

【VS Code+Qt6】拖放操作

由于老周的示例代码都是用 VS Code + CMake + Qt 写的,为了不误导人,在标题中还是加上“VS Code”好一些。 上次咱们研究了剪贴板的基本用法,也了解了叫 QMimeData 的重要类。为啥要强调这个类?因为接下来扯到的拖放操作也是和它有关系。哦,对了,咱们先避开一下主题,关于剪

设计模式:命令模式(Command Pattern)及实例

好家伙, 0.什么是命令模式 在软件系统中,“行为请求者”与“行为实现者”通常呈现一种“紧耦合”。 但在某些场合,比如要对行为进行“记录、撤销/重做、事务”等处理,这种无法抵御变化的紧耦合是不合适的。 在这种情况下,如何将“行为请求者”与“行为实现者”解耦?将一组行为抽象为对象,实现二者之间的松耦合

项目管理之八大绩效域-------笔记(一)

绪论 一、核心术语 1.预期目标 给干系人绩效域一个KPI(预期目标)来对其衡量其做的好不好,这个KPI就叫做预期目标. 2.指标及检查方法 要对目标是否做好进行评价,这个评价就是指标及检查方法 3.绩效要点 为了完成预期目标的三个KPI,应该做什么工作或者应该关注哪几个方面的活动,来达成预期目标,

调用了这么久的JS方法是长在对象、类、值本身还是原型链上?

调用了这么久的JS方法是长在对象、类、值本身还是原型链上? JavaScript这门语言总是能带给我惊喜,在敲代码的时候习以为常的写法,退一步再看看发现自己其实对很多基操只有表面的使用,而从来没思考过为何要这样操作。 今天整理JS代码的时候突然发出灵魂三连问: 为什么有些时候操作对象,可以直接调用对

将彩色图转化为灰度图及其原理介绍

本文介绍了彩色图与灰度图,为什么要转化为灰度图,及其转化为灰度图的原理,包含加权平均法与简单平均法,在明白了原理之后,直接使用OpenCV中提供的函数进行图像灰度处理,希望对你有所帮助。

[转帖]tcp 粘包 和 TCP_NODELAY 学习

https://www.cnblogs.com/zhangkele/p/9494280.html TCP通信粘包问题分析和解决 在socket网络程序中,TCP和UDP分别是面向连接和非面向连接的。因此TCP的socket编程,收发两端(客户端和服务器端)都要有成对的socket,因此,发送端为了将

使用 Python 旋转PDF页面、或调整PDF页面顺序

在将纸质文档扫描成PDF电子文档时,有时可能会出现页面方向翻转或者页面顺序混乱的情况。为了确保更好地浏览和查看PDF文件,本文将分享一个使用Python来旋转PDF页面或者调整PDF页面顺序的解决方案。 要实现Python对PDF页面进行设置,我们需要用到第三方库 Spire.PDF for Pyt

【实践篇】手把手教你落地DDD

本文通过对贫血三层架构进行精炼,推导出适合我们落地的应用架构,并且将之实现为Maven Archetype以应用到实际开发,然而应用架构只是落地DDD的一个知识点,要完整落地DDD还必须体系化地掌握限界上下文、上下文映射、充血模型、实体、值对象、领域服务、Factory、Repository等知识点。

我对微服务架构的简单理解

我理解的微服务,就是把以前一个接口一个数据库里实现的逻辑,改变为通过一级或多级远程调用去不同的服务器和数据库获取数据,然后完成整个逻辑。这也算是分布式开发技术了,每次业务要保证在多级远程调用过程中,数据的一致性,在存储数据时,因为是分不同数据库,不同服务器保存数据,有可能一个请求,要保存或更新a、b...