다음 튜토리얼 칼럼인 golang에서는 golang의 pprof 패키지를 사용하여 프로그램 성능 분석을 수행하는 방법을 소개합니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!
golang은 golang 프로그램 스택, CPU 시간 소모 및 기타 성능 정보를 모니터링할 수 있는 pprof 패키지를 제공합니다. 이 pprof 패키지의 사용법에 대해 이야기해 보겠습니다.
1. 먼저 소개입니다.
“net/http/pprof” "runtime/prof"
그 중 "net/http/pprof"는 "runtime/pprof"와 함께 패키징되어 있으며, 그 다음에는 http 포트가 노출되어 있습니다. 브라우저를 사용하여 프로그램의 성능 분석을 볼 수 있습니다. "runtime/pprof"는 *.pprof 파일을 생성한 다음 이 파일을 기반으로 성능 분석을 수행할 수 있습니다.
2. 그런 다음 코드에서 pprof를 사용합니다. 실제 응용 프로그램에는 세 가지 상황이 있습니다.
1)
프로그램 자체가 웹 서버의 경우
import( _"net/http/pprof" )
코드를 통해 pprof를 도입하고 브라우저에서 http://localhost:port/debug/pprof/를 방문하면 CPU 사용량을 포함한 현재 웹 서비스 상태를 확인할 수 있습니다. 및 메모리 사용량 등
2)
go 프로그램이 웹 서버가 아니라 서비스 프로세스인 경우 포트 수신 대기를 활성화하려면 고루틴을 열어야 합니다.
예:
go func() { log.Println(http.ListenAndServe("localhost:6060", nil)) }()
마찬가지로 http://localhost:6060/debug/pprof를 방문하여 프로그램 실행 정보를 확인하세요.
3) 프로그램이 단순한 애플리케이션인 경우 "runtime/ppprof" 패키지를 사용해야 합니다.
공식 웹사이트에서 제공하는 코드는 다음과 같습니다:
var cpuprofile = flag.String("cpuprofile", "", "write cpu profile to file") func main() { flag.Parse() if *cpuprofile != "" { f, err := os.Create(*cpuprofile) if err != nil { log.Fatal(err) } pprof.StartCPUProfile(f) defer pprof.StopCPUProfile() }
그리고 이 프로그램을 실행할 때 --cpuprofile=*.prof 매개변수를 추가하여 해당 디렉터리에 .pprof 파일을 생성하고, 프로그램은 실행 정보는 모두 이 파일에 있습니다. 그런 다음 해당 디렉터리를 입력하고 go tool pprof 명령을 실행합니다. 방금 생성한 pprof 파일 이름을 추가하여 pprof를 입력합니다. 해당 svg 파일을 생성합니다.
두 번째 방법:
"net/http/pprof" 패키지를 사용할 때 go tool pprof 명령을 사용하여 프로그램의 실행 상태를 볼 수도 있습니다. 예를 들어, 간단한 go 서버 프로그램을 시작하고 포트 8080을 수신하는 경우 다음 명령을 사용하여 pprof 명령줄을 입력할 수 있습니다.
스택 정보를 보려면 이 명령을 사용하세요.
go tool pprof http://localhost:6060/debug/pprof/heap 利用这个命令可以查看程序CPU使用情况信息: go tool pprof http://localhost:6060/debug/pprof/profile 使用这个命令可以查看block信息: go tool pprof http://localhost:6060/debug/pprof/block 进入pprof命令行,输入help,查看命令帮助, topN命令可以查看占用前N 的线程或者函数,用svg可以生成svg图。 pprof简单使用就是这样了,掌握了使用方法,在实践中加以利用才是我们的目的,希望我写的这些可以对你有所帮助。
ps; 실제로 사용하지는 않습니다. golang으로 대규모 프로그램을 작성했지만 이 패키지를 실제로 사용한 적은 없습니다. 단지 몇 가지 기사를 읽고 공식 웹 사이트에 몇 가지 정보를 요약한 것뿐입니다. 수정은 불가피합니다. 환영! 감사합니다
위 내용은 golang의 pprof 패키지를 사용하여 프로그램 성능 분석을 수행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!