ホームページ > バックエンド開発 > Golang > GoLang で MDC のようなログを実現するにはどうすればよいですか?

GoLang で MDC のようなログを実現するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-27 22:42:02
オリジナル
1164 人が閲覧しました

How to Achieve MDC-Like Logging in GoLang?

GoLang での MDC ログ記録の実現

Java のマップされた診断コンテキスト (MDC) を使用したログ記録では、サーバー ログに UUID を追加することで同時リクエストをトレースできます。 。 Go では、Java で MDC が依存するスレッド ローカル ストレージが利用できません。

GoLang の解決策: スレッド コンテキスト

Go で MDC のようなロギングを有効にするには、次のようにします。アプリケーション スタック全体でコンテキストをスレッド化するために必要です。このアプローチは Go ライブラリの間で人気を集めています。

一般的な実装には、ミドルウェア パッケージを使用して Web リクエストのコンテキストにリクエスト ID を追加することが含まれます。これにより、ctx.Value("requestId") を使用して ID を取得し、それをログ記録に使用できるようになります。

たとえば、カスタム ロガー関数を作成できます。

<code class="go">func logStuff(ctx context.Context, msg string) {
    log.Println(ctx.Value("requestId"), msg) // Call the standard library logger
}</code>
ログイン後にコピー

このアプローチ柔軟性があり、必要に応じてリクエスト ID を処理できます。これは Java の MDC と直接同等ではありませんが、Go での同時リクエストをトレースするための実行可能なソリューションを提供します。

以上がGoLang で MDC のようなログを実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート