mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-30 15:35:33 +08:00
This PR implements a new CDC service for Milvus 2.6, providing log-based cross-cluster replication. issue: https://github.com/milvus-io/milvus/issues/44123 --------- Signed-off-by: bigsheeper <yihao.dai@zilliz.com> Signed-off-by: chyezh <chyezh@outlook.com> Co-authored-by: chyezh <chyezh@outlook.com>
55 lines
1.9 KiB
Go
55 lines
1.9 KiB
Go
package service
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/milvus-io/milvus/internal/streamingnode/server/service/handler/consumer"
|
|
"github.com/milvus-io/milvus/internal/streamingnode/server/service/handler/producer"
|
|
"github.com/milvus-io/milvus/internal/streamingnode/server/walmanager"
|
|
"github.com/milvus-io/milvus/pkg/v2/proto/streamingpb"
|
|
)
|
|
|
|
var _ HandlerService = (*handlerServiceImpl)(nil)
|
|
|
|
// NewHandlerService creates a new handler service.
|
|
func NewHandlerService(walManager walmanager.Manager) HandlerService {
|
|
return &handlerServiceImpl{
|
|
walManager: walManager,
|
|
}
|
|
}
|
|
|
|
type HandlerService = streamingpb.StreamingNodeHandlerServiceServer
|
|
|
|
// handlerServiceImpl implements HandlerService.
|
|
// handlerServiceImpl is just a rpc level to handle incoming grpc.
|
|
// It should not handle any wal related logic, just
|
|
// 1. recv request and transfer param into wal
|
|
// 2. wait wal handling result and transform it into grpc response (convert error into grpc error)
|
|
// 3. send response to client.
|
|
type handlerServiceImpl struct {
|
|
walManager walmanager.Manager
|
|
}
|
|
|
|
// GetReplicateCheckpoint returns the WAL checkpoint that will be used to create scanner
|
|
func (hs *handlerServiceImpl) GetReplicateCheckpoint(ctx context.Context, req *streamingpb.GetReplicateCheckpointRequest) (*streamingpb.GetReplicateCheckpointResponse, error) {
|
|
panic("not implemented") // TODO: sheep, implement it.
|
|
}
|
|
|
|
// Produce creates a new producer for the channel on this log node.
|
|
func (hs *handlerServiceImpl) Produce(streamServer streamingpb.StreamingNodeHandlerService_ProduceServer) error {
|
|
p, err := producer.CreateProduceServer(hs.walManager, streamServer)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return p.Execute()
|
|
}
|
|
|
|
// Consume creates a new consumer for the channel on this log node.
|
|
func (hs *handlerServiceImpl) Consume(streamServer streamingpb.StreamingNodeHandlerService_ConsumeServer) error {
|
|
c, err := consumer.CreateConsumeServer(hs.walManager, streamServer)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return c.Execute()
|
|
}
|