首頁 >後端開發 >Golang >是否可以在運行時更新 zap 記錄器的日誌等級?

是否可以在運行時更新 zap 記錄器的日誌等級?

王林
王林轉載
2024-02-08 23:20:311129瀏覽

是否可以在运行时更新 zap 记录器的日志级别?

php小編西瓜在運行時更新zap記錄器的日誌等級是一個常見的需求。 zap是一個強大的日誌記錄工具,可以幫助我們擷取和記錄應用程式的運作資訊。通常情況下,我們需要在應用程式啟動時設定zap的日誌級別,但是有時我們希望能夠在運行時動態地更新日誌級別,以便根據實際需要進行調整。在zap中,我們可以透過使用zap的Logger介面提供的方法來實現這個功能。具體來說,我們可以使用`zap.Info()`、`zap.Debug()`、`zap.Warn()`等方法來動態更新日誌等級。這樣,我們就可以根據需要在運行時靈活地調整zap的日誌記錄行為了。

問題內容

我使用 kubebuilder 建立了一個記錄器,它是基於 zap 記錄器:

import (
    "flag"
    "github.com/gin-gonic/gin"
    "net/http"
    "os"
    "go.uber.org/zap/zapcore"
    uzap "go.uber.org/zap"
    // Import all Kubernetes client auth plugins (e.g. Azure, GCP, OIDC, etc.)
    // to ensure that exec-entrypoint and run can make use of them.
    _ "k8s.io/client-go/plugin/pkg/client/auth"

    "k8s.io/apimachinery/pkg/runtime"
    utilruntime "k8s.io/apimachinery/pkg/util/runtime"
    clientgoscheme "k8s.io/client-go/kubernetes/scheme"
    ctrl "sigs.k8s.io/controller-runtime"
    "sigs.k8s.io/controller-runtime/pkg/healthz"
    "sigs.k8s.io/controller-runtime/pkg/log/zap"

)

var (
    scheme   = runtime.NewScheme()
    setupLog = ctrl.Log.WithName("setup")
)

var zapOpts []uzap.Option
    zapOpts = append(zapOpts, uzap.AddCaller())
    zapOpts = append(zapOpts, uzap.AddCallerSkip(1))
    zapOpts = append(zapOpts, uzap.AddStacktrace(uzap.DebugLevel))

    opts := zap.Options{
        Development:     developmentFlag,
        StacktraceLevel: stacktraceLevel,
        Level:           level,
        Encoder:         encoder,
        ZapOpts:  zapOpts,
    }

    opts.BindFlags(flag.CommandLine)
    flag.Parse()

    ctrl.SetLogger(zap.New(zap.UseFlagOptions(&opts)))

現在我想在運行時將日誌等級更改為 zapcore.infolevel 。我沒有找到任何 setloglevel 或類似的 api。

我需要建立新選項然後設定新等級嗎?

我還需要使用 sigs.k8s.io/controller-runtime/pkg/log/zap 庫來設定記錄器。記錄器的介面來自go-logr,它實作了logr.logger介面。如果我嘗試將其更改為 zapcore.newcore ,我將無法再使用 ctrl.setlogger 設定記錄器。

我想保留更新zap.options 的所有選項的選項,並更改日誌級別,並且仍然使用sigs.k8s.io/controller-runtime/pkg/log/zap 中的zap。

是否可以這樣做 sigs.k8s.io/controller-runtime/pkg/log/zapsigs.k8s.io/controller-runtime

解決方法

更好的答案:依照@oliver dain的建議,使用 zap.atomiclevel。有關詳細信息,請參閱他們的回答。

另一個選項是使用自訂 levelenabler 函數建立核心。您可以使用 zap.levelenablerfunc 將閉包轉換為 zapcore.levelenabler

相關文件:

levelenabler 決定在記錄訊息時是否啟用給定的日誌記錄等級。

levelenablerfunc 是使用匿名函數實作 zapcore.levelenabler 的便捷方法。

該函數可能會根據運行時更改的其他變數傳回 truefalse

// will be actually initialized and changed at run time 
    // based on your business logic
    var infoEnabled bool 

    errorUnlessEnabled := zap.LevelEnablerFunc(func(level zapcore.Level) bool {
        // true: log message at this level
        // false: skip message at this level
        return level >= zapcore.ErrorLevel || infoEnabled
    })

    core := zapcore.NewCore(
        zapcore.NewJSONEncoder(zap.NewProductionEncoderConfig()),
        os.Stdout,
        errorUnlessEnabled,
    )
    logger := zap.New(core)

    logger.Info("foo") // not logged
    
    infoEnabled = true

    logger.Info("foo again") // logged

ps:這段程式碼是人為的。您的程式必須在 infoenabled 變數上實現初始化、執行時間值變更以及正確的同步(如果需要)。

您可以在 playground 中執行此範例:https://play.golang.org/p/ ot3nvnp1bwc

以上是是否可以在運行時更新 zap 記錄器的日誌等級?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除