mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-30 23:45:28 +08:00
30 lines
835 B
Go
30 lines
835 B
Go
package wal
|
|
|
|
import (
|
|
"github.com/milvus-io/milvus/internal/util/streamingutil/message"
|
|
"github.com/milvus-io/milvus/internal/util/streamingutil/options"
|
|
)
|
|
|
|
// ReadOption is the option for reading records from the wal.
|
|
type ReadOption struct {
|
|
DeliverPolicy options.DeliverPolicy
|
|
DeliverOrder options.DeliverOrder
|
|
}
|
|
|
|
// Scanner is the interface for reading records from the wal.
|
|
type Scanner interface {
|
|
// Chan returns the channel of message.
|
|
Chan() <-chan message.ImmutableMessage
|
|
|
|
// Error returns the error of scanner failed.
|
|
// Will block until scanner is closed or Chan is dry out.
|
|
Error() error
|
|
|
|
// Done returns a channel which will be closed when scanner is finished or closed.
|
|
Done() <-chan struct{}
|
|
|
|
// Close the scanner, release the underlying resources.
|
|
// Return the error same with `Error`
|
|
Close() error
|
|
}
|