亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

go語言程序cpu過高問題排查的方法詳解

 更新時間:2023年04月15日 16:18:34   作者:zoudaohoutianI  
使用golang進行復(fù)雜的組合運算,導(dǎo)致CPU占用率非常高,下面這篇文章主要給大家介紹了關(guān)于go語言程序cpu過高問題排查的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

一、前言

Go程序像C/C++一樣,如果開發(fā)編碼考慮不當,會出現(xiàn)cpu負載過高的性能問題。如果程序是線上環(huán)境或者特定場景下出現(xiàn)負載過高,問題不好復(fù)現(xiàn),則需要利用當前負載過高的進程進行調(diào)用棧分析。

C/C++中一般先通過top -d 1 -p $pid -H 命令查看負載過高的線程號(TID),然后使用gdb attach到該進程,通過thread info獲取線程信息,然后切換到對應(yīng)負載高的線程,輸入bt查看調(diào)用棧。

結(jié)合對應(yīng)代碼中的函數(shù),進一步分析。Go語言中方法也類似,我們將通過dlv來分析負載高的協(xié)程調(diào)用棧。

二、問題排查過程

2.1 通過top查看高cpu的進程pid

通過top -d 1,可以發(fā)現(xiàn)進程cava_smu(pid=11205)的cpu過高。

2.2 通過top查看高cpu的線程tid

通過上一步,我們確定了是pid=11205的cava_smu進程cpu過高,那么可以通過top -d 1 -p 11205 -H 來確認cpu過載的線程tid,如下圖所示:

通過以上操作,可以確認tid=11208,11212,11213三個線程的cpu過高。

2.3 通過dlv附加到進程,分析線程/協(xié)程cpu過載的堆棧

首先,如果生產(chǎn)環(huán)境沒有dlv,則可以拷貝對應(yīng)的dlv到/usr/local/bin下。

接著 dlv attach 11205,確認tid=11208的goroutine 序號,如下圖所示:

2.4 在dlv中切換到對應(yīng)高cpu協(xié)程,并查看堆棧

如下圖所示:

通過以上操作,可以確認業(yè)務(wù)底層的棧幀是第6→5幀,business.go:18行的disPatchTask ->business.go:168 行的dispatchIdleTeu方法相關(guān),查看對應(yīng)版本代碼如下:

代碼執(zhí)行到下圖中,dispatchIdleTeu返回了錯誤qferror.ErrNoTeu。

代碼執(zhí)行到下圖中,189行dispatchIdleTeu返回了錯誤qferror.ErrNoTeu,所以189 if的執(zhí)行語句192~212無法進入進行,而外層是一個for死循環(huán),則會造成該協(xié)程一直占用cpu,導(dǎo)致cpu過載。

修復(fù)方法可以是在for 循環(huán)內(nèi)增加sleep休眠,例如在214行處增加time.Sleep(200 * time.Millisecond),效果請自行驗證。

總結(jié)

到此這篇關(guān)于go語言程序cpu過高問題排查的文章就介紹到這了,更多相關(guān)go程序cpu過高排查內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Golang切片Slice功能操作詳情

    Golang切片Slice功能操作詳情

    這篇文章主要介紹了Golang切片功能操作詳情,切片是一個擁有相同類型元素的可變長度的序列。它是基于數(shù)組類型做的一層封,切片是一個引用類型,它的內(nèi)部結(jié)構(gòu)包含地址、長度和容量
    2022-09-09
  • go1.8之安裝配置具體步驟

    go1.8之安裝配置具體步驟

    下面小編就為大家?guī)硪黄猤o1.8之安裝配置具體步驟。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Go中函數(shù)的使用細節(jié)與注意事項詳解

    Go中函數(shù)的使用細節(jié)與注意事項詳解

    在Go語言中函數(shù)可是一等的(first-class)公民,函數(shù)類型也是一等的數(shù)據(jù)類型,下面這篇文章主要給大家介紹了關(guān)于Go中函數(shù)的使用細節(jié)與注意事項的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • Go語言調(diào)用ffmpeg-api實現(xiàn)音頻重采樣

    Go語言調(diào)用ffmpeg-api實現(xiàn)音頻重采樣

    最近對golang處理音視頻很感興趣,對golang音視頻常用庫goav進行了一番研究。自己寫了一個wav轉(zhuǎn)采樣率的功能。給大家分享一下,中間遇到了不少坑,解決的過程中還是蠻有意思的,希望大家能喜歡
    2022-12-12
  • 使用Go語言解決Scan空格結(jié)束輸入問題

    使用Go語言解決Scan空格結(jié)束輸入問題

    這篇文章主要為大家介紹了使用Go語言來解決Scan空格結(jié)束輸入問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-11-11
  • Golang中使用不定數(shù)量空格分割字符串的方法

    Golang中使用不定數(shù)量空格分割字符串的方法

    有這樣一個使用空格分割字符串的場景,字符串中被分割的子串之間的空格數(shù)量不確定,有一個兩個或者多個空格,這種場景下,使用最容易想到的strings.Split函數(shù)就做不到了,本文接下來就介紹幾種行之有效的方法,需要的朋友可以參考下
    2023-07-07
  • go語言實現(xiàn)接口查詢

    go語言實現(xiàn)接口查詢

    這篇文章主要介紹了go語言實現(xiàn)接口查詢,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 一文帶你掌握Go語言中文件的寫入操作

    一文帶你掌握Go語言中文件的寫入操作

    這篇文章主要和大家分享一下Go語言中文件的寫入操作,文中的示例代碼講解詳細,對我們學(xué)習Go語言有一定的幫助,需要的小伙伴可以參考一下
    2022-12-12
  • golang實現(xiàn)微信支付v3版本的方法

    golang實現(xiàn)微信支付v3版本的方法

    這篇文章主要介紹了golang實現(xiàn)微信支付v3版本的方法,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • GoLang OS包以及File類型詳細講解

    GoLang OS包以及File類型詳細講解

    go中對文件和目錄的操作主要集中在os包中,下面對go中用到的對文件和目錄的操作,做一個總結(jié)筆記。在go中的文件和目錄涉及到兩種類型,一個是type File struct,另一個是type Fileinfo interface
    2023-03-03

最新評論