Java服务cpu100%的解决过程分享

 更新时间:2024年05月01日 07:37:28   作者:千云  
最近一个任务是优化一个导出的功能,但是点击功能时发现,程序长时间无反应,过一段时间又有反应,通过查看服务的监控发现,服务存在cpu持续100%的情况,下面分享一下我的处理方案和过程,需要的朋友可以参考下

背景

最近一个任务是优化一个导出的功能,但是点击功能时发现,程序长时间无反应,过一段时间又有反应,通过查看服务的监控发现,服务存在cpu持续100%的情况,下面分享一下我的处理方案和过程

处理过程

1.程序cpu监控图

2. 定位 通过查看cpu的使用率发现服务cpu100%的情况,却在两个节点上都存在问题,于是查看cpu情况

a. 登录服务器执行top命令,查看cpu使用率

-- 此图非100%时截图

b. 使用to -Hp [pid] 命令查看具体的线程占用cpu情况

我们可以看到506和856较高

c. 执行 printf "%x\n" [线程id] 将线程id转换成16进制,并在前缀前+0x,目的是等下在线程日志里面找到对应的线程具体信息,cpu最高时当时我得到的线程16进制为0x1a8

d. 执行jstack [pid] > jstack.txt

e. 通过c步骤得到的0x1a8查询jstack.txt

线程日志发现,这个线程其实是GC线程,也就说明存在fullgc导致了cpu持续过高,而fullgc都是由大对象导致的,这就以为这系统中存在着大对象。

f. 查看jvm内存情况

存在内存快照上找到了大对象

g. 查看程序日志

发现这个定时任务一直在执行,在类中发现了和大对象相同的类

e. 找到原因,此定时任务一次性查询20多万条数据到对象中,导致fullgc,关掉定时任务,服务恢复正常

结语

本次问题的原因是fullgc导致cpu使用率过高,对于cpu过高的异常很多都是偶现的,所以不太容易排查,因为基本都要在出现100%时才能看到哪些线程出问题。

以上就是Java服务cpu100%的解决过程分享的详细内容,更多关于Java服务cpu100%的资料请关注脚本之家其它相关文章!

相关文章

  • 使用IDEA如何导入SpringBoot项目

    使用IDEA如何导入SpringBoot项目

    这篇文章主要介绍了使用IDEA如何导入SpringBoot项目问题,具有很好的参考价值,希望对大家有所帮助,
    2023-12-12
  • 详解Java如何创建Annotation

    详解Java如何创建Annotation

    在本文中,我们将介绍注解的基础知识,包括注解是什么,它们如何在示例中使用,以及如何处理它们。下面和小编一起来学习吧
    2019-05-05
  • Spring中ContextLoaderListener监听详解

    Spring中ContextLoaderListener监听详解

    这篇文章主要介绍了Spring中ContextLoaderListener监听详解,SpringMVC启动时会启动WebApplicationContext类型的容器,并且会调用之前分析的refresh方法,需要的朋友可以参考下
    2024-01-01
  • Java开发环境配置教程(win7 64bit)

    Java开发环境配置教程(win7 64bit)

    这篇文章主要为大家详细介绍了win7 64bit下Java开发环境的配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Java使用Apache compress实现文件夹压缩成Zip包

    Java使用Apache compress实现文件夹压缩成Zip包

    Apache common提供了很多实用的工具包,这篇文章主要来和大家介绍一下Java如何使用Apache compress包实现文件夹压缩成Zip包,希望对大家有所帮助
    2024-01-01
  • Java中特殊运算符及其应用详解

    Java中特殊运算符及其应用详解

    当涉及位操作和位级运算时,Java 提供了一组特殊的运算符,即左移(<<)和右移(>>)运算符,下面小编就带大家深入了解一下它们的具体应用吧
    2023-08-08
  • Spring Boot集成redis,key自定义生成方式

    Spring Boot集成redis,key自定义生成方式

    这篇文章主要介绍了Spring Boot集成redis,key自定义生成方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java如何获取JSONObject内指定字段key的value值

    Java如何获取JSONObject内指定字段key的value值

    这篇文章主要介绍了Java如何获取JSONObject内指定字段key的value值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Springboot中spring-boot-starter-quartz的使用及说明

    Springboot中spring-boot-starter-quartz的使用及说明

    这篇文章主要介绍了Springboot中spring-boot-starter-quartz的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Java四种遍历Map的方法

    Java四种遍历Map的方法

    今天小编就为大家分享一篇关于Java四种遍历Map的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01

最新评论