mirror of
https://gitee.com/milvus-io/milvus.git
synced 2026-01-06 02:42:53 +08:00
issue: #41439 - add IsPersisted and VChannel interface for message - add WithNotPersisted() for message builder - fix the persisted time tick lost at write ahead buffer Signed-off-by: chyezh <chyezh@outlook.com>
34 lines
1.2 KiB
Go
34 lines
1.2 KiB
Go
package timetick
|
|
|
|
import (
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/msgpb"
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
|
|
"github.com/milvus-io/milvus/pkg/v2/util/commonpbutil"
|
|
)
|
|
|
|
func NewTimeTickMsg(ts uint64, lastConfirmedMessageID message.MessageID, sourceID int64, persist bool) message.MutableMessage {
|
|
// TODO: time tick should be put on properties, for compatibility, we put it on message body now.
|
|
// Common message's time tick is set on interceptor.
|
|
// TimeTickMsg's time tick should be set here.
|
|
b := message.NewTimeTickMessageBuilderV1().
|
|
WithHeader(&message.TimeTickMessageHeader{}).
|
|
WithBody(&msgpb.TimeTickMsg{
|
|
Base: commonpbutil.NewMsgBase(
|
|
commonpbutil.WithMsgType(commonpb.MsgType_TimeTick),
|
|
commonpbutil.WithMsgID(0),
|
|
commonpbutil.WithTimeStamp(ts),
|
|
commonpbutil.WithSourceID(sourceID),
|
|
),
|
|
}).
|
|
WithAllVChannel()
|
|
if !persist {
|
|
b.WithNotPersisted()
|
|
}
|
|
msg := b.MustBuildMutable()
|
|
if lastConfirmedMessageID != nil {
|
|
return msg.WithTimeTick(ts).WithLastConfirmed(lastConfirmedMessageID)
|
|
}
|
|
return msg.WithTimeTick(ts).WithLastConfirmedUseMessageID()
|
|
}
|