1 Star 0 Fork 0

妥協/fabric

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
logger.go 3.89 KB
一键复制 编辑 原始数据 按行查看 历史
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package kafka
import (
"fmt"
"strings"
"sync"
"github.com/Shopify/sarama"
"github.com/hyperledger/fabric/common/flogging"
"go.uber.org/zap"
)
const (
pkgLogID = "orderer/consensus/kafka"
saramaLogID = pkgLogID + "/sarama"
)
var logger = flogging.MustGetLogger(pkgLogID)
var saramaLogger eventLogger
// init initializes the samara logger
func init() {
loggingProvider := flogging.MustGetLogger(saramaLogID)
saramaEventLogger := &saramaLoggerImpl{
logger: loggingProvider.WithOptions(zap.AddCallerSkip(3)),
eventListenerSupport: &eventListenerSupport{
listeners: make(map[string][]chan string),
},
}
sarama.Logger = saramaEventLogger
saramaLogger = saramaEventLogger
}
// init starts a go routine that detects a possible configuration issue
func init() {
listener := saramaLogger.NewListener("insufficient data to decode packet")
go func() {
for {
select {
case <-listener:
logger.Critical("Unable to decode a Kafka packet. Usually, this " +
"indicates that the Kafka.Version specified in the orderer " +
"configuration is incorrectly set to a version which is newer than " +
"the actual Kafka broker version.")
}
}
}()
}
// eventLogger adapts a Logger to the sarama.Logger interface.
// Additionally, listeners can be registered to be notified when a substring has
// been logged.
type eventLogger interface {
sarama.StdLogger
NewListener(substr string) <-chan string
RemoveListener(substr string, listener <-chan string)
}
type debugger interface {
Debug(...interface{})
}
type saramaLoggerImpl struct {
logger debugger
eventListenerSupport *eventListenerSupport
}
func (l saramaLoggerImpl) Print(args ...interface{}) {
l.print(fmt.Sprint(args...))
}
func (l saramaLoggerImpl) Printf(format string, args ...interface{}) {
l.print(fmt.Sprintf(format, args...))
}
func (l saramaLoggerImpl) Println(args ...interface{}) {
l.print(fmt.Sprintln(args...))
}
func (l saramaLoggerImpl) print(message string) {
l.eventListenerSupport.fire(message)
l.logger.Debug(message)
}
// this should be more than enough for a well behaved listener
const listenerChanSize = 100
func (l saramaLoggerImpl) NewListener(substr string) <-chan string {
listener := make(chan string, listenerChanSize)
l.eventListenerSupport.addListener(substr, listener)
return listener
}
func (l saramaLoggerImpl) RemoveListener(substr string, listener <-chan string) {
l.eventListenerSupport.removeListener(substr, listener)
}
// eventListenerSupport maintains a map of substrings to a list of listeners
// interested in receiving a notification when the substring is logged.
type eventListenerSupport struct {
sync.Mutex
listeners map[string][]chan string
}
// addListener adds a listener to the list of listeners for the specified substring
func (b *eventListenerSupport) addListener(substr string, listener chan string) {
b.Lock()
defer b.Unlock()
if listeners, ok := b.listeners[substr]; ok {
b.listeners[substr] = append(listeners, listener)
} else {
b.listeners[substr] = []chan string{listener}
}
}
// fire sends the specified message to each listener that is registered with
// a substring contained in the message
func (b *eventListenerSupport) fire(message string) {
b.Lock()
defer b.Unlock()
for substr, listeners := range b.listeners {
if strings.Contains(message, substr) {
for _, listener := range listeners {
listener <- message
}
}
}
}
// addListener removes a listener from the list of listeners for the specified substring
func (b *eventListenerSupport) removeListener(substr string, listener <-chan string) {
b.Lock()
defer b.Unlock()
if listeners, ok := b.listeners[substr]; ok {
for i, l := range listeners {
if l == listener {
copy(listeners[i:], listeners[i+1:])
listeners[len(listeners)-1] = nil
b.listeners[substr] = listeners[:len(listeners)-1]
}
}
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/liurenhao/fabric.git
git@gitee.com:liurenhao/fabric.git
liurenhao
fabric
fabric
v1.3.0

搜索帮助