mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-06 17:18:35 +08:00
issue: #33285 - use reader but not consumer for pulsar - advanced test framework - move some streaming related package into pkg --------- Signed-off-by: chyezh <chyezh@outlook.com>
28 lines
817 B
Go
28 lines
817 B
Go
package wal
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/milvus-io/milvus/pkg/streaming/util/message"
|
|
"github.com/milvus-io/milvus/pkg/streaming/util/types"
|
|
)
|
|
|
|
// WAL is the WAL framework interface.
|
|
// !!! Don't implement it directly, implement walimpls.WAL instead.
|
|
type WAL interface {
|
|
// Channel returns the channel assignment info of the wal.
|
|
Channel() types.PChannelInfo
|
|
|
|
// Append writes a record to the log.
|
|
Append(ctx context.Context, msg message.MutableMessage) (message.MessageID, error)
|
|
|
|
// Append a record to the log asynchronously.
|
|
AppendAsync(ctx context.Context, msg message.MutableMessage, cb func(message.MessageID, error))
|
|
|
|
// Read returns a scanner for reading records from the wal.
|
|
Read(ctx context.Context, deliverPolicy ReadOption) (Scanner, error)
|
|
|
|
// Close closes the wal instance.
|
|
Close()
|
|
}
|