Rumah > pembangunan bahagian belakang > Golang > Zap logger menambah UUID pada semua log dalam golang

Zap logger menambah UUID pada semua log dalam golang

PHPz
Lepaskan: 2024-02-14 19:24:09
ke hadapan
1235 orang telah melayarinya

Zap logger 将 UUID 添加到 golang 中的所有日志中

PHP Editor Xigua Pengenalan: Dalam golang, pembalakan merupakan bahagian penting dalam proses pembangunan. Zap logger ialah perpustakaan pembalakan yang sangat popular yang menyediakan fungsi yang kaya dan prestasi tinggi. Baru-baru ini, ciri baharu telah ditambahkan pada Zap logger, iaitu menambah UUID pada semua log. Tujuan fungsi ini adalah untuk menjejaki log dengan lebih baik dan memudahkan pembangun mengesan masalah dalam sistem teragih. Dengan ciri baharu ini, pembangun boleh mengesan masalah dengan lebih tepat dan meningkatkan kecekapan penyahpepijatan. Ini adalah ciri yang sangat praktikal untuk jurutera yang membangunkan menggunakan golang.

Kandungan soalan

Saya menggunakan kaedah ini dalam lambda:

import (
    "os"

    "go.uber.org/zap"
    "go.uber.org/zap/zapcore"
)

func initlogger() *zap.logger {
    config := zap.newproductionencoderconfig()
    config.encodetime = zapcore.rfc3339timeencoder
    consoleencoder := zapcore.newjsonencoder(config)
    core := zapcore.newtee(zapcore.newcore(consoleencoder, zapcore.addsync(os.stdout), zapcore.infolevel))
    return zap.new(core).with()
}
Salin selepas log masuk

Dalam pengendali lambda saya, saya ada:

var (
    log *zap.Logger
)

func init() {
    log = u.InitLogger()
}

func handler(r events.APIGatewayProxyRequest) (*events.APIGatewayProxyResponse, error) {

    out, err := exec.Command("uuidgen").Output()
    uuid := strings.ReplaceAll(string(out), "\n", "")
    if err != nil {
        log.Error(err.Error())
    }

    log.Info("PRINT_1", zap.Any("uuid", uuid), zap.Any("Request", r.Body))
}
Salin selepas log masuk

Saya ada soalan, adakah mungkin untuk menambah uuid pada semua log tanpa menambahnya satu demi satu? Kerana dalam setiap log di mana saya perlu mencetak sesuatu, saya perlu menambah zap.any("uuid", uuid)

Masalahnya ialah saya perlu menghantar uuid sebagai parameter kepada semua kaedah untuk mencetaknya dalam mesej log atau ralat.

Penyelesaian

Anda perlu menyusun semula kod anda sedikit kerana anda hanya mencipta uuid dalam pengendali yang bermaksud ia adalah permintaan khusus manakala pembalak adalah global...

Maksud untuk pustaka ini, bagaimanapun, ialah anda perlu mencipta sublogger (sebenarnya, anda sudah melakukan ini: anda hanya melepasi medan di sana). Sebarang log seterusnya yang ditulis kepada sublogger akan mengandungi medan ini.

Contohnya:

func main() {
    logger := initlogger(zap.string("foo", "bar"))
    logger.info("first message with our `foo` key")
    logger.info("second message with our `foo` key")
}

func initlogger(fields ...zap.field) *zap.logger {
    config := zap.newproductionencoderconfig()
    config.encodetime = zapcore.rfc3339timeencoder
    consoleencoder := zapcore.newjsonencoder(config)
    core := zapcore.newtee(zapcore.newcore(consoleencoder, zapcore.addsync(os.stdout), zapcore.infolevel))
    return zap.new(core).with(fields...)
}
Salin selepas log masuk

Keluaran:

{"level":"info","ts":"2022-11-24T18:30:45+01:00","msg":"First message with our `foo` key","foo":"bar"}
{"level":"info","ts":"2022-11-24T18:30:45+01:00","msg":"Second message with our `foo` key","foo":"bar"}
Salin selepas log masuk

Atas ialah kandungan terperinci Zap logger menambah UUID pada semua log dalam golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:stackoverflow.com
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan