mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-07 09:38:39 +08:00
issue: #41544 - implement message can be logged as a field by zap. - fix too many slow log for woodpecker. Signed-off-by: chyezh <chyezh@outlook.com>
87 lines
2.1 KiB
Go
87 lines
2.1 KiB
Go
package wp
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"fmt"
|
|
|
|
"github.com/cockroachdb/errors"
|
|
wp "github.com/zilliztech/woodpecker/woodpecker/log"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
|
|
)
|
|
|
|
func NewWpID(id *wp.LogMessageId) message.MessageID {
|
|
return wpID{
|
|
logMsgId: id,
|
|
}
|
|
}
|
|
|
|
func UnmarshalMessageID(data string) (message.MessageID, error) {
|
|
id, err := unmarshalMessageID(data)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return id, nil
|
|
}
|
|
|
|
func unmarshalMessageID(data string) (wpID, error) {
|
|
val, err := base64.StdEncoding.DecodeString(data)
|
|
if err != nil {
|
|
return wpID{logMsgId: nil}, errors.Wrapf(message.ErrInvalidMessageID, "decode pulsar fail when decode base64 with err: %s, id: %s", err.Error(), data)
|
|
}
|
|
msgID, err := wp.DeserializeLogMessageId(val)
|
|
if err != nil {
|
|
return wpID{logMsgId: nil}, errors.Wrapf(message.ErrInvalidMessageID, "decode pulsar fail when deserialize with err: %s, id: %s", err.Error(), data)
|
|
}
|
|
return wpID{logMsgId: msgID}, nil
|
|
}
|
|
|
|
var _ message.MessageID = wpID{}
|
|
|
|
type wpID struct {
|
|
logMsgId *wp.LogMessageId
|
|
}
|
|
|
|
func (id wpID) WoodpeckerID() *wp.LogMessageId {
|
|
return id.logMsgId
|
|
}
|
|
|
|
func (id wpID) WoodpeckerMsgId() *wp.LogMessageId {
|
|
return id.logMsgId
|
|
}
|
|
|
|
func (id wpID) WALName() string {
|
|
return WALName
|
|
}
|
|
|
|
func (id wpID) LT(other message.MessageID) bool {
|
|
id2 := other.(wpID)
|
|
if id.logMsgId.SegmentId != id2.logMsgId.SegmentId {
|
|
return id.logMsgId.SegmentId < id2.logMsgId.SegmentId
|
|
}
|
|
return id.logMsgId.EntryId < id2.logMsgId.EntryId
|
|
}
|
|
|
|
func (id wpID) LTE(other message.MessageID) bool {
|
|
id2 := other.(wpID)
|
|
if id.logMsgId.SegmentId < id2.logMsgId.SegmentId {
|
|
return true
|
|
} else if id.logMsgId.SegmentId > id2.logMsgId.SegmentId {
|
|
return false
|
|
}
|
|
return id.logMsgId.EntryId <= id2.logMsgId.EntryId
|
|
}
|
|
|
|
func (id wpID) EQ(other message.MessageID) bool {
|
|
id2 := other.(wpID)
|
|
return id.logMsgId.SegmentId == id2.logMsgId.SegmentId && id.logMsgId.EntryId == id2.logMsgId.EntryId
|
|
}
|
|
|
|
func (id wpID) Marshal() string {
|
|
return base64.StdEncoding.EncodeToString(id.logMsgId.Serialize())
|
|
}
|
|
|
|
func (id wpID) String() string {
|
|
return fmt.Sprintf("%d/%d", id.logMsgId.SegmentId, id.logMsgId.EntryId)
|
|
}
|