>백엔드 개발 >Golang >golang의 pprof 패키지를 사용하여 프로그램 성능 분석을 수행하는 방법

golang의 pprof 패키지를 사용하여 프로그램 성능 분석을 수행하는 방법

藏色散人
藏色散人앞으로
2020-11-25 15:12:022856검색

다음 튜토리얼 칼럼인 golang에서는 golang의 pprof 패키지를 사용하여 프로그램 성능 분석을 수행하는 방법을 소개합니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제