Maison  >  Article  >  développement back-end  >  Comment obtenir une journalisation de type MDC dans GoLang ?

Comment obtenir une journalisation de type MDC dans GoLang ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-27 22:42:02979parcourir

How to Achieve MDC-Like Logging in GoLang?

Réalisation de la journalisation MDC dans GoLang

La journalisation avec un contexte de diagnostic mappé (MDC) en Java permet de suivre les requêtes simultanées en ajoutant des UUID aux journaux du serveur . Dans Go, le stockage local des threads, sur lequel MDC s'appuie en Java, n'est pas disponible.

Solution de GoLang : contexte de thread

Pour activer la journalisation de type MDC dans Go, il est nécessaire d'enfiler un contexte dans toute la pile d'application. Cette approche a gagné en popularité parmi les bibliothèques Go.

Une implémentation courante consiste à utiliser un package middleware pour ajouter un ID de requête au contexte d'une requête Web. Cela vous permet de récupérer l'ID à l'aide de ctx.Value("requestId") et de l'utiliser pour la journalisation.

Par exemple, vous pouvez créer une fonction de journalisation personnalisée :

<code class="go">func logStuff(ctx context.Context, msg string) {
    log.Println(ctx.Value("requestId"), msg) // Call the standard library logger
}</code>

Cette approche offre de la flexibilité et vous permet de gérer les ID de demande si nécessaire. Bien qu'il ne s'agisse pas d'un équivalent direct du MDC de Java, il fournit une solution viable pour tracer les requêtes simultanées dans Go.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn