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!