phpエディタStrawberryでは、Go lang slogのログレベルを実行時に変更する方法を紹介します。 Go lang slog は一般的に使用されるログ ライブラリですが、開発中にアプリケーションを再起動せずにログのレベルを変更する必要がある場合があります。この記事では、さまざまなニーズに合わせて実行時にログ レベルを簡単に変更できる、シンプルで効果的な方法を紹介します。初心者でも経験豊富な開発者でも、このヒントはプロジェクトに役立ちます。
Go slog ロギング パッケージ ("log/slog"
) を使用して、実行時にロガーのログ レベルを変更する方法を探しています。
出来ますか? 何時間も遊んでみましたが、これを行う方法が見つかりません。
以下は、Peter の回答に基づいて作成したコードです。
HTTP 呼び出しを行う
http://localhost:8080/changeLogLevel?logger=TCP&level=ERROR
。
以下のコードは期待どおりに機能します。
リーリー ###出力###package main import ( "log" "log/slog" "net/http" "os" "strings" "time" ) func main() { // Create a LevelVar variable and initialize it to DEBUG. // Create the template logger with info tcpLvl := new(slog.LevelVar) tcpLvl.Set(slog.LevelDebug) dbLvl := new(slog.LevelVar) dbLvl.Set(slog.LevelDebug) mqLvl := new(slog.LevelVar) mqLvl.Set(slog.LevelDebug) tcpLogger := slog.New(slog.NewTextHandler(os.Stderr, &slog.HandlerOptions{ Level: tcpLvl, })) mqLogger := slog.New(slog.NewTextHandler(os.Stderr, &slog.HandlerOptions{ Level: mqLvl, })) // Create the MQLogger. dbLogger := slog.New(slog.NewTextHandler(os.Stderr, &slog.HandlerOptions{ Level: dbLvl, })) // Create a goroutine that prints debug messages to the 3 loggers. go func() { levels := map[string]slog.Level{ "DEBUG": slog.LevelDebug, "WARN": slog.LevelWarn, "INFO": slog.LevelInfo, "ERROR": slog.LevelError, } for { for levelStr, numericLevel := range levels { log.Printf("Is: %s enabled for tcpLogger? %v \n", levelStr, tcpLogger.Enabled(nil, numericLevel)) } dbLogger.Debug("This is a debug message from the DBLogger.") tcpLogger.Debug("This is a debug message from the TCPLogger.") mqLogger.Debug("This is a debug message from the MQLogger.") log.Println("----------------------------------------------------") time.Sleep(10 * time.Second) } }() // Create an HTTP server. http.HandleFunc("/changeLogLevel", func(w http.ResponseWriter, r *http.Request) { // Get the logger name from the request. log.Println("----- Got HTTP call -------") loggerName := r.URL.Query().Get("logger") // Get the new log level from the request. newLogLevelStr := r.URL.Query().Get("level") var level slog.Level log.Printf("Incoming log level is %v\n", newLogLevelStr) switch strings.ToUpper(newLogLevelStr) { case "DEBUG": level = slog.LevelDebug case "WARNING": level = slog.LevelWarn case "ERROR": level = slog.LevelError case "INFO": level = slog.LevelInfo default: { w.WriteHeader(http.StatusBadRequest) w.Write([]byte("Invalid level name")) return } } log.Printf("Incoming logger name is %v\n", loggerName) switch strings.ToUpper(loggerName) { case "DB": dbLvl.Set(level) case "TCP": log.Printf("Going to set the TCP logger level to %v\n", level) tcpLvl.Set(level) case "MQ": mqLvl.Set(level) default: w.WriteHeader(http.StatusBadRequest) w.Write([]byte("Invalid logger name")) return } w.WriteHeader(http.StatusOK) }) // Start the HTTP server. http.ListenAndServe(":8080", nil) }
したがって、ロガーを作成するときに LevelVar を設定するだけです:
リーリー独自のハンドラーを実装している場合、Enabled メソッドによってログ レベルが決定され、LevelVar を簡単に使用することもできます。 リーリー
以上が実行時に Go lang slog のログ レベルを変更するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。