
jvm-04
发布日期:2021-05-08 05:28:16
浏览次数:19
分类:精选文章
本文共 2558 字,大约阅读时间需要 8 分钟。
jvm参数
- 标准参数:不随着jdk的版本变化而发生变化,
- 如java -version
- java -help
- -X 参数:随着jdk版本的变动而变动
- 如:-Xint(运行期解释字节码并执行)
- -XX参数
- Boolean类型 -XX:[+/-]name 启动或停止
- 非Boolean类型
- -XX:name = value
- -XX:MaxHeapSize=100M
- 其他参数[-XX参数]
- -Xms100M ===>等同于 -XX:InitialHeapSize=100M
- -Xmx100M ====> -XX:MaxHeapSize=100M
- -Xss100k ===> -XX:ThreadStackSize=100k
查看参数
- 查看所有: java -XX:+PrintFlagsFinal -version *查看某个:jinfo
参数修改:
- idea、eclipse
- 运行jar包的时候:java -XX:+UseG1GC xxx.jar
- web容器比如tomcat,可以在脚本中的进行设置
- 通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)
实践和单位换算
1Byte(字节)=8bit(位) 1KB=1024Byte(字节) 1MB=1024KB 1GB=1024MB 1TB=1024GB
常用命令
- jps
- 查看java进程
- jinfo
- 实时查看和调整jvm配置参数
- 查看:jinfo -flag name PID(查看某个java进程的name属性的值)
- jinfo -flag MaxHeapSize PID
- jinfo -flag UseG1GC PID
- 修改:参数只有被标志为manageable的flags可以被实时修改
- jinfo -flag[+|-] PID
- jinfo -flag = PID
- 查看曾经赋值过的一些参数
- jinfo -flag PID
- jstat
- 查看虚拟机性能统计信息
- jstat -class PID 1000 10 查看某个java进程的类装载信息,每1000毫秒输出一次,共输出10 次
- 查看垃圾收集信息
- jstat -gc PID 1000 10
- jstack
- 查看进程堆栈信息
- 用法 jstack PID
- 排查死锁
- 死锁代码:
class MyLockObject{public static Object object1 = new Object();public static Object object2 = new Object();}public class DealLockDemo { public static void main(String[] args) { new Thread(()->{ while (true){ synchronized (MyLockObject.object1){ System.out.println(Thread.currentThread().getName()+"获取到锁1"); synchronized (MyLockObject.object2){ System.out.println(Thread.currentThread().getName()+"获取锁2"); } } } }).start(); new Thread(()->{ while (true){ synchronized (MyLockObject.object2){ System.out.println(Thread.currentThread().getName()+"获取到锁2"); synchronized (MyLockObject.object1){ System.out.println(Thread.currentThread().getName()+"获取锁1"); } } } }).start(); }}
- 查看虚拟机性能统计信息
- jmap
- 生成堆转储快照
- 打印出堆内存相关信息
- jmap -heap PID
- dump出堆内存相关信息
- jmap -dump:format=b,file=heap.hprof 44808
- 在发生堆内存溢出的时候,自动dump出该文件
- -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=heap.hprof
常用工具
-
jconsole
-
jvisualvm
- 点击"线程" 如果有死锁,界面会提示“检测到死锁!”
- 工具–>插件–>VisualGC–>可以查看Metaspce,新生代,老年代等实时图形化信息。
- 监控远端Java进程(网上很多教程)
-
Arthas https://github.com/alibaba/arthas
-
Arthas 是Alibaba开源的Java诊断工具,采用命令行交互模式
-
Mat(相对比较强大的工具)
- 可以点击Overview–>Reports–>Leak Suspects(内存泄漏猜测)
-
在綫工具:
console.perfma.com
GC日志分析工具
- 打印GC日志:
-XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -Xloggc:gc.log
- 在线工具:
http://gceasy.io
- GCView
- 不断选择垃圾收集器,然后观测吞吐量和停顿时间的最佳值
常用参数:
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2025年03月29日 10时18分52秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
STM8 GPIO模式
2021-05-08
omnet++
2021-05-08
23种设计模式一:单例模式
2021-05-08
Qt中的析构函数
2021-05-08
C语言实现dijkstra(adjacence matrix)
2021-05-08
三层框架+sql server数据库 实战教学-徐新帅-专题视频课程
2021-05-08
【单片机开发】智能小车工程(经验总结)
2021-05-08
【单片机开发】基于stm32的掌上游戏机设计 (项目规划)
2021-05-08
C++&&STL
2021-05-08
子集(LeetCode 78)
2021-05-08
微信js-sdk使用简述(分享,扫码功能等)
2021-05-08
mxsrvs支持thinkphp3.2伪静态
2021-05-08
c++中ifstream及ofstream超详细说明
2021-05-08
vuex modules
2021-05-08
sleep、wait、yield、join——简介
2021-05-08
web项目配置
2021-05-08
基于单片机简易信号误差分析设计-全套资料
2021-05-08
基于单片机简易脉搏测量仪系统设计-毕设课设资料
2021-05-08
Javascript中String支持使用正则表达式的四种方法
2021-05-08
eclipse引用sun.misc开头的类
2021-05-08