专栏首页维C果糖记一次 JVM CPU 使用率飙高问题的排查过程
原创

记一次 JVM CPU 使用率飙高问题的排查过程

问题现象

首先,我们一起看看通过 VisualVM 监控到的机器 CPU 使用率图:

cpu-usage

如上图所示,在 下午3:45 分之前,CPU 的使用率明显飙高,最高飙到近 100%,为什么会出现这样的现象呢?

排查过程

Step 1:使用top命令,查询资源占用情况:

top

如上图所示,显示了服务器当前的资源占用情况,其中PID5456的进程占用的资源最多。

在这里,我们也使用top -p PID命令,查询指定PID的资源占用情况:

top-p

Step 2:使用ps -mp PID -o THREAD,tid,time命令,查询该进程的线程情况:

ps

在这里,我们也使用ps -mp PID -o THREAD,tid,time | sort -rn命令,将该进程下的线程按资源使用情况倒序展示:

ps-sort

Step 3:使用printf "%x\n" PID命令,将PID转为十六进制的TID

printf

在这里,我们之所以需要将PID转为十六进制是因为在堆栈信息中,PID是以十六进制形式存在的。

Step 4:使用jstack PID | grep TID -A 100命令,查询堆栈信息:

jstack

如上图所示,显示该进程下多个线程均处于TIMED_WAITING状态。

虽然线程处于WAITING或者TIMED_WAITING状态都不会消耗 CPU,但是线程频繁的挂起和唤醒却会消耗 CPU,而且代价高昂。

而上面之所以会出现 CPU 使用率飙高的情况,则是因为有人在做压测。

特别地,在 mock 底层接口的时候,使用了类似TimeUnit.SECONDS.sleep(1)这样的语句。

至于为何在 下午3:45 分之后,CPU 的使用率降下来了,则是因为停止了压测。


除此之外,我们还可以使用jinfojstat命令来查询 Java 进程的启动参数以及 GC 情况:

  • 使用jinfo PID命令,查询启动参数:
jinfo

如上图所示,使用该命令我们主要是为了查询启动参数,如初始化堆大小、垃圾回收器等配置。

  • 使用jstat -gcutil PID 1000命令,查询 GC 情况:
jstat

如上图所示,显示了PID20567的 Java 进程每秒的 GC 情况,其中1000表示 GC 状态的更新频率,单位为毫秒。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 创建 GitHub 仓库的步骤及方法

    在「GitHub 主页介绍及修改个人信息」一文中,我们已经对 GitHub 的个人主页有了一些了解,并且完成了对个人信息的修改。但是美中不足的是,我们还没有自己...

    CG国斌
  • 详述 IntelliJ IDEA 的使用界面

    是否还记得在博文“ IntelliJ IDEA 安装目录的核心文件讲解 ”中,这张充满神秘色彩的图片呢?进入她,让咱们一起感受她的魅力吧! 如上图所示,打开 I...

    CG国斌
  • 详述 IntelliJ IDEA 版本控制不显示颜色提示的解决方法

    在使用 IntelliJ IDEA 版本控制功能的时候,有一个功能点特别好,那就是对于新增文件或者修改文件,IDEA 会给出颜色提示,以区分文件类型,如新增、...

    CG国斌
  • 命名空间介绍之三:PID 命名空间

    接着前两篇命名空间文章,现在看一下 PID 命名空间。与 PID 命名空间相关的全局资源就是进程 ID 数字空间。这意味着在不同 PID 命名空间中的进程可以有...

    谛听
  • Nginx服务器的进程

    Nginx服务器的进程有3类:主进程、工作进程、缓存进程 (1)主进程 Nginx启动时运行的主要进程,主要功能是与外界通信和对内部其他进程进行管理 主要工作内...

    dys
  • 0555-6.1.0-使用Python并发访问认证和非认证集群

    Fayson在前面的文章《0553-6.1.0-如何使用Java代码同时访问安全和非安全CDH集群》和《0554-6.1.0-同一java进程中同时访问认证和非...

    Fayson
  • 深入理解Binder

    之前一直对 Binder 理解不够透彻,仅仅知道一些皮毛,所以最近抽空深入理解一下,并在这里做个小结。

    俞其荣
  • 利用HydroCMS水利设计成果管理系统进行资源整理和项目策划

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hotqin888/article/det...

    hotqin888
  • 安卓从入门到进阶第四章(调试方法)

    首先,Android是一种基于Linux的开放源代码软件栈,为广泛的设备和机型而创建。下图是Android平台的主要组件。

    程序亦非猿
  • .NET 时间轴:从出生到巨人

    自1995年互联网战略日以来最雄心勃勃的事业 —— 微软.NET战略, 2000年6月30日。

    张传宁老师

扫码关注云+社区

领取腾讯云代金券