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

jvm调优以及常见jvm问题解决等

 1、通过top命令查询异常的进程

top

2、通过 使用top -Hp<PID>命令查看该进程内各个线程的CPU占用情况:

top -Hp PID

记录下占用CPU较高的线程ID。

3、转换线程ID为十六进制

使用printf命令将线程ID 19664 转换为十六进制,结果为 0x4cd0:

printf "%x\n" <线程ID>

4、获取线程堆栈
使用jstack命令获取进程的线程堆栈信息:

# 得到线程堆栈信息中 4cd0 这个线程所在行的后面10行,从堆栈中可以发现导致cpu飙高的调用方法
jstack 19663|grep -A 10 4cd0

5、代码分析

根据堆栈信息,查看相关的Java代码。以下是一些可能导致CPU飙高的代码示例:

例如死循环,死锁等

public class BadSynchronization {  private static final Object lock1 = new Object();  private static final Object lock2 = new Object();  public static void method1() {  synchronized (lock1) {  synchronized (lock2) {  // 操作  }  }  }  public static void method2() {  synchronized (lock2) {  synchronized (lock1) {  // 操作  }  }  }  
}

6、使用性能分析工具

可以使用诸如Arthas、JProfile等Java性能分析工具进行更深入的分析。

7、查看GC日志

如果怀疑是GC问题,可以查看GC日志:

jstat -gcutil PID 1000

相关文章:

  • chrono类 根据duration 类的周期类型得到对应的周期名称
  • 基于AI大语言模型的历史文献分析在气候与灾害重建中的技术-以海南岛千年台风序列重建为例
  • 现代生活中的健康养生之道
  • 传统Spring MVC + RESTful 与 Vue3 结合 JWT Token 验证的示例
  • 双检锁(Double-Checked Locking)单例模式
  • 管理会议最佳实践:高效协同与价值最大化
  • 卫星互联网:构建全球无缝通信网络的未来
  • C#SQLServer数据库通用访问类
  • Seata源码—8.Seata Saga模式的事务处理二
  • 线程、线程池、异步
  • OpenHarmony外设驱动使用 (九),Pin_auth
  • [Harmony]自定义导航栏
  • OpenHarmony外设驱动使用 (十),Sensor
  • DeepSeek 的强化学习优化策略:RLHF 与 DPO 的应用
  • canvas(二)-动画(2d)
  • 如果有三个服务实例部署在三台不同的服务器上,这三个服务实例的本地缓存,是存储一模一样的数据?还是各自只存一部分?
  • 《算法笔记》12.1小节——字符串专题->字符串hash进阶 问题 A: 求最长公共子串(串)
  • vscode连接本地Ubuntu
  • Docker安装Fluentd采集中间件
  • OpenCV CUDA模块特征检测与描述------一种基于快速特征点检测和旋转不变的二进制描述符类cv::cuda::ORB
  • 广告公司网站模版/网页制作教程步骤
  • 网站建设 站内搜索/上海网络营销seo
  • 长春学校网站建设方案咨询/南昌企业网站建设
  • 佛山java web网站开发/跟我学seo从入门到精通
  • dedecms wap网站模板下载/seo关键词排名怎么优化
  • 做h5小游戏的网站有哪些/5g网络优化工程师