當開發golang程式完成後,其實有一些工具可以查看自己的程式效能,是否有些地方佔了太大的資訊進而改進,另外也可以 透過品質檢測工具去看修改建議;最後,如果有撰寫測試案例的話,也有工具可以產生測試報告,確認測試案例涵蓋了程式多少百分比,還有沒被寫到的地方也可以透過報告顯示出來.
本章介紹:
- 性能分析工具-pprof 查看CPU/memory 等的瓶頸
- 檢視go的品質與建議-gosec
- 產生測試覆蓋報表-gotest
性能分析工具-pprof
先在程式碼插入以下程式後執行。
1 | import _ "net/http/pprof" |
開啟http://localhost:8080/debug/pprof/
可以看到一個簡單的分析數字
go tool 看記憶體(heap)
透過以下指令可以看到佔記憶體的前幾名
1 | $go tool pprof http://127.0.0.1:8080/debug/pprof/heap<br> |
go tool 看CPU(profile)
而以下幾令則是幾秒內的CPU計算
1 | go tool pprof http://localhost:6060/debug/pprof/profile?seconds=60<br> |
網頁版查看 圖表
以上兩種指令其實可以透過以下指令可以開啟一個網頁更容易看到資料的圖表呈現
1 | go tool pprof -http=":9099" -seconds=30 http://localhost:8080/debug/pprof/profile |
參考文章:
golang pprof
使用多年的go pprof检查内存泄漏的方法居然是错的?!
檢視go的品質與建議
1.先下載 go set
go get github.com/securego/gosec/cmd/gosec@v2.2.0
2.輸出報告(可選格式)
1 | gosec -fmt=json -out=results.json ./...<br> |
- 然後打開HTML檔案就可以看到程式品質分析報告了
- 像是以上這條處理檔案位置時,path應該清理處理過以避免輸入異常
產生測試覆蓋(coverage)報表-gotest
事前準備:已撰寫好測試檔案
產生整個專案的測試率
1 | 測試整個專案 |
產生特定檔案測試率
1 | go test -v -cover=true myfunc_test.go myfunc.go<br> |
產生測試報告
1 | go test -coverprofile=coverage.out ./...<br> |
- 然後打開看到測試分析報告了,綠色是有涵蓋到的測試,紅色是被遺漏的測試地方,超級方便!!
參考文章:
go test 提示 no test files
Go: tests with HTML coverage report
使用 Go 进行单元测试
來源 | 摘要 |
---|---|
新手问题 golang内存检测工具 | 生产环境中使用 pprof 时会遇到一些问题 |
go pprof与线上事故:一次成功的定位与失败的复现 | 很多小伙伴担心线上使用pprof会影响性能,担心安全问题。这个在我看来利大于弊,当服务出现问题的时候,资源占用多一点点与能够解决问题相比微不足道,当服务没有问题的时候使用pprof那更没有问题了~ |
Golang 語言的單元測試和性能測試(也叫 壓力測試) | (高級測試技術) |
https://etcnotes.com/posts/pprof/ | 生成圖 |