如何查看golang程序中有哪些goroutine 正在执行


查看 正在执行的goroutine分两步:

1.程序中引入pprof pakage

在程序中引入pprof package:

import _ "net/http/pprof"

程序中开启HTTP监听服务:


package main

import (
        _ "net/http/pprof"
        "net/http"

)

func main() {

        go func() {
                log.Println(http.ListenAndServe("localhost:6060", nil))
        }()

        select{}
}

2.下载并分析goroutine文件

浏览器中打开链接127.0.0.1:6060/debug/pprof/goroutine
会下载goroutine文件。

下载后,在命令行下执行:

go tool pprof -http=":8081" goroutine

会自动打开浏览器页面如下图所示。
在这里插入图片描述

在图中可以清晰的看到goroutine的数量以及调用关系。

左侧的菜单栏,可以查看Top、Graph、Flame Graph等。

3.参考

golang 性能剖析pprof

golang程序性能分析


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM