Go語言程序查看和診斷工具詳解
想必Java 的開發(fā)者沒有不知道或者沒用過 jps 這個(gè)命令的,這個(gè)命令是用來在主機(jī)上查看有哪些 Java 程序在運(yùn)行的。

我剛用 Go 語言程序的時(shí)候也很苦惱,我部署在公司服務(wù)器上的 Go 程序,其他的同事由于不清楚就經(jīng)常找不到。
那么 Go 語言有沒有像 jps 這樣的工具呢?當(dāng)然有,不僅有,而且還是 Google 自己出品的,官方認(rèn)證(這種問題 Google 不可能自己想不到啊)。名稱也跟 jps 很像,叫 gops。
安裝
gops 并不包含在官方安裝包中,不屬于標(biāo)準(zhǔn)工具。需要手動(dòng)獲取。
go get -u github.com/google/gops
簡單使用
goes 的使用方法非常簡單,我們看一下 help 文檔就可以了。

最簡單的用法就是 gops,會(huì)直接列出正在運(yùn)行的 Go 程序

會(huì)依次列出 PID,PPID,程序名稱,編譯使用的 Go 版本號(hào),程序路徑。信息比 jps 還詳細(xì),不錯(cuò)哦。
不止如此,gops 還能進(jìn)行程序的診斷。
診斷
可能有人注意到了上面我的 memory-test 程序后面有個(gè) * 號(hào)。這是因?yàn)槌绦蛑形壹尤肓?gops 用的診斷支持代碼:
if err := agent.Listen(agent.Options{ShutdownCleanup:true}); err != nil {
log.Fatalln(err)
}
對于這樣的程序,我們才能進(jìn)行 gops pprof-cpu 和 gops pprof-heap 等命令。(stack, gc, setgc, memstats, version, stats, trace 等命令運(yùn)行同樣需要加入上面的代碼)。
使用很簡單,就直接貼一點(diǎn)圖,不講了。



因?yàn)?go pprof 命令有助于我們分析程序,相對來說更加常用。但是以往用起來相對要麻煩一些(可參照本人另一篇《Go 程序的性能優(yōu)化及 pprof 的使用》)。現(xiàn)在有了 gops,分析 cpu 和內(nèi)存使用就跟方便了。
gops 不僅支持本地使用,而且支持遠(yuǎn)程。查看 agent.Options:

可以設(shè)置 Addr 為 host:port 形式。我這邊設(shè)置為 ":9779"。將其部署到遠(yuǎn)程服務(wù)器上,運(yùn)行命令 gops pprof-heap 192.168.199.210:9779,可以看到:

完全可行。 (注意,不僅只有 pprof-heap,gops 所有命令都支持遠(yuǎn)程)
在我們的程序中加入診斷用代碼,當(dāng)部署到遠(yuǎn)程服務(wù)器上,也能很方便地分析程序情況。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Golang實(shí)現(xiàn)超時(shí)機(jī)制讀取文件的方法示例
讀寫文件是Go程序的基本任務(wù),包括使用程序查看文件內(nèi)容、創(chuàng)建或修改文件,Go提供了os,ioutil,io以及bufio包實(shí)現(xiàn)文件操作,本文介紹如果在讀文件過程中增加超時(shí)機(jī)制,避免文件太大一直占用資源,需要的朋友可以參考下2025-01-01
golang中range在slice和map遍歷中的注意事項(xiàng)
今天小編就為大家分享一篇關(guān)于golang中range在slice和map遍歷中的注意事項(xiàng),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-04-04
構(gòu)建go鏡像實(shí)現(xiàn)過程全面講解
這篇文章主要為大家介紹了構(gòu)建go鏡像實(shí)現(xiàn)過程全面講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12

