mirror of
https://gitee.com/milvus-io/milvus.git
synced 2026-01-04 09:52:30 +08:00
issue: #43785 - pulsar client will print log into milvus logger now. - pulsar client open the metric by default. - upgrade the pulsar client to v0.15.1, and use offical repo. - the fixing of milvus-io/pulsar-client-go is already covered by official v0.15.1. Signed-off-by: chyezh <chyezh@outlook.com>
106 lines
2.5 KiB
Go
106 lines
2.5 KiB
Go
package pulsarlog
|
|
|
|
import (
|
|
plog "github.com/apache/pulsar-client-go/pulsar/log"
|
|
"go.uber.org/zap"
|
|
"go.uber.org/zap/zapcore"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/log"
|
|
)
|
|
|
|
var _ plog.Logger = (*logger)(nil)
|
|
|
|
// NewLogger creates a new pulsar logger.
|
|
// TODO: currently, pulsar client will log a huge message when logging,
|
|
// so we only log the first msg without format the log.
|
|
func NewLogger() plog.Logger {
|
|
return &logger{log.With(zap.String("component", "pulsar"))}
|
|
}
|
|
|
|
type logger struct {
|
|
inner *log.MLogger
|
|
}
|
|
|
|
func (l *logger) SubLogger(fields plog.Fields) plog.Logger {
|
|
return &logger{l.inner.With(exportFields(fields)...)}
|
|
}
|
|
|
|
func (l *logger) WithFields(fields plog.Fields) plog.Entry {
|
|
return &logger{l.inner.With(exportFields(fields)...)}
|
|
}
|
|
|
|
func (l *logger) WithField(name string, value interface{}) plog.Entry {
|
|
fs := exportFields(plog.Fields{name: value})
|
|
return &logger{l.inner.With(fs...)}
|
|
}
|
|
|
|
func (l *logger) WithError(err error) plog.Entry {
|
|
return &logger{l.inner.With(zap.Error(err))}
|
|
}
|
|
|
|
func (l *logger) Debug(args ...interface{}) {
|
|
l.logWithLevel(zap.DebugLevel, args...)
|
|
}
|
|
|
|
func (l *logger) Info(args ...interface{}) {
|
|
l.logWithLevel(zap.InfoLevel, args...)
|
|
}
|
|
|
|
func (l *logger) Warn(args ...interface{}) {
|
|
l.logWithLevel(zap.WarnLevel, args...)
|
|
}
|
|
|
|
func (l *logger) Error(args ...interface{}) {
|
|
l.logWithLevel(zap.ErrorLevel, args...)
|
|
}
|
|
|
|
func (l *logger) Debugf(format string, args ...interface{}) {
|
|
l.logWithLevel(zap.DebugLevel, format)
|
|
}
|
|
|
|
func (l *logger) Infof(format string, args ...interface{}) {
|
|
l.logWithLevel(zap.InfoLevel, format)
|
|
}
|
|
|
|
func (l *logger) Warnf(format string, args ...interface{}) {
|
|
l.logWithLevel(zap.WarnLevel, format)
|
|
}
|
|
|
|
func (l *logger) Errorf(format string, args ...interface{}) {
|
|
l.logWithLevel(zap.ErrorLevel, format)
|
|
}
|
|
|
|
func (l *logger) logWithLevel(level zapcore.Level, args ...interface{}) {
|
|
if len(args) == 0 {
|
|
return
|
|
}
|
|
if msg, ok := args[0].(string); ok {
|
|
l.inner.WithOptions(zap.AddCallerSkip(2)).Log(level, msg)
|
|
} else {
|
|
l.inner.WithOptions(zap.AddCallerSkip(2)).Log(level, "unknown log message type")
|
|
}
|
|
}
|
|
|
|
func exportFields(fields plog.Fields) []zap.Field {
|
|
fs := make([]zap.Field, 0, 2*len(fields))
|
|
for k, v := range fields {
|
|
switch v := v.(type) {
|
|
case string:
|
|
fs = append(fs, zap.String(k, v))
|
|
case int:
|
|
fs = append(fs, zap.Int(k, v))
|
|
case bool:
|
|
fs = append(fs, zap.Bool(k, v))
|
|
case float64:
|
|
fs = append(fs, zap.Float64(k, v))
|
|
case []byte:
|
|
fs = append(fs, zap.Binary(k, v))
|
|
case error:
|
|
fs = append(fs, zap.Error(v))
|
|
default:
|
|
fs = append(fs, zap.Any(k, v))
|
|
}
|
|
}
|
|
return fs
|
|
}
|