Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk log ralat menggunakan 'log/slog'

Bagaimana untuk log ralat menggunakan 'log/slog'

PHPz
PHPzke hadapan
2024-02-06 11:24:03649semak imbas

Bagaimana untuk log ralat menggunakan log/slog

Kandungan soalan

Dokumentasi rasmi menunjukkan cara menggunakan pakej pengelogan berstruktur baharu, tetapi nampaknya mengabaikan cara mengelog ralat.

https://pkg.go.dev/log/slog

package main

import (
    "fmt"
    "log/slog"
    "os"
)

func demoFunction() error {
    return fmt.Errorf("oh no: %v", 123)
}

func main() {
    logger := slog.New(slog.NewJSONHandler(os.Stdout, nil))
    slog.SetDefault(logger)

    slog.Info("info demo", "count", 3)
    slog.Warn("warn demo", slog.String("somekey", "somevalue"))
    slog.Error("error demo", slog.Int("someintkey", 123))
    err := demoFunction()
    if err != nil {
        // Here I'm logging the error as a string, but I presume there is a better way
        // possibly that will log stack trace info as well.
        slog.Error("the demo function got an error.", slog.String("error", err.Error()))
    }
}

Jawapan betul


Seseorang membuat cadangan dan menutupnya. Saya fikir ia akhirnya menjadi gula sintaksis yang tidak perlu.

Nampaknya seseorang telah memutuskan untuk membungkus slog.Sebarang panggilan

func ErrAttr(err error) slog.Attr {
    return slog.Any("error", err)
}

Atas ialah kandungan terperinci Bagaimana untuk log ralat menggunakan 'log/slog'. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam