电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Tomcat進(jìn)程占用CPU過高的解決方法

瀏覽:356日期:2023-03-19 16:51:47
目錄
  • 案例
  • 上下文切換開銷?
  • 總結(jié)

CPU經(jīng)常會(huì)成為系統(tǒng)性能的瓶頸,可能:

  • 內(nèi)存泄露導(dǎo)致頻繁GC,進(jìn)而引起CPU使用率過高
  • 代碼Bug創(chuàng)建了大量的線程,導(dǎo)致CPU頻繁上下文切換

通常所說的CPU使用率過高,隱含著一個(gè)用來比較高與低的基準(zhǔn)值,比如

  • JVM在峰值負(fù)載下的平均CPU利用率40%
  • CPU使用率飆到80%就可認(rèn)為不正常

JVM進(jìn)程包含多個(gè)Java線程:

  • 一些在等待工作
  • 另一些則正在執(zhí)行任務(wù)

最重要的是找到哪些線程在消耗CPU,通過線程棧定位到問題代碼
如果沒有找到個(gè)別線程的CPU使用率特別高,考慮是否線程上下文切換導(dǎo)致了CPU使用率過高。

案例

程序模擬CPU使用率過高 - 在線程池中創(chuàng)建4096個(gè)線程

在Linux環(huán)境下啟動(dòng)程序:

java -Xss256k -jar demo-0.0.1-SNAPSHOT.jar

線程棧大小指定為256KB。對(duì)于測(cè)試程序來說,操作系統(tǒng)默認(rèn)值8192KB過大,因?yàn)樾枰獎(jiǎng)?chuàng)建4096個(gè)線程。

使用top命令,我們看到Java進(jìn)程的CPU使用率達(dá)到了961.6%,注意到進(jìn)程ID是55790。

用更精細(xì)化的top命令查看這個(gè)Java進(jìn)程中各線程使用CPU的情況:

#top -H -p 55790

可見,有個(gè)叫“scheduling-1”的線程占用了較多的CPU,達(dá)到了42.5%。因此下一步我們要找出這個(gè)線程在做什么事情。

為了找出線程在做什么,用jstack生成線程快照。
jstack輸出較大,一般將其寫入文件:

jstack 55790 > 55790.log

打開55790.log,定位到第4步中找到的名為 scheduling-1 的線程,其線程棧:

看到AbstractExecutorService#submit這個(gè)函數(shù)調(diào)用,說明它是Spring Boot啟動(dòng)的周期性任務(wù)線程,向線程池中提交任務(wù),該線程消耗了大量CPU。

上下文切換開銷?

經(jīng)歷上述過程,往往已經(jīng)可以定位到大量消耗CPU的線程及bug代碼,比如死循環(huán)。但對(duì)于該案例:Java進(jìn)程占用的CPU是961.6%, 而“scheduling-1”線程只占用了42.5%的CPU,那其它CPU被誰占用了?

第4步用top -H -p pid命令看到的線程列表中還有許多名為“pool-1-thread-x”的線程,它們單個(gè)的CPU使用率不高,但是似乎數(shù)量比較多。你可能已經(jīng)猜到,這些就是線程池中干活的線程。那剩下的CPU是不是被這些線程消耗了呢?

還需要看jstack的輸出結(jié)果,主要是看這些線程池中的線程是不是真的在干活,還是在“休息”呢?

發(fā)現(xiàn)這些“pool-1-thread-x”線程基本都處WAITING狀態(tài)。

  • Blocking指的是一個(gè)線程因?yàn)榈却R界區(qū)的鎖(Lock或者synchronized關(guān)鍵字)而被阻塞的狀態(tài),請(qǐng)你注意的是處于這個(gè)狀態(tài)的線程還沒有拿到鎖
  • Waiting指的是一個(gè)線程拿到了鎖,但需等待其他線程執(zhí)行某些操作。比如調(diào)用了Object.wait、Thread.join或LockSupport.park方法時(shí),進(jìn)入Waiting狀態(tài)。前提是這個(gè)線程已經(jīng)拿到鎖了,并且在進(jìn)入Waiting狀態(tài)前,os層面會(huì)自動(dòng)釋放鎖,當(dāng)?shù)却龡l件滿足,外部調(diào)用了Object.notify或者LockSupport.unpark方法,線程會(huì)重新競(jìng)爭(zhēng)鎖,成功獲得鎖后才能進(jìn)入到Runnable狀態(tài)繼續(xù)執(zhí)行。

回到我們的“pool-1-thread-x”線程,這些線程都處在“Waiting”狀態(tài),從線程棧我們看到,這些線程“等待”在getTask方法調(diào)用上,線程嘗試從線程池的隊(duì)列中取任務(wù),但是隊(duì)列為空,所以通過LockSupport.park調(diào)用進(jìn)到了“Waiting”狀態(tài)。那“pool-1-thread-x”線程有多少個(gè)呢?通過下面這個(gè)命令來統(tǒng)計(jì)一下,結(jié)果是4096,正好跟線程池中的線程數(shù)相等。

grep -o "pool-2-thread" 55790.log | wc -l

剩下CPU到底被誰消耗了?
應(yīng)該懷疑CPU的上下文切換開銷了,因?yàn)槲覀兛吹絁ava進(jìn)程中的線程數(shù)比較多。

下面通過vmstat命令來查看一下操作系統(tǒng)層面的線程上下文切換活動(dòng):

cs那一欄表示線程上下文切換次數(shù),in表示CPU中斷次數(shù),我們發(fā)現(xiàn)這兩個(gè)數(shù)字非常高,基本證實(shí)了我們的猜測(cè),線程上下文切切換消耗了大量CPU。
那具體是哪個(gè)進(jìn)程導(dǎo)致的呢?

停止Spring Boot程序,再次運(yùn)行vmstat命令,會(huì)看到in和cs都大幅下降,這就證實(shí)引起線程上下文切換開銷的Java進(jìn)程正是55790。

總結(jié)

遇到CPU過高,首先定位哪個(gè)進(jìn)程導(dǎo)致的,之后可以通過top -H -p pid命令定位到具體的線程。
其次還要通jstack查看線程的狀態(tài),看看線程的個(gè)數(shù)或者線程的狀態(tài),如果線程數(shù)過多,可以懷疑是線程上下文切換的開銷,我們可以通過vmstat和pidstat這兩個(gè)工具進(jìn)行確認(rèn)。

到此這篇關(guān)于Tomcat進(jìn)程占用CPU過高的解決方法的文章就介紹到這了,更多相關(guān)Tomcat進(jìn)程占用CPU過高內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: Tomcat
主站蜘蛛池模板: 影合社-影视人的内容合作平台 | 学叉车培训|叉车证报名|叉车查询|叉车证怎么考-工程机械培训网 | 精密五金冲压件_深圳五金冲压厂_钣金加工厂_五金模具加工-诚瑞丰科技股份有限公司 | cnc精密加工_数控机械加工_非标平键定制生产厂家_扬州沃佳机械有限公司 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 液压压力机,液压折弯机,液压剪板机,模锻液压机-鲁南新力机床有限公司 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 高压互感器,电流互感器,电压互感器-上海鄂互电气科技有限公司 | 滚筒烘干机_转筒烘干机_滚筒干燥机_转筒干燥机_回转烘干机_回转干燥机-设备生产厂家 | 地磅-地秤-江阴/无锡地磅-江阴天亿计量设备有限公司_ | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | 耐酸碱泵-自吸耐酸碱泵型号「品牌厂家」立式耐酸碱泵价格-昆山国宝过滤机有限公司首页 | 软文发布平台 - 云软媒网络软文直编发布营销推广平台 | 西装定制/做厂家/公司_西装订做/制价格/费用-北京圣达信西装 | 诺冠气动元件,诺冠电磁阀,海隆防爆阀,norgren气缸-山东锦隆自动化科技有限公司 | 高考志愿规划师_高考规划师_高考培训师_高报师_升学规划师_高考志愿规划师培训认证机构「向阳生涯」 | 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 抓斗式清污机|螺杆式|卷扬式启闭机|底轴驱动钢坝|污水处理闸门-方源水利机械 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | 深圳善跑体育产业集团有限公司_塑胶跑道_人造草坪_运动木地板 | 水成膜泡沫灭火剂_氟蛋白泡沫液_河南新乡骏华消防科技厂家 | HYDAC过滤器,HYDAC滤芯,现货ATOS油泵,ATOS比例阀-东莞市广联自动化科技有限公司 | NBA直播_NBA直播免费观看直播在线_NBA直播免费高清无插件在线观看-24直播网 | 大型果蔬切片机-水果冬瓜削皮机-洗菜机切菜机-肇庆市凤翔餐饮设备有限公司 | 防勒索软件_数据防泄密_Trellix(原McAfee)核心代理商_Trellix(原Fireeye)售后-广州文智信息科技有限公司 | 汕头市盛大文化传播有限公司,www.11400.cc | 知网论文检测系统入口_论文查重免费查重_中国知网论文查询_学术不端检测系统 | 武汉刮刮奖_刮刮卡印刷厂_为企业提供门票印刷_武汉合格证印刷_现金劵代金券印刷制作 - 武汉泽雅印刷有限公司 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 雷冲击高压发生器-水内冷直流高压发生器-串联谐振分压器-武汉特高压电力科技有限公司 | 继电器模组-IO端子台-plc连接线-省配线模组厂家-世麦德 | 浙江皓格药业有限公司| 联系我们老街华纳娱乐公司官网19989979996(客服) | 济宁工业提升门|济宁电动防火门|济宁快速堆积门-济宁市统一电动门有限公司 | 云南丰泰挖掘机修理厂-挖掘机维修,翻新,再制造的大型企业-云南丰泰工程机械维修有限公司 | LZ-373测厚仪-华瑞VOC气体检测仪-个人有毒气体检测仪-厂家-深圳市深博瑞仪器仪表有限公司 | 北京网站建设首页,做网站选【优站网】,专注北京网站建设,北京网站推广,天津网站建设,天津网站推广,小程序,手机APP的开发。 | 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 |