Zhen Ye 5bdc593b8a
enhance: use v0.15.1 official pulsar client and add logging for pulsar client (#43913)
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>
2025-08-26 16:45:53 +08:00

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
}