pkg/rules/logrus/setup.go (46 lines of code) (raw):

// Copyright (c) 2024 Alibaba Group Holding Ltd. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package logrus import ( _ "unsafe" "github.com/alibaba/opentelemetry-go-auto-instrumentation/pkg/api" "github.com/sirupsen/logrus" "go.opentelemetry.io/otel/sdk/trace" "os" ) type logrusInnerEnabler struct { enabled bool } func (l logrusInnerEnabler) Enable() bool { return l.enabled } var logrusEnabler = logrusInnerEnabler{os.Getenv("OTEL_INSTRUMENTATION_LOGRUS_ENABLED") != "false"} //go:linkname logNewOnEnter github.com/sirupsen/logrus.logNewOnEnter func logNewOnEnter(call api.CallContext, log *logrus.Logger, formatter logrus.Formatter) { if !logrusEnabler.Enable() { return } call.SetData(log) } //go:linkname logNewOnExit github.com/sirupsen/logrus.logNewOnExit func logNewOnExit(call api.CallContext) { if !logrusEnabler.Enable() { return } logger := call.GetData().(*logrus.Logger) logger.AddHook(&logHook{}) return } type logHook struct{} func (hook *logHook) Levels() []logrus.Level { return logrus.AllLevels } func (hook *logHook) Fire(entry *logrus.Entry) error { if !logrusEnabler.Enable() { return nil } // 修改日志内容 traceId, spanId := trace.GetTraceAndSpanId() if traceId != "" { entry.Data["trace_id"] = traceId } if spanId != "" { entry.Data["span_id"] = spanId } return nil }