>  기사  >  백엔드 개발  >  Go에서 pprof를 사용하는 방법을 완전히 익히세요.

Go에서 pprof를 사용하는 방법을 완전히 익히세요.

尚
앞으로
2019-11-25 13:41:214266검색

Go에서 pprof를 사용하는 방법을 완전히 익히세요.

go에는 코드 성능 모니터링을 위한 pprof 패키지가 있습니다.

#🎜🎜 #net. /http/pprof

runtime/pprof

사실 net/http/pprof는 런타임/pprof 패키지를 사용하여 이를 캡슐화하고 http 포트에 노출합니다.

pprof package

web 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에서 pprof를 사용하는 방법을 완전히 익히세요.

go-tour를 예로 들어보겠습니다. 이것은 웹 프로그램에

#을 추가한 것입니다. . 🎜🎜#_ "net/http/pprof"

프로프 정보를 브라우저에서 직접 볼 수 있습니다

#🎜🎜 #

CPU 상태 분석 그래프 생성

이제 CPU 상태 분석 그래프를 생성하고 go 도구 pprof를 호출하겠습니다. http://localhost:3999/debug/pprof/profile# 🎜 🎜#

에서는 프로필 수집 시간이 30초로 입력됩니다. 이 기간 동안 Go-Tour 브라우저에서 페이지를 새로 고치고 CPU 사용량을 최대화하여 데이터를 생성해 보세요. Go에서 pprof를 사용하는 방법을 완전히 익히세요.

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

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