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

Linda Hamilton
Lepaskan: 2024-11-28 02:11:11
asal
577 orang telah melayarinya

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
}
Salin selepas log masuk

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),
}
Salin selepas log masuk

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
}
Salin selepas log masuk

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

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

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan