Heim > Backend-Entwicklung > Golang > Wie protokolliere ich Strukturen automatisch über Zerolog?

Wie protokolliere ich Strukturen automatisch über Zerolog?

WBOY
Freigeben: 2024-02-12 22:09:09
nach vorne
1050 Leute haben es durchsucht

如何通过 Zerolog 自动记录结构?

php-Editor Xigua zeigt Ihnen, wie Sie die Struktur automatisch über Zerolog aufzeichnen. Zerolog ist eine leistungsstarke Protokollierungsbibliothek, die uns hilft, strukturierte Protokolle in Anwendungen automatisch aufzuzeichnen. Durch die Verwendung von Zerolog können wir Informationen problemlos auf verschiedenen Ausgabequellen wie Konsole, Datei oder Remote-Server protokollieren. Gleichzeitig bietet Zerolog auch umfangreiche Protokollierungsebenen sowie Funktionen zum Hinzufügen von Feldern und Formatierungen, sodass wir Protokollinformationen flexibler steuern und verwalten können. Als Nächstes erfahren Sie, wie Sie mit Zerolog automatisch strukturierte Protokolle aufzeichnen!

Frageninhalt

Ich verwende zerolog, um mich bei der Go-App anzumelden. Ich möchte eine Karte (json) protokollieren und habe einen Weg gefunden:

log.info().
    str("foo", "bar").
    dict("dict", zerolog.dict().
        str("bar", "baz").
        int("n", 1),
    ).msg("hello world")

// output: {"level":"info","time":1494567715,"foo":"bar","dict":{"bar":"baz","n":1},"message":"hello world"}
Nach dem Login kopieren

Im obigen Beispiel benötige ich die Methode in zerolog.dict() 方法中指定每个 key-value 对。我想知道是否有自动记录 struct .

Zum Beispiel habe ich eine Struktur wie diese:

type message struct {
    aws_region     string `json:"region"`
    log_level      string `json:"level"`
    stage          string `json:"stage"`
    request_id     string `json:"requestid"`
}
Nach dem Login kopieren

Ich suche nach einer Möglichkeit, eine message-Instanz an

zu übergeben
msg := Message{ ... }
zerolog.Dict("message", msg)
Nach dem Login kopieren

Workaround

Sie können die Interface-Methode verwenden, um dies zu erreichen.

Beispiel

Aber bitte beachten Sie, dass Interface Reflektion für die Serialisierung verwendet, sodass kurzer Code auf Kosten der Leistung geht

Das obige ist der detaillierte Inhalt vonWie protokolliere ich Strukturen automatisch über Zerolog?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage