精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

美團一面,你碰到過CPU 100%的情況嗎?你是怎么處理的?

開發(fā) 前端
為了防止并發(fā)場景中,多個線程修改公共資源,導致的數(shù)據(jù)異常問題,很多時候我們會在代碼中使用synchronized?或者Lock加鎖。

CPU被打滿的常見原因

1. 死循環(huán)

在實際工作中,可能每個開發(fā)都寫過死循環(huán)的代碼。

死循環(huán)有兩種:

  1. 在 while、for、forEach 循環(huán)中的死循環(huán)。
  2. 無限遞歸。

這兩種情況,程序會不停地運行,使用寄存器保存循環(huán)次數(shù)或者遞歸深度,一直占用 cpu,導致 cpu 使用率飆升。

在使用 JDK1.7 時,還有些死循環(huán)比如多線程的環(huán)境下,往 HashMap 中 put 數(shù)據(jù),可能會導致鏈表出現(xiàn)死循環(huán)。

就會導致cpu不斷飆高。

2.大量GC

我之前參與過餐飲相關(guān)的業(yè)務(wù)系統(tǒng)開發(fā),當時我所在的團隊是菜品的下游業(yè)務(wù)。

當時菜品系統(tǒng)有菜品的更新,會發(fā)kafka消息,我們系統(tǒng)訂閱該topic,就能獲取到最近更新的菜品數(shù)據(jù)。

同步菜品數(shù)據(jù)的功能,上線了一年多的時候,沒有出現(xiàn)過什么問題。

但在某一天下午,我們收到了大量 CPU100% 的報警郵件。

追查原因之后發(fā)現(xiàn),菜品系統(tǒng)出現(xiàn)了 bug,我們每次獲取到的都是全量的菜品數(shù)據(jù),并非增量的數(shù)據(jù)。

一次性獲取的數(shù)據(jù)太多。

菜品修改還是比較頻繁的,也就是說我們系統(tǒng),會頻繁地讀取和解析大量的數(shù)據(jù),導致 CPU 不斷飆升。

其根本原因是頻繁的full gc。

3. 大量計算密集型任務(wù)

有時候,我們的業(yè)務(wù)系統(tǒng)需要實時計算數(shù)據(jù),比如:電商系統(tǒng)中需要實時計算優(yōu)惠后的最終價格。

或者需要在代碼中,從一堆數(shù)據(jù)中,統(tǒng)計匯總出我們所需要的數(shù)據(jù)。

如果這個實時計算或者實時統(tǒng)計的場景,是一個非常耗時的操作,并且該場景的請求并發(fā)量還不小,就可能會導致 cpu 飆高。

因為實時計算需要消耗 cpu 資源,如果一直計算,就會一直消耗 cpu 資源。

4. 死鎖

為了防止并發(fā)場景中,多個線程修改公共資源,導致的數(shù)據(jù)異常問題,很多時候我們會在代碼中使用synchronized或者Lock加鎖。

這樣多個線程進入臨界方法或者代碼段時,需要競爭某個對象或者類的鎖,只有搶到相應的鎖,才能訪問臨界資源。其他的線程,則需要等待,擁有鎖的線程釋放鎖,下一次可以繼續(xù)競爭那把鎖。

有些業(yè)務(wù)場景中,某段代碼需要線程獲取多把鎖,才能完成業(yè)務(wù)邏輯。

但由于代碼的 bug,或者釋放鎖的順序不正確,可能會引起死鎖的問題。

例如:

"pool-4-thread-1" prio=10 tid=0x00007f27bc11a000 nid=0x2ae9 waiting on condition [0x00007f2768ef9000]
java.lang.Thread.State: WAITING (parking)
at sun.misc.Unsafe.park(Native Method)
- parking to wait for  <0x0000000090e1d048> (a java.util.concurrent.locks.ReentrantLock$FairSync)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)

比如線程 a 擁有鎖 c,需要獲取鎖 d,才能完成業(yè)務(wù)邏輯。

而剛好此時線程 b 擁有鎖 d,需要獲取鎖 c,才能完成業(yè)務(wù)邏輯。

線程 a 等待線程 b 釋放鎖,而線程 b 等待線程 a 釋放鎖,兩個線程都持有對方需要的鎖,無法主動釋放,就會出現(xiàn)死鎖問題。

死鎖會導致 CPU 使用率飆升。

CPU被打滿如何排查

1. 使用系統(tǒng)工具和JDK自帶的jstack工具

第一步:使用top命令找出占用CPU最高的Java進程

首先,使用top命令確認是不是Java進程是罪魁禍首。Java進程要么是個后臺任務(wù),要么是個jar包,比如一個Spring Boot服務(wù)。

圖片圖片

假設(shè)發(fā)現(xiàn)占用CPU 99.7%的線程是Java進程,進程PID為13731。

第二步:找到占用CPU最高的線程

接下來,還是用top命令,只不過加一個參數(shù)-Hp,就是下面這樣:

top -Hp 13731

H參數(shù)表示要顯示線程級別的信息,p則表示指定的pid,也就是進程ID。執(zhí)行之后,這個Java進程中占用線程占用CPU的情況就列出來了。假設(shè)占用CPU最高的那個線程PID為13756。

圖片圖片

第三步:保存線程堆棧信息

這就要用到JDK默認提供的一個工具——jstack。jstack用于生成Java進程的線程快照(thread dump)。線程快照是一個關(guān)于Java進程中所有線程當前狀態(tài)的快照,包括每個線程的堆棧信息。通過分析線程快照,可以了解Java進程中各個線程的運行狀態(tài)、鎖信息等。

我們用jstack的目的是將那個占用CPU最高的線程的堆棧信息搞下來,然后進一步分析。使用命令jstack pid > out.log將某個進程的堆棧信息輸出到out.log文件中。

jstack 13731 > thread_stack.log

第四步:在線程棧中查找罪魁禍首的線程

將13756轉(zhuǎn)換為16進制,可以用在線進制轉(zhuǎn)換工具直接轉(zhuǎn)換,比如這個。轉(zhuǎn)換結(jié)果為0x35bc。

然后在線程棧中,也就是上一步保存的那個thread_stack.log文件,查找這個16進制的線程ID(0x35bc)。

這樣,我們就能看到需要的線程名稱、線程狀態(tài),哪個方法的哪一行代碼消耗了最多的CPU都很清楚了。

圖片圖片

2. 使用Arthas探測工具

Arthas是阿里開源的一款線上監(jiān)控診斷產(chǎn)品,通過全局視角實時查看應用load、內(nèi)存、GC、線程的狀態(tài)信息,并能在不修改應用代碼的情況下,對業(yè)務(wù)問題進行診斷,包括查看方法調(diào)用的入?yún)ⅰ惓#O(jiān)測方法執(zhí)行耗時,類加載信息等,大大提升線上問題排查效率。

安裝Arthas

要使用Arthas,你需要先把它安裝到你的目標服務(wù)器上。

  1. 下載jar包:
curl -O https://arthas.aliyun.com/arthas-boot.jar
  1. 啟動Arthas服務(wù):
java -jar arthas-boot.jar

啟動之后,會列出當前這臺服務(wù)器上的所有Java進程,選擇你要排查的那個服務(wù)即可。出現(xiàn)arthas@之后表示已經(jīng)啟動,并成功attach到目標進程上。

圖片圖片

可以輸入命令dashboard看一下實時面板,默認5秒刷新一次,在這個面板上能夠看到線程、內(nèi)存堆棧、GC和Runtime的基本信息。如果你用過VisualVM的話,操作界面與之類似。

找到占用CPU最高的線程

執(zhí)行thread命令,這個命令會顯示所有線程的信息,并且把CPU使用率高的線程排在前面。

這樣,一眼就看出來了,第一個線程的CPU使用率高達99%。

圖片圖片

查看堆棧信息

使用thread ID獲取堆棧信息,其實就是jstack pid相同的作用。通過前一步看到這個線程的ID是18,然后執(zhí)行:

thread 18

圖片圖片

直接就看出來了出現(xiàn)問題的位置,比如TestController.java文件的high方法的第23行。然后可以進入代碼查看具體問題。

參考答案

面試官:“你碰到過CPU 100%的情況嗎?你是怎么處理的?”

生產(chǎn)環(huán)境如果cpu已經(jīng)被打滿了,不要一上來就說什么top,jstack,記住,真實的生產(chǎn)環(huán)境如果CPU已經(jīng)要被打爆了的話

第一選擇肯定是重啟,并且如果你近段時間有發(fā)布的話,還要考慮是否可以回滾,保障生產(chǎn)環(huán)境的穩(wěn)定性是最重要的

還有就是,如果CPU已經(jīng)被打爆了,不管arthas還是jstack大概率也是執(zhí)行不了的,jvm無法響應

我:“之前碰到過CPU被打滿的情況,我們線上第一時間做了重啟,在重啟的過程中,我們?nèi)ゲ榱朔?wù)在那段時間的日志、鏈路、指標,沒有發(fā)現(xiàn)特殊的異常。”

有時候CPU100&會伴隨非常明顯的日志、鏈路或者指標異常。例如:通過gc的指標發(fā)現(xiàn),發(fā)現(xiàn)full gc的次數(shù)激增,或者發(fā)現(xiàn)內(nèi)存的使用率很高,這個時候大概率是因為gc導致的cpu 100%。這個時候就不要再去jstack了,應該第一次時間查看堆dump文件,確認是哪個對象占用了大量內(nèi)存

我:“當服務(wù)重啟完成后,我們開始排查具體的原因。我們通過定期執(zhí)行top命令,發(fā)現(xiàn)java進程的CPU的使用率確實在慢慢增加”

我:“接著,我通過top -Hp以及jstack命令拿到了應用里cpu使用率最高的那個線程的堆棧,通過分析堆棧最終定位到了具體的代碼,是因為代碼觸發(fā)了一個臨界值,進入了死循環(huán)”

下面這段代碼是我實際工作碰到一個導致線上CPU 100%的代碼:

public ShortUrlRandomSeed getAvailableSeed()  {
  MachineInfo machineInfo = UrlConverUtil.getMachineInfo();
  for (; ; ) {
    // 獲取種子
    ShortUrlRandomSeed seed = shortUrlSeedService.getAvailableSeed(machineInfo);
    if (seed != null) {
      int influenceNum = shortUrlSeedService.updateSeedStatus(seed.getId());
      if (influenceNum > 0) {
        return seed;
      }
    }
  }
}

這段代碼的作用是為了獲取一個種子用于短鏈的生成,在項目上線之初預生成了接近21w個種子,這個代碼在線上跑了3年了一直沒有問題,直到去年的某一天,21w個種子用光了,seed一直為null,開始死循環(huán),最終導致CPU 100%

責任編輯:武曉燕 來源: 明智說
相關(guān)推薦

2025-03-25 12:00:00

@Value?Spring開發(fā)

2023-02-27 09:03:23

JavaCAS

2024-04-24 09:02:58

線程池面試鎖升級

2024-04-01 00:00:00

Redis緩存服務(wù)消息隊列

2024-10-31 08:50:14

2025-04-27 01:30:01

業(yè)務(wù)系統(tǒng)QPS

2021-08-29 18:36:17

MySQL技術(shù)面試題

2023-07-13 09:16:47

循環(huán)隊列指針front?

2025-04-15 08:00:00

Java開發(fā)服務(wù)網(wǎng)格

2025-03-07 00:11:00

JWTJSONSession

2018-07-09 08:35:45

Windows 10WindowsBug

2023-04-03 07:57:00

2023-04-21 13:57:38

Redis阻塞半自動

2024-04-22 00:00:00

CASCPU硬件

2022-01-05 21:54:51

網(wǎng)絡(luò)分層系統(tǒng)

2022-06-15 09:02:32

JVM線程openJDK

2022-02-10 09:04:50

架構(gòu)

2024-04-08 00:00:00

asyncawaiPromise

2022-11-30 17:13:05

MySQLDynamic存儲

2024-04-17 08:02:29

接口refused程序
點贊
收藏

51CTO技術(shù)棧公眾號

欧美日韩国产中文| 国产99精品国产| 日韩亚洲在线观看| avtt中文字幕| 色综合亚洲图丝熟| 国产精品免费看片| 成人xxxxx色| 9i看片成人免费看片| 婷婷六月综合| 日韩av网站导航| 亚洲最大成人在线观看| av大片在线| 久久奇米777| 99久久伊人精品影院| www.久久久久久久| 午夜日本精品| 一区二区三区亚洲| 白丝校花扒腿让我c| 一呦二呦三呦精品国产| 一区二区高清免费观看影视大全| 欧美极品一区| 草草视频在线播放| 青青草精品视频| 国内精品久久久久久| 婷婷国产成人精品视频| 日韩高清电影免费| 欧美岛国在线观看| 在线观看国产一级片| 国产高清自产拍av在线| 亚洲欧美日韩国产综合在线| 蜜桃视频在线观看91| 国内老熟妇对白hdxxxx| 免费视频最近日韩| 5278欧美一区二区三区| 国产精品老熟女一区二区| av在线不卡顿| 亚洲欧美日韩中文视频| 香港三日本8a三级少妇三级99| 国产精品亚洲一区二区在线观看 | 欧美高清性xxxxhd| 亚洲精品字幕在线| 国产一区二区在线观看视频| 国产精品第一第二| 国产一区免费看| 亚洲在线成人| 欧洲成人在线观看| 免费在线不卡视频| 日韩午夜在线电影| 国内精品久久久久久久| 精品无码久久久久久久| 欧美777四色影| 欧美成人在线影院| 黑鬼狂亚洲人videos| 午夜欧美在线| 久久精品视频播放| 四虎884aa成人精品| 99久久激情| 搡老女人一区二区三区视频tv| 性少妇xx生活| 色婷婷色综合| 日韩中文字幕av| 欧美激情精品久久久久久免费| 99久久99视频只有精品| 欧美成人精品影院| 久久免费在线观看视频| 亚洲三级电影在线观看| 8090成年在线看片午夜| av中文在线播放| 久久一综合视频| 国产精品免费一区| 国产免费av观看| 国产91丝袜在线播放| 成人精品水蜜桃| 神宫寺奈绪一区二区三区| 波多野结衣91| 欧美黄色直播| 中文字幕日本在线| 亚洲人成小说网站色在线| 日本老太婆做爰视频| 国产精品蜜臀| 色婷婷av一区二区三区大白胸| 黄色高清无遮挡| 日韩成人综合网| 精品少妇一区二区三区在线播放| 欧美一级片黄色| 精品国产一区二区三区久久久蜜臀 | 成人日韩在线视频| 日韩精品一区国产| 亚洲精品一区二区久| 成人一级片免费看| 亚洲精品1区2区| 国产成人在线播放| 亚洲av无码乱码国产麻豆| 91免费看片在线观看| 中文字幕不卡每日更新1区2区| 欧美videossex| 色噜噜久久综合| 久久发布国产伦子伦精品| 蜜桃一区av| 色噜噜久久综合伊人一本| 久久久久久久9999| 日韩精品成人一区二区在线| 亚洲自拍小视频免费观看| 色鬼7777久久| 亚洲精品一二三四区| 久久久久久久久久久久久国产精品| 91在线亚洲| 日韩电视剧免费观看网站| 久久噜噜色综合一区二区| 99国产精品99久久久久久粉嫩| 国产美女精彩久久| 午夜在线观看视频18| 亚洲欧美乱综合| 成人精品视频一区二区| 中文字幕日韩高清在线| 最近更新的2019中文字幕| 国产手机在线视频| 国产精品911| 蜜桃传媒视频麻豆第一区免费观看 | 国产欧美日产一区| 国产中文字幕二区| 日韩在线亚洲| 久久久精品国产| 中文字幕日本视频| 久久亚洲一级片| 九九热只有这里有精品| 国产一区二区久久久久| 最好看的2019年中文视频 | 在线中文字幕第一页| 欧美午夜在线观看| 好吊日免费视频| 亚洲国产91| av免费观看久久| 黄网站在线播放| 在线观看91精品国产入口| 国产偷人妻精品一区| 亚洲夜间福利| 97se亚洲综合| 操你啦视频在线| 欧美精品久久天天躁| youjizz亚洲女人| 天堂午夜影视日韩欧美一区二区| www久久99| 欧美hdxxxxx| 日韩欧美二区三区| 劲爆欧美第一页| 国产成人在线视频网站| 日本a级片在线观看| 亚洲欧洲二区| 久久天天躁狠狠躁夜夜av| 国产精品一二三四五区| 亚洲欧美日韩国产一区二区三区| 网站在线你懂的| 图片区亚洲欧美小说区| 亚洲一区二区三区在线视频| 在线视频中文字幕第一页| 日韩亚洲欧美中文三级| 久久久久久久久精| 懂色av中文一区二区三区| www.日本在线视频| 亲子伦视频一区二区三区| 欧美中文字幕在线| 美女毛片在线看| 欧美综合在线视频| 一级黄色片日本| 丰满白嫩尤物一区二区| 妞干网在线视频观看| 亚欧洲精品视频在线观看| 欧美在线不卡区| 国产精品秘入口| 欧美日韩国产成人在线免费| 东方av正在进入| 99久久综合国产精品| 国产又黄又猛视频| 国产精品毛片久久| 99蜜桃在线观看免费视频网站| 成人一级福利| 在线视频免费一区二区| 国产美女www爽爽爽视频| 亚洲福利电影网| 加勒比一区二区| 精品一区中文字幕| 91动漫在线看| 狠狠综合久久av一区二区蜜桃| 国产欧美精品在线| 91破解版在线观看| 中文字幕在线观看亚洲| 懂色av成人一区二区三区| 色呦呦日韩精品| 欧美特级一级片| 2020国产精品| 亚洲欧美日韩网站| 男人的天堂亚洲在线| 手机成人在线| 国产精品久久久久久久久久白浆| 国产精品99久久久久久久久久久久 | 亚洲天堂视频在线| 亚洲午夜免费视频| 91免费在线看片| 99久久精品国产一区二区三区| 中文字幕av不卡在线| 1024日韩| 国产又大又长又粗又黄| 三级精品视频| 亚洲自拍偷拍在线| 成人涩涩视频| 91黑丝高跟在线| 成人免费观看视频大全| 欧美天堂社区| 日本不卡免费高清视频| 91麻豆一二三四在线| 亚洲欧美日韩成人| 亚洲国产一二三区| 欧美精选在线播放| 日韩在线 中文字幕| 一区二区在线观看免费| 亚洲第一综合网| bt欧美亚洲午夜电影天堂| av在线网址导航| 日韩精品欧美成人高清一区二区| 成年人视频大全| 999视频精品| 日韩高清国产精品| 美女视频亚洲色图| 成人动漫视频在线观看免费| 欧美激情福利| 国产精品久久久久9999| 国产传媒在线| 午夜精品久久久99热福利| 欧美激情办公室videoshd| 亚洲欧洲一区二区三区在线观看| 丰满人妻av一区二区三区| 在线综合视频播放| 在线观看国产精品入口男同| 91国偷自产一区二区开放时间 | 色av一区二区| 日本一区二区三区免费视频| 一区二区三区毛片| 一区二区在线观看免费视频| **性色生活片久久毛片| 国产传媒在线看| 欧美国产精品专区| 99精品全国免费观看| 国产人成亚洲第一网站在线播放| 无套内谢大学处破女www小说| 99视频一区二区| 国产黑丝在线观看| 99热99精品| 中国av免费看| 久久综合av免费| 摸摸摸bbb毛毛毛片| 国产欧美精品一区| 国产欧美小视频| 中文字幕一区日韩精品欧美| 日韩av片在线免费观看| 《视频一区视频二区| 日日骚一区二区三区| 一区二区三区成人| 日本熟妇成熟毛茸茸| 精品国产鲁一鲁一区二区张丽| 人妻 日韩精品 中文字幕| 一本一本久久a久久精品综合麻豆| youjizz在线视频| 欧美中文字幕一区二区三区| 亚洲天天综合网| 日韩午夜激情视频| 日韩一级在线播放| 亚洲欧美第一页| 91啦中文在线| 欧美理论片在线观看| 密臀av在线播放| 国产精品福利在线| 99久久99九九99九九九| 国产激情一区二区三区在线观看| 久久精品色综合| 日韩欧美99| 国产精品国产一区| 妺妺窝人体色777777| 美女黄色成人网| 国产在线观看中文字幕| 成人动漫在线一区| 欧美丰满美乳xxⅹ高潮www| 亚洲欧美日韩小说| 久久狠狠高潮亚洲精品| 欧美亚日韩国产aⅴ精品中极品| 国产女人高潮的av毛片| 亚洲国产成人精品女人久久久| 丁香婷婷在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 51精品在线| 国产精品揄拍500视频| 极品束缚调教一区二区网站| 亚洲精品自在在线观看| 亚洲久久成人| 一区二区三区四区毛片| 99久久99久久精品国产片果冻| 久草手机视频在线观看| 精品久久中文字幕| 国产精品欧美久久久久天天影视| 亚洲国产精品人久久电影| 在线免费观看黄色av| 91精品国产乱码久久久久久久久 | 国产综合精品一区二区三区| 成人91在线| 东北少妇不带套对白| 美日韩一级片在线观看| 天天插天天射天天干| 亚洲精品久久嫩草网站秘色| 久久久国产免费| 亚洲国产第一页| av在线免费观看网址| 国产精品扒开腿做爽爽爽男男| a级日韩大片| 久久久国产精华液999999| 久久婷婷一区| a天堂视频在线观看| 一区二区三区中文字幕在线观看| www.久久网| 亚洲跨种族黑人xxx| 国精产品一区一区三区mba下载| 国产精品福利在线| 妖精一区二区三区精品视频| 免费特级黄色片| 国产成人8x视频一区二区| 美女视频久久久| 欧美亚洲国产一区二区三区| 日韩电影免费| 韩国国内大量揄拍精品视频| 激情视频亚洲| 国产日本欧美在线| 奇米影视在线99精品| 欧美大波大乳巨大乳| 欧美视频裸体精品| 色香蕉在线视频| 欧美激情视频三区| 日韩在线成人| 波多野结衣 作品| 狠狠色丁香久久婷婷综合丁香| 超碰人人干人人| 欧美视频中文一区二区三区在线观看 | 精品一区二区三区在线播放视频 | 国产精品久久久久久久久借妻 | 欧美极品xxx| 日韩美一区二区| 精品无码久久久久久国产| 国产精选在线| 久久久久久久久四区三区| 最新成人av网站| 久久福利小视频| 激情懂色av一区av二区av| 色窝窝无码一区二区三区成人网站| 国精产品一区一区三区有限在线| av成人综合| 精品久久一二三| 久久亚洲精华国产精华液| 国产一级免费视频| 一区二区成人精品| 福利一区二区免费视频| 天天综合中文字幕| 国产一区二区三区不卡在线观看| 精国产品一区二区三区a片| 精品裸体舞一区二区三区| 免费高潮视频95在线观看网站| 噜噜噜噜噜久久久久久91| 日韩av一级片| 免费高清在线观看电视| 日韩精品在线网站| 热三久草你在线| 翔田千里亚洲一二三区| 国产在线视频一区二区三区| 国产免费无码一区二区视频| 亚洲第一精品夜夜躁人人爽 | 亚洲专区区免费| 欧美这里有精品| 成人日日夜夜| 国产精品推荐精品| 久久久蜜桃一区二区人| 三上悠亚作品在线观看| 精品国产3级a| 日韩三区免费| 日韩精品手机在线观看| 99国产精品视频免费观看| 瑟瑟视频在线免费观看| 久久99久久亚洲国产| 婷婷激情久久| 日日干日日操日日射| 精品免费在线视频| 中文字幕在线视频区| 国产精选一区二区| 毛片不卡一区二区| 日韩精品在线免费看| 中文字幕亚洲欧美在线| 国产厕拍一区| 色一情一区二区| 精品人伦一区二区三区蜜桃免费| 免费av网站在线观看| 蜜桃精品久久久久久久免费影院| 激情成人午夜视频| 亚洲欧美综合自拍| 久久国产精品久久久久久久久久 |