当前位置: 首页 > 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

http://www.dtcms.com/a/204251.html

相关文章:

  • 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
  • 嵌入式学习的第二十五天-系统编程-文件相关函数-标准I0+文件IO
  • 视觉生成新突破!仅0.5B参数,SimpleAR解锁预训练、SFT、RL全能模式
  • 使用 Vue 展示 Markdown 文本
  • 【Java高阶面经:微服务篇】7. 1秒响应保障:超时控制如何成为高并发系统的“救火队长”?
  • 期刊采编系统安装升级错误
  • 软考 系统架构设计师系列知识点之杂项集萃(66)
  • Nginx负载均衡配置详解
  • 回溯算法——排列篇
  • 阿里云ecs 8核 16G 内存 装有redis6 分配了3G内存,和2个tomcat 每个tomcat 4G 服务器反应迟钝,如何确认不是redis的问题
  • web.py使用时报错AttributeError: No template named image_window