go에는 코드 성능 모니터링을 위한 pprof 패키지가 있습니다.
#🎜🎜 #net. /http/pprofruntime/pprof사실 net/http/pprof는 런타임/pprof 패키지를 사용하여 이를 캡슐화하고 http 포트에 노출합니다. pprof packageweb server
go 프로그램이 http 패키지로 시작되는 웹 서버인 경우, 웹 서버의 상태를 확인하고 싶습니다. 이때 net/http/pprof를 선택하시면 됩니다. package_"net/http/pprof"를 가져오기만 하면 됩니다. 그런 다음 브라우저에서 http://localhost:port/debug/pprof/를 사용하여 CPU 사용량, 메모리 사용량을 포함한 현재 웹 서비스의 상태를 직접 확인할 수 있습니다. 구체적인 사용법에 대해서는 godoc의 지침을 읽어보세요.서비스 프로세스
go 프로그램이 웹 서버가 아닌 서비스 프로세스인 경우 net/을 사용하도록 선택할 수도 있습니다. http /pprof 패키지, net/http/pprof 패키지도 도입한 다음 다른 고루틴을 열어 포트 모니터링을 활성화합니다. 예:go func() { log.Println(http.ListenAndServe("localhost:6060", nil)) }()
application
go 프로그램이 파보나치 계산과 같은 단순한 애플리케이션인 경우 순서대로, net/http/pprof 패키지를 사용할 수 없으며, Runtime/pprof를 사용해야 합니다. 구체적인 방법은 pprof.StartCPUProfile 및 pprof.StopCPUProfile을 사용하는 것입니다. 예를 들어 다음 예는 다음과 같습니다.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() } …프로그램을 실행할 때 fabonacci --cpuprofile=fabonacci.prof이런 방식으로 --cpuprofile 매개변수를 추가합니다. 프로그램 실행 시 CPU 정보는 XXX.prof에 기록됩니다. 다음 단계는 이 교수 정보를 활용하여 성능 분석 그래프를 만드는 것입니다(graphviz 설치 필요). go tool pprof(application)(application prof 파일) 사용 pprof 입력, web 명령어를 사용하여 /tmp 아래에 svg 파일 생성, svg 파일에서 볼 수 있습니다. 브라우저. 예를 들어, 프로그램이 매우 간단한 경우(예: println 문이 하나만 있는 경우) pprof.StartCPUProfile을 사용하여 아무 것도 인쇄할 수 없습니다.
Example
go-tour를 예로 들어보겠습니다. 이것은 웹 프로그램에
#을 추가한 것입니다. . 🎜🎜#_ "net/http/pprof"프로프 정보를 브라우저에서 직접 볼 수 있습니다
#🎜🎜 #CPU 상태 분석 그래프 생성
이제 CPU 상태 분석 그래프를 생성하고 go 도구 pprof를 호출하겠습니다. http://localhost:3999/debug/pprof/profile# 🎜 🎜#에서는 프로필 수집 시간이 30초로 입력됩니다. 이 기간 동안 Go-Tour 브라우저에서 페이지를 새로 고치고 CPU 사용량을 최대화하여 데이터를 생성해 보세요.
(pprof) top10 Total: 3 samples 1 33.3% 33.3% 1 33.3% MHeap_AllocLocked 1 33.3% 66.7% 1 33.3% os/exec.(*Cmd).closeDescriptors 1 33.3% 100.0% 1 33.3% runtime.sigprocmask 0 0.0% 100.0% 1 33.3% MCentral_Grow 0 0.0% 100.0% 2 66.7% main.Compile 0 0.0% 100.0% 2 66.7% main.compile 0 0.0% 100.0% 2 66.7% main.run 0 0.0% 100.0% 1 33.3% makeslice1 0 0.0% 100.0% 2 66.7% net/http.(*ServeMux).ServeHTTP 0 0.0% 100.0% 2 66.7% net/http.(*conn).serve(pprof)web
더 많은 바둑 지식을 알고 싶다면
go 언어 튜토리얼을 주목하세요. #🎜🎜 #컬럼.위 내용은 Go에서 pprof를 사용하는 방법을 완전히 익히세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!