2022-12-06 04:54:08 +08:00
|
|
|
package kafka
|
|
|
|
|
|
|
|
|
|
import (
|
2024-08-01 06:32:24 +08:00
|
|
|
"sync"
|
|
|
|
|
|
2023-11-28 00:13:22 +08:00
|
|
|
"github.com/IBM/sarama"
|
2022-12-06 04:54:08 +08:00
|
|
|
|
|
|
|
|
"github.com/influxdata/telegraf"
|
2024-05-11 05:43:43 +08:00
|
|
|
"github.com/influxdata/telegraf/logger"
|
2022-12-06 04:54:08 +08:00
|
|
|
)
|
|
|
|
|
|
2024-08-01 06:32:24 +08:00
|
|
|
var (
|
|
|
|
|
log = logger.New("sarama", "", "")
|
|
|
|
|
once sync.Once
|
|
|
|
|
)
|
2022-12-06 04:54:08 +08:00
|
|
|
|
2024-08-01 06:32:24 +08:00
|
|
|
type debugLogger struct{}
|
2022-12-06 04:54:08 +08:00
|
|
|
|
2025-01-14 16:24:13 +08:00
|
|
|
func (*debugLogger) Print(v ...interface{}) {
|
2024-08-01 06:32:24 +08:00
|
|
|
log.Trace(v...)
|
2022-12-06 04:54:08 +08:00
|
|
|
}
|
|
|
|
|
|
2025-01-14 16:24:13 +08:00
|
|
|
func (*debugLogger) Printf(format string, v ...interface{}) {
|
2024-08-01 06:32:24 +08:00
|
|
|
log.Tracef(format, v...)
|
2022-12-06 04:54:08 +08:00
|
|
|
}
|
|
|
|
|
|
2024-08-01 06:32:24 +08:00
|
|
|
func (l *debugLogger) Println(v ...interface{}) {
|
2022-12-06 04:54:08 +08:00
|
|
|
l.Print(v...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// SetLogger configures a debug logger for kafka (sarama)
|
2024-08-01 06:32:24 +08:00
|
|
|
func SetLogger(level telegraf.LogLevel) {
|
|
|
|
|
// Set-up the sarama logger only once
|
|
|
|
|
once.Do(func() {
|
|
|
|
|
sarama.Logger = &debugLogger{}
|
|
|
|
|
})
|
|
|
|
|
// Increase the log-level if needed.
|
|
|
|
|
if !log.Level().Includes(level) {
|
|
|
|
|
log.SetLevel(level)
|
|
|
|
|
}
|
2022-12-06 04:54:08 +08:00
|
|
|
}
|