ホームページ バックエンド開発 Golang Go での pprof の使い方を完全にマスターする

Go での pprof の使い方を完全にマスターする

Nov 25, 2019 pm 01:41 PM
go pprof

Go での pprof の使い方を完全にマスターする

go には、コード パフォーマンス モニタリング用の pprof パッケージがあります。パッケージは

net/http/pprof

# の 2 か所にあります。 ##runtime/pprof

実際には、net/http/pprof は runtime/pprof パッケージを使用してカプセル化し、http ポートで公開します

pprof パッケージ

Web サーバー

Go プログラムが http パッケージで起動された Web サーバーの場合は、Web サーバーのステータスを確認する必要があります。この時点では、net/http/pprof を選択できます。 package_「net/http/pprof」をインポートするだけです。

その後、ブラウザで http://localhost:port/debug/pprof/ を使用すると、CPU 使用率やメモリ使用率など、現在の Web サービスのステータスを直接確認できます。具体的な使用方法については、godoc の説明書をご覧ください。

サービス プロセス

Go プログラムが Web サーバーではなくサービス プロセスである場合は、net/http/pprof パッケージの使用を選択することもできます。これも導入されています。 net/http/pprof をパッケージ化し、別の goroutine を開いてポート監視を有効にします。

例:

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 がインストールされている必要があります)。

Use go tool pprof (application) (application prof file)

pprof と入力し、Web コマンドを使用して /tmp の下に svg ファイルを生成します。svg ファイルは参照できます。デバイスの下で表示されます。 。

Go での pprof の使い方を完全にマスターする

#プログラムが非常に単純である場合、たとえば println ステートメントが 1 つしかない場合、pprof.StartCPUProfile を使用して何も出力することはできません。

Go-tour を例に挙げます。これは Web プログラムです。

__ "net/http /pprof" を追加しました。

ブラウザでプロファイル情報を直接表示できます

Go での 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 での pprof の使い方を完全にマスターする

Go 言語の知識について詳しくは、

go 言語チュートリアル 列に注目してください。

以上がGo での pprof の使い方を完全にマスターするの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Go WebSocket メッセージを送信するにはどうすればよいですか? Go WebSocket メッセージを送信するにはどうすればよいですか? Jun 03, 2024 pm 04:53 PM

Go では、gorilla/websocket パッケージを使用して WebSocket メッセージを送信できます。具体的な手順: WebSocket 接続を確立します。テキスト メッセージを送信します。 WriteMessage(websocket.TextMessage,[]byte("message")) を呼び出します。バイナリ メッセージを送信します。WriteMessage(websocket.BinaryMessage,[]byte{1,2,3}) を呼び出します。

Golang 関数のライフサイクルと変数スコープの深い理解 Golang 関数のライフサイクルと変数スコープの深い理解 Apr 19, 2024 am 11:42 AM

Go では、関数のライフ サイクルには定義、ロード、リンク、初期化、呼び出し、戻り値が含まれます。変数のスコープは関数レベルとブロック レベルに分割されますが、ブロック内の変数はブロック内でのみ表示されます。 。

Go で正規表現を使用してタイムスタンプを照合するにはどうすればよいですか? Go で正規表現を使用してタイムスタンプを照合するにはどうすればよいですか? Jun 02, 2024 am 09:00 AM

Go では、正規表現を使用してタイムスタンプを照合できます。ISO8601 タイムスタンプの照合に使用されるような正規表現文字列をコンパイルします。 ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ 。 regexp.MatchString 関数を使用して、文字列が正規表現と一致するかどうかを確認します。

GolangとGo言語の違い GolangとGo言語の違い May 31, 2024 pm 08:10 PM

Go と Go 言語は、異なる特性を持つ別個の存在です。 Go (Golang とも呼ばれます) は、同時実行性、高速なコンパイル速度、メモリ管理、およびクロスプラットフォームの利点で知られています。 Go 言語の欠点としては、他の言語に比べてエコシステムが充実していないこと、構文が厳格であること、動的型付けが欠如していることが挙げられます。

Golang の技術的なパフォーマンスの最適化でメモリ リークを回避するにはどうすればよいですか? Golang の技術的なパフォーマンスの最適化でメモリ リークを回避するにはどうすればよいですか? Jun 04, 2024 pm 12:27 PM

メモリ リークは、ファイル、ネットワーク接続、データベース接続などの使用されなくなったリソースを閉じることによって、Go プログラムのメモリを継続的に増加させる可能性があります。弱参照を使用してメモリ リークを防ぎ、強参照されなくなったオブジェクトをガベージ コレクションの対象にします。 go coroutine を使用すると、メモリ リークを避けるために、終了時にコルーチンのスタック メモリが自動的に解放されます。

IDE で Golang 関数のドキュメントを表示するにはどうすればよいですか? IDE で Golang 関数のドキュメントを表示するにはどうすればよいですか? Apr 18, 2024 pm 03:06 PM

IDE を使用して Go 関数のドキュメントを表示する: 関数名の上にカーソルを置きます。ホットキーを押します (GoLand: Ctrl+Q; VSCode: GoExtensionPack をインストールした後、F1 キーを押して「Go:ShowDocumentation」を選択します)。

Go 同時関数の単体テストのガイド Go 同時関数の単体テストのガイド May 03, 2024 am 10:54 AM

並行関数の単体テストは、同時環境での正しい動作を確認するのに役立つため、非常に重要です。同時実行機能をテストするときは、相互排他、同期、分離などの基本原則を考慮する必要があります。並行機能は、シミュレーション、競合状態のテスト、および結果の検証によって単体テストできます。

Golang関数がマップパラメータを受け取る際の注意点 Golang関数がマップパラメータを受け取る際の注意点 Jun 04, 2024 am 10:31 AM

Go の関数にマップを渡すと、デフォルトでコピーが作成され、コピーへの変更は元のマップには影響しません。元のマップを変更する必要がある場合は、ポインタを介してそれを渡すことができます。空のマップは技術的には nil ポインターであり、空ではないマップを期待する関数に空のマップを渡すとエラーが発生するため、空のマップは慎重に扱う必要があります。

See all articles