当前位置: 首页 > news >正文

Jvm调优实战笔记

一、基础命令


  1. jps 查看所有java进程

  1. jinfo 进程号 查看该线程相关信息

3、jstat 统计信息(数据跟踪信息)

jstat -gc 进程号 查看该线程在内存中每一块占用的大小

jstat -gc 进程号 时间(毫秒) 更新频率

4、jstack 跟踪线程

jstack 进程号

  1. top 查看当前系统中每个进程占用cpu和内存的信息

top -Hp 进程号 查看当前进程中所有线程的CPU和内存占用情况

CPU飚高生产环境解决思路:

top 查看所有进程中CPU最高的,拿到进程编号

top -HP 进程编号 找到CPU占用最高的线程,拿到线程编号

jstack 进程号 与上一步拿到的线程编号进行对应

看看有问题的线程到底是哪个

找到之后判断起始GC线程还是业务线程

业务线程:查看业务线程中调用了哪些方法,看是哪个方法不断循环占用CPU

GC线程:一定是在频繁的GC,排查原因是什么?

例:双十一秒杀来了一大波流量,撑不住扩机器;内存回收来会回收去总是回收不掉,这种情况就是有内存泄漏

频繁Full GC

6、jmap

作用一:查看堆内存中哪些对象占用情况

jmap -histo 进程号

jmap -histo 4878 | head -20

20表示取前20行

对比两次GC后对象数量

注意:JMAP命令不能再生产环境直接执行,会stp拿出当前进程所有对象信息

方法1:来的访问复制一份,摘下来执行

方法2:测试环境压测

作用二:产生堆内存存储文件

jmap -dump:format=b,file=20230301.hprof 进程号

文件分析工具可以使用jdk自带的

图形界面工具jvisualvm

可以直接读取jmap导出的文件分析,也可以远程连接LInux服务器分析排查问题

图形界面中分析出问题

压测环境中观察出问题

机器做了负载均衡,摘出其中一台,导出其堆存储文件

TCP down复制一份到生产环境,另一份到测试环境

图形界面工具:arthas 阿里开源

1、arthas启动方式 java -jar arthas-boot.jar
  1. help :查看arthas所有命令

dashboard :(仪表盘)

heap dump =》 jmap

thread 列出当前进程所有线程占用CPU和内存情况

thread -b 寻找死锁
jvm 查看各参数设置 =》 jinfo

more 类名.java 读取java文件
jad 类名 反编译

redefine 定义class

可以在不停止项目的情况下,修改java文件,通过javac 类名.java编译 再通过redefine 定义class上传到远程

trace 类名 方法名 :查看该方法执行时间

分布式链路追踪工具:zipkin、skywalking

7、-XX:+HeadDumpOnOutOfMemoryError 什么时候发生OOM了,什么时候自动帮忙导出堆内存存储文件

8、-Xms20M 堆内存

9、-Xmx20M 栈内存

10、-XX:+UseParallelGc 垃圾回收器

http://www.lryc.cn/news/26391.html

相关文章:

  • JVM 全面了解
  • 阿里开源自研高性能核心搜索引擎 Havenask
  • nginx日志服务之敏感信息脱敏
  • 【uni-app教程】一、UniAPP 介绍
  • Splunk Real-time Search 的研究
  • SWM181 串口功能使用介绍
  • Stochastic Approximation 随机近似方法的详解之(三)Dvoretzky’s convergence theorem
  • 7个ES6解构技巧让代码更简洁
  • 曾经被人们看成是异想天开的产业互联网,或许终将会实现
  • log4j控制台不打印日志的故障解决方案
  • C# 序列化时“检测到循环引用”错误的彻底解决方案
  • 小红书“复刻”微信,微信“内造”小红书
  • 用arthas轻松排查线上问题
  • mysql一explain结果分析
  • 原理底层计划--HashMap
  • win10 设备管理器中的黄色感叹号(华硕)
  • 新产品上市推广不是“铺货”上架
  • MATLAB训练神经网络小结
  • 实战:一天开发一款内置游戏直播的国产版Discord应用【附源码】
  • 嵌入式学习笔记——基于Cortex-M的单片机介绍
  • Python 虚拟环境的使用
  • 招生咨询|浙江大学MPA项目2023年招生问答与通知
  • Qt std :: bad_alloc
  • 《设计模式》装饰者模式
  • 一文说清Kubernetes的本质
  • 信息发布小程序【源码好优多】
  • 创新型中小企业申报流程
  • 【UE4 Cesium】加载离线地图
  • Spring面试题
  • 动态网站开发讲课笔记03:HTTP协议