A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

© 小刘同学90 中级黑马   /  2019-1-20 10:45  /  890 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

基本命令:top,vmstat,mpstat,sar,tsar
us高:用户进程消耗的CPU时间多
    原因:full gc,CMS gc,代码死循环,整体消耗CPU多等
    方案:查看gc.log ;jstat -gcutil [pid] //https://github.com/oldratlee/useful-scripts/blob/master/show-busy-javathreads.sh
sy高:内核消耗的CPU时间多
    原因:锁竞争激烈,线程主动切换频繁
    方案:jstack查看是否有锁,或者是否是线程切换频繁。//修改为无锁结构,线程切换频繁改为通知机制
        btrace ConditionObject.awaitNanos 是否存在很小值,最好是ms级别
wa高:等待IO的CPU时间多,随机IO太多或者磁盘性能问题
    原因:io读写频繁
    方案:iostat,iotop,lsof//增加缓存,同步改为异步,随机写入改为顺序写

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马