我創建了一個記錄器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.
可以用sigs.k8s.io/controller-runtime/pkg/log/zap
and做到
sigs.k8s.io/controller-runtime嗎?
uj5u.com熱心網友回復:
您無法在運行時更改現有記錄器的日志級別。
您可以做的是創建具有自定義LevelEnabler功能的核心。您可以使用zap.LevelEnablerFunc將閉包轉換為zapcore.LevelEnabler.
相關檔案:
LevelEnabler 決定在記錄訊息時是否啟用給定的日志記錄級別。
LevelEnablerFunc 是一種使用匿名函式實作 zapcore.LevelEnabler 的便捷方法。
然后,該函式可能會回傳true或false基于其他一些在運行時發生變化的變數:
// 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
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/339727.html
下一篇:除錯單個測驗時如何提供測驗標志?
