


Comment puis-je personnaliser la journalisation des erreurs dans le package net/http de Go ?
Nov 28, 2024 am 10:48 AMConsignation des erreurs au format personnalisé avec net/http
Dans net/http, les erreurs peuvent être enregistrées à l'aide du Server.ErrorLog champ. Pour enregistrer les erreurs dans un format personnalisé, vous pouvez remplacer l'enregistreur par défaut par votre propre implémentation.
Implémentation de journalisation personnalisée
Pour créer un enregistreur personnalisé, définissez un type qui implémente l'interface io.Writer, comme le montre l'exemple suivant :
type CustomLogger struct { writer io.Writer } func (l *CustomLogger) Write(p []byte) (n int, err error) { // Implement custom logging logic here }
Utilisation de Custom Logger dans net/http
Une fois que vous avez votre enregistreur personnalisé, vous pouvez le définir comme ErrorLog pour le http.Server :
server := &http.Server{ Addr: ":8080", Handler: myHandler, ErrorLog: &CustomLogger{writer: os.Stderr}, }
Utilisation de Zap Logger pour net/ http Error Logging
Pour que les erreurs soient écrites dans le même format que Zap, vous devez implémenter un serverJsonWriter tapez qui transmet le message d’erreur à l’enregistreur Zap. Voici comment :
type serverJsonWriter struct { fw *fwdToZapWriter } func (w serverJsonWriter) Write(p []byte) (n int, err error) { w.fw.logger.Errorw(string(p)) return len(p), nil }
Où se trouve fwdToZapWriter :
type fwdToZapWriter struct { logger *zap.SugaredLogger } func (fw *fwdToZapWriter) Write(p []byte) (n int, err error) { fw.logger.Errorw(string(p)) return len(p), nil }
Vous pouvez ensuite utiliser le type serverJsonWriter dans votre serveur :
server := &http.Server{ Addr: ":8080", Handler: myHandler, ErrorLog: log.New(&serverJsonWriter{fw: &fwdToZapWriter{logger: myZapLogger}}, "", 0), }
En mettant en œuvre ces étapes, vous pouvez enregistrer les erreurs net/http dans votre propre format personnalisé à l'aide de votre enregistreur Zap.
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?

Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?

Comment écrire des objets et des talons simulés pour les tests en Go?

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?

Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?

Comment écrire des fichiers dans GO Language de manière pratique?

Comment puis-je utiliser des liners et des outils d'analyse statique pour améliorer la qualité et la maintenabilité de mon code GO?
