Maison > développement back-end > Golang > Comment puis-je personnaliser la journalisation des erreurs dans le package net/http de Go ?

Comment puis-je personnaliser la journalisation des erreurs dans le package net/http de Go ?

Susan Sarandon
Libérer: 2024-11-28 10:48:12
original
681 Les gens l'ont consulté

How Can I Customize Error Logging in Go's net/http Package?

Consignation 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
}
Copier après la connexion

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},
}
Copier après la connexion

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
}
Copier après la connexion

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
}
Copier après la connexion

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),
}
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal