ホームページ > バックエンド開発 > Golang > スレッドローカルストレージを使用せずにGolangでMDCのようなログインを実現するにはどうすればよいですか?

スレッドローカルストレージを使用せずにGolangでMDCのようなログインを実現するにはどうすればよいですか?

Susan Sarandon
リリース: 2024-10-27 22:55:01
オリジナル
778 人が閲覧しました

 How to Achieve MDC-like Logging in Golang Without Thread Local Storage?

スレッドレス ロギングを制御する: Golang で MDC を実現する

Java の MDC (Mapped Diagnostic Context) に似たロギング メカニズムを Golang で実現するのは簡単ではありません。 Go にはスレッド ローカル ストレージがないことが大きな障害となります。

この制限を回避するには、リクエスト スタックを通じてコン​​テキストを渡すことをお勧めします。これは、Golang ライブラリでますます一般的になってきています。

一般的な実装には、ミドルウェアを使用して一意のリクエスト ID をコンテキストに追加することが含まれます。次に例を示します。

req = req.WithContext(context.WithValue(req.Context(), "requestId", ID))
ログイン後にコピー

このリクエスト ID は、ctx.Value("requestId") にアクセスすることで取得し、コード全体で利用できます。

ロギング プロセスをカスタマイズするには、専用のロガー関数を作成できます。

func logStuff(ctx context.Context, msg string) {
    log.Println(ctx.Value("requestId"), msg) // log using the stdlib logger
}
ログイン後にコピー

さまざまなメソッドを統合することで、Golang 開発者は Java の MDC と同様の機能を提供するロギング メカニズムを実装でき、カスタマイズされたログを通じて同時リクエストを効率的にトレースできます。

以上がスレッドローカルストレージを使用せずにGolangでMDCのようなログインを実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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