yihao.dai 51f69f32d0
feat: Add CDC support (#44124)
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>
2025-09-16 16:32:01 +08:00

50 lines
1.5 KiB
Go

package contextutil
import (
"context"
"encoding/base64"
"fmt"
"github.com/cockroachdb/errors"
"google.golang.org/grpc/metadata"
"google.golang.org/protobuf/proto"
"github.com/milvus-io/milvus/pkg/v2/proto/streamingpb"
)
const createProducerKey = "create-producer"
// WithCreateProducer attaches create producer request to context.
func WithCreateProducer(ctx context.Context, req *streamingpb.CreateProducerRequest) context.Context {
bytes, err := proto.Marshal(req)
if err != nil {
panic(fmt.Sprintf("unreachable: marshal create producer request failed, %+v", err))
}
// use base64 encoding to transfer binary to text.
msg := base64.StdEncoding.EncodeToString(bytes)
return metadata.AppendToOutgoingContext(ctx, createProducerKey, msg)
}
// GetCreateProducer gets create producer request from context.
func GetCreateProducer(ctx context.Context) (*streamingpb.CreateProducerRequest, error) {
md, ok := metadata.FromIncomingContext(ctx)
if !ok {
return nil, errors.New("create producer metadata not found from incoming context")
}
msg := md.Get(createProducerKey)
if len(msg) == 0 {
return nil, errors.New("create consumer metadata not found")
}
bytes, err := base64.StdEncoding.DecodeString(msg[0])
if err != nil {
return nil, errors.Wrap(err, "decode create consumer metadata failed")
}
req := &streamingpb.CreateProducerRequest{}
if err := proto.Unmarshal(bytes, req); err != nil {
return nil, errors.Wrap(err, "unmarshal create producer request failed")
}
return req, nil
}