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

长春今日疫情最新消息西安seo排名扣费

长春今日疫情最新消息,西安seo排名扣费,广州建站代运营公司有哪些,软件定制开发税率是多少文章目录 问题场景问题定位问题解决 本文参考: Linux服务器之CPU过高解决思路_linux cpu温度过高_Jeremy_Lee123的博客-CSDN博客 Java程序员必备:jstack命令解析 - 掘金 (juejin.cn) 重点问题!CPU利用率过高排查思路|原创 (qq.…

文章目录

  • 问题场景
  • 问题定位
  • 问题解决

本文参考:

Linux服务器之CPU过高解决思路_linux cpu温度过高_Jeremy_Lee123的博客-CSDN博客

Java程序员必备:jstack命令解析 - 掘金 (juejin.cn)

重点问题!CPU利用率过高排查思路|原创 (qq.com)

问题场景

通常会收到监控系统告警,相关服务器负载异常,cpu使用率过高

原因:可能是业务代码死循环、GC频繁、线程阻塞等

在虚拟机上运行下面的文件:

/*** @Author jiangxuzhao* @Description* @Date 2023/8/1*/
public class CPUHigh {public static void main(String[] args) {Thread t = new Thread(()->{int a = 3;while (true) {if (a == 3) {a = a/2;}else {a = 3;}}});t.start();}
}

javac CPUHigh.java

问题定位

1.执行top 命令查看占用cpu最多的Java进程为4018。

top

在这里插入图片描述

2.看到PID,根据pid进程号去查看它的所有线程,找到对应cpu占用最多的Java线程为4030。

top -Hp 4018

在这里插入图片描述

  1. 将10进制线程id 4030转换为16进制
[root@VM-8-3-centos ~] printf '%x\n' 4030
fbe
  1. 通过jstack命令找到进程4018对应的堆栈信息,搜索其中的线程id为16进制fbe的记录
[root@VM-8-3-centos ~]# jstack 4018 | grep fbe -C 10

结果如下:

2023-08-01 22:31:43
Full thread dump OpenJDK 64-Bit Server VM (25.362-b08 mixed mode):"Attach Listener" #10 daemon prio=9 os_prio=0 tid=0x00007fa70c001000 nid=0x7000 waiting on condition [0x0000000000000000]java.lang.Thread.State: RUNNABLE"DestroyJavaVM" #9 prio=5 os_prio=0 tid=0x00007fa73404b800 nid=0xfb3 waiting on condition [0x0000000000000000]java.lang.Thread.State: RUNNABLE"Thread-0" #8 prio=5 os_prio=0 tid=0x00007fa734203800 nid=0xfbe runnable [0x00007fa71fbd2000]java.lang.Thread.State: RUNNABLEat CPUHigh.lambda$main$0(CPUHigh.java:14)at CPUHigh$$Lambda$1/471910020.run(Unknown Source)at java.lang.Thread.run(Thread.java:750)"Service Thread" #7 daemon prio=9 os_prio=0 tid=0x00007fa73412f800 nid=0xfbc runnable [0x0000000000000000]java.lang.Thread.State: RUNNABLE"C1 CompilerThread1" #6 daemon prio=9 os_prio=0 tid=0x00007fa73411d000 nid=0xfbb waiting on condition [0x0000000000000000]java.lang.Thread.State: RUNNABLE

从中可以看出问题定位在Thread-0

问题解决

对于CPU占用率飙高的场景,刚才列举的测试代码只是一种情况,还有如下可能。

1.业务线程出现大量阻塞,比如synchronized锁,可以检索状态为BLOCKED的线程找到堆栈信息,然后分析。

2.网络IO或者磁盘IO阻塞导致的,排查方法和上面一样。

3.GC线程频繁导致,线程的标识为GC task thread,对于这种情况可能是年轻代设置不合理、大对象分配过多,old区存活对象过多,具体问题具体分析。

http://www.hrbkazy.com/news/1203.html

相关文章:

  • 站长工具国色天香文案发布平台
  • 做网站值钱吗关键词推广排名软件
  • 网站建设合同审查成人教育培训机构十大排名
  • 网站建设移动网络苏州seo门户网
  • 做公司 网站建设价格低seo接单一个月能赚多少钱
  • 要写网站建设方案域名服务器地址查询
  • 360网站做二维码磁力宝
  • 毕业设计做网站论文微信广告朋友圈投放
  • 网站建设+设计那种连接线厂家百度人工服务热线电话
  • 怎样做元古建筑的网站结构图宁波seo深度优化平台
  • 团购网站APP怎么做怎么在百度上做网站
  • 做请帖网站百度移动应用
  • 建设部城管局网站抚州seo外包
  • wordpress跳转到不同分站东莞seo软件
  • 用群晖做网站服务器南京网络推广优化哪家好
  • 什么网站专门做境外当地游百度排行榜小说
  • 公司网站备案号上海网站营销seo方案
  • wordpress可以做网站吗网站首页推广
  • 公司给了个邮箱地址怎么登录优化方法
  • 网站建设实战李静百度小程序排名优化
  • 厨房装修效果图seo积分系统
  • 建设免费网站模板网站友情链接怎么弄
  • 日日干天天做网站吴中seo页面优化推广
  • 上海网站建设公司网经典软文案例200字
  • 北京网站建设 专业10年网页设计模板网站免费
  • 淘宝网站都是怎么做的市场推广外包团队
  • wd wordpress优化营商环境的金句
  • 姑苏区做网站百度云网盘官网
  • 网站后续建设网络营销推广方法
  • 建设银行咸阳交费网站张北网站seo