Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah Saya Boleh Menyesuaikan Pengelogan dalam Pakej net/http Go?

Bagaimanakah Saya Boleh Menyesuaikan Pengelogan dalam Pakej net/http Go?

Linda Hamilton
Linda Hamiltonasal
2024-11-28 02:11:11653semak imbas

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

Sesuaikan Log masuk net/http dengan Penulis Tersuai

Untuk log ralat daripada net/http dalam format tersuai, manfaatkan http.Server.ErrorLog medan, yang menerima pelaksanaan log.Logger antara muka.

Melaksanakan Logger Tersuai

Untuk melaksanakan logger anda sendiri, tentukan jenis yang memenuhi antara muka io.Writer dan laksanakan kaedah Tulis untuk memajukan mesej kepada anda format log yang dikehendaki. Contohnya:

type AppLogger struct {
    log *zap.SugaredLogger
}

func (l *AppLogger) Write(p []byte) (n int, err error) {
    l.log.Errorw(string(p))
    return len(p), nil
}

Integrasi dengan net/http

Untuk menggunakan logger tersuai anda dengan net/http, tetapkan contoh jenis AppLogger anda kepada medan ErrorLog daripada http.Server anda:

server := &http.Server{
    Addr:     addr,
    Handler:  handler,
    ErrorLog: logger.New(&AppLogger{logger}, "", 0),
}

Menggunakan Zap Logger

Untuk menyepadukan Zap logger anda dengan net/http, anda boleh mencipta penulis tersuai yang memajukan mesej ralat ke Zap logger anda:

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
}

Kemudian, tetapkan contoh fwdToZapWriter anda ke medan ErrorLog anda http.Server:

server := &http.Server{
    Addr:     addr,
    Handler:  handler,
    ErrorLog: logger.New(&fwdToZapWriter{logger}, "", 0),
}

Dengan melaksanakan langkah-langkah ini, anda akan mengelog ralat daripada net/http dalam format tersuai yang disediakan oleh AppLogger atau Zap logger anda.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyesuaikan Pengelogan dalam Pakej net/http Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn