JVM调优

jvm调优步骤:1发现问题、2。定位问题、3.解决问题

jdk自带的命令行调优工具:

1. jps 查看正在运行的 Java 进程

jps -v 查看进程启动时的JVM参数

options 参数:

-q:仅仅显示 LVMID(local virtual machine id),即本地虚拟机唯一 id。不显示主类的名称等

-l:输出应用程序主类的全类名或如果进程执行的是 jar 包,则输出 jar 完整路径

-m:输出虚拟机进程启动时传递给主类 main() 的参数

-v:列出虚拟机进程启动时的 JVM 参数

2.**jstat:**查看指定进程的 JVM 统计信息

jstat -gcutil <pid> 查看堆各分区大小、YGC,FGC次数和时长

jstat -gc 1489 1000 10 表示1000 毫秒打印一次,打印10次

jstat -class <pid>

options 参数:

**-class:**显示 ClassLoader 的相关信息:类的装载、卸载数量、总空间、类装载所消耗的时间等

-gc:显示堆各分区大小、YGC,FGC次数和时长。包括 Eden 区、两个 Survivor 区、老年代、永久代等的容量、已用空间、GC 时间合计等信息

-gccapacity:显示内容与 -gc 基本相同,但输出主要关注 Java 堆各个区域使用到的最大、最小空间

-gcutil:显示内容与 -gc 基本相同,但输出主要关注已使用空间占总空间的百分比

-gccause:与 -gcutil 功能一样,但是会额外输出导致最后一次或当前正在发生的 GC 产生的原因

-gcnew:显示新生代 GC 状况

-gcnewcapacity:显示内容与 -gcnew 基本相同,输出主要关注使用到的最大、最小空间

-geold:显示老年代 GC 状况

-gcoldcapacity:显示内容与 -gcold 基本相同,输出主要关注使用到的最大、最小空间

-gcpermcapacity:显示永久代使用到的最大、最小空间

jstat -compiler :显示 JIT 编译器编译过的方法、耗时等信息

**3.jinfo:**实时查看和修改指定进程的 JVM 配置参数。

jinfo -flag查看和修改具体参数

相关推荐
u0109147601 分钟前
C#怎么使用Span和Memory C#如何用Span优化内存操作减少GC压力提升性能【进阶】
jvm·数据库·python
恼书:-(空寄2 分钟前
synchronized从偏向锁到重量级锁:JVM锁升级全流程
jvm·锁升级
m0_716430074 分钟前
CSS项目开发如何提速_应用BEM规范建立可复用的样式库
jvm·数据库·python
maqr_1105 分钟前
PyTorch bfloat16 张量转 NumPy 的兼容性解决方案
jvm·数据库·python
weixin_408717775 分钟前
mysql如何防止SQL注入攻击_使用预编译语句与参数化查询
jvm·数据库·python
somi77 分钟前
ARM-10-SQLite3 库移植笔记
jvm·笔记·sqlite
952368 分钟前
-JVM-
jvm
weixin_424999369 分钟前
http-equiv属性有哪些常用值_meta模拟HTTP头汇总【详解】
jvm·数据库·python
2301_8135995517 分钟前
持久化存储如何适配不同浏览器?解决隐私模式下存储失败的指南
jvm·数据库·python
2501_9142459319 分钟前
SQL如何高效提取大表前几行:分页查询与OFFSET优化
jvm·数据库·python