欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

arthas排查jvm中CPU占用過高問題解決

 更新時間:2022年09月02日 11:29:47   作者:笑松小站  
這篇文章主要介紹了arthas排查jvm中CPU占用過高問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

安裝 小試

記一次使用arthas排查jvm中CPU占用過高問題。這工具屌爆了 碾壓我目前使用的全部JVM工具。

curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar --repo-mirror aliyun --use-http

jar后面的參數(shù)也可以不加 加上只是為了下載速度更快

接下來arthas 控制臺中顯示了當前機器上jvm進程列表 輸入需要排查的jvm進程號即可進入監(jiān)控命令模式

找出CPU的元兇

處理問題之前 先想想如何去找到問題的原因 這個是解決問題個人覺得最重要的一步。

當前的現(xiàn)狀是jvm啟動后 cpu直接飆升到80+%。而內(nèi)存是正常的,可以認為大概率是某個線程占用了計算資源 導致的。所以第一步需要先把占用過高線程給揪出來。

這次使用arthas排查。也順便提一下以前記錄過用top -Hp的方法找出占用資源的線程PID 方法 top -Hp方法參考 。

輸入命令 thread 查看所有線程信息 默認是按照cpu資源占用排名的

可以看到當前線程lettuce-nioEventLoop-4-1 占用cpu高達47.75。其實這個線程名稱已經(jīng)能定位到具體某個方向的問題了,所以線程名稱的定義需要有意義 為了方便排查問題。

可以看出因為我們程序使用了lettuce做redis的客戶端,主要是使用了redis stream

StreamMessageListenerContainer.StreamMessageListenerContainerOptions<String, ObjectRecord<String, String>> containerOptions =
        StreamMessageListenerContainer.StreamMessageListenerContainerOptions.builder()
                .batchSize(10) // 一次性最多拉取多少條消息
                .targetType(String.class) // 目標類型。統(tǒng)一使用 String
                .executor(mqConsumerExecutor)
                .pollTimeout(Duration.ZERO)//0不超時
                .build();

.pollTimeout(Duration.ZERO)這一句改為 .pollTimeout(Duration.ofMillis(10))cpu就正常了。

原因就是設置了永不超時 資源得不到釋放。

改為指定時間超時后 程序一點問題都沒有了。

查看線程棧的參數(shù)

可以直接使用thread pid 上圖占用最高的id為22 則輸入 thread 22 能看到類似jstack的功能

"lettuce-nioEventLoop-4-1" Id=22 RUNNABLE
    at sun.nio.ch.EPollArrayWrapper.epollWait(Native Method)
    at sun.nio.ch.EPollArrayWrapper.poll(EPollArrayWrapper.java:269)
    at sun.nio.ch.EPollSelectorImpl.doSelect(EPollSelectorImpl.java:93)
    at sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:86)
    at sun.nio.ch.SelectorImpl.select(SelectorImpl.java:97)
    at sun.nio.ch.SelectorImpl.select(SelectorImpl.java:101)

還有一個更好用的命令 -n參數(shù)能顯示top-n-threads 比上面一種更詳細

"lettuce-nioEventLoop-4-1" Id=22 cpuUsage=49.51% deltaTime=99ms time=392976ms RUNNABLE
    at sun.nio.ch.EPollArrayWrapper.epollWait(Native Method)
    at sun.nio.ch.EPollArrayWrapper.poll(EPollArrayWrapper.java:269)
    at sun.nio.ch.EPollSelectorImpl.doSelect(EPollSelectorImpl.java:93)
    at sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:86)
    at sun.nio.ch.SelectorImpl.select(SelectorImpl.java:97)
    at sun.nio.ch.SelectorImpl.select(SelectorImpl.java:101)

可以看出使用arthas排除這類問題 比使用top -Hp方便太多。當然這只是它的一個小功能而已。

以上就是arthas排查jvm中CPU占用過高問題解決的詳細內(nèi)容,更多關于arthas排查jvm CPU過高的資料請關注腳本之家其它相關文章!

相關文章

  • Java實現(xiàn)Excel導入導出數(shù)據(jù)庫的方法示例

    Java實現(xiàn)Excel導入導出數(shù)據(jù)庫的方法示例

    這篇文章主要介紹了Java實現(xiàn)Excel導入導出數(shù)據(jù)庫的方法,結(jié)合實例形式分析了java針對Excel的讀寫及數(shù)據(jù)庫操作相關實現(xiàn)技巧,需要的朋友可以參考下
    2017-08-08
  • 詳解Spring Boot2 Webflux的全局異常處理

    詳解Spring Boot2 Webflux的全局異常處理

    這篇文章主要介紹了詳解Spring Boot2 Webflux的全局異常處理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • SpringBoot整合Solr實現(xiàn)文檔檢索

    SpringBoot整合Solr實現(xiàn)文檔檢索

    Solr高度可靠、可擴展和容錯,提供分布式索引、復制和負載平衡查詢、自動故障轉(zhuǎn)移和恢復、集中配置等,Solr 為世界上許多最大的 Internet 站點的搜索和導航功能提供支持,本文將給大家介紹SpringBoot整合Solr實現(xiàn)文檔檢索,需要的朋友可以參考下
    2023-08-08
  • Java AbstractMethodError原因案例詳解

    Java AbstractMethodError原因案例詳解

    這篇文章主要介紹了Java AbstractMethodError原因案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java實現(xiàn)最小生成樹算法詳解

    Java實現(xiàn)最小生成樹算法詳解

    這篇文章主要介紹了如何在Java中實現(xiàn)最小生成樹算法,文中的示例代碼講解詳細,對我們學習Java有一定幫助,需要的可以參考一下
    2022-04-04
  • Java Swing BoxLayout箱式布局的實現(xiàn)代碼

    Java Swing BoxLayout箱式布局的實現(xiàn)代碼

    這篇文章主要介紹了Java Swing BoxLayout箱式布局的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • Java別名Alias是如何工作的

    Java別名Alias是如何工作的

    這篇文章主要介紹了Java別名Alias是如何工作的,別名的問題是,當用戶寫入特定對象時,其他幾個引用的所有者不希望該對象發(fā)生更改,下文相關介紹需要的小伙伴可以參考一下
    2022-04-04
  • 基于params、@PathVariabl和@RequestParam的用法與區(qū)別說明

    基于params、@PathVariabl和@RequestParam的用法與區(qū)別說明

    這篇文章主要介紹了方法參數(shù)相關屬性params、@PathVariabl和@RequestParam用法與區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • java實現(xiàn)memcache服務器的示例代碼

    java實現(xiàn)memcache服務器的示例代碼

    本篇文章主要介紹了java實現(xiàn)memcache服務器的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • springboot訪問404問題的解決辦法

    springboot訪問404問題的解決辦法

    工作中遇到url404問題,解決問題的進程比較崎嶇,寫篇文章記錄,下面這篇文章主要給大家介紹了關于springboot訪問404問題的解決辦法,文中通過圖文介紹的非常詳細,要的朋友可以參考下
    2023-03-03

最新評論