mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-06-28 13:31:55 +08:00

Some checks are pending
go: build dev binaries / cleanup (push) Waiting to run
go: build dev binaries / build_dev_linux_windows (amd64, linux) (push) Blocked by required conditions
go: build dev binaries / build_dev_linux_windows (amd64, windows) (push) Blocked by required conditions
go: build dev binaries / build_dev_darwin (amd64, darwin) (push) Blocked by required conditions
go: build dev binaries / build_dev_darwin (arm64, darwin) (push) Blocked by required conditions
docker: build dev containers / build-dev-containers (push) Waiting to run
End to End / FUSE Mount (push) Waiting to run
go: build binary / Build (push) Waiting to run
Ceph S3 tests / Ceph S3 tests (push) Waiting to run
* rename * set agent address * refactor * add agent sub * pub messages * grpc new client * can publish records via agent * send init message with session id * fmt * check cancelled request while waiting * use sessionId * handle possible nil stream * subscriber process messages * separate debug port * use atomic int64 * less logs * minor * skip io.EOF * rename * remove unused * use saved offsets * do not reuse session, since always session id is new after restart remove last active ts from SessionEntry * simplify printing * purge unused * just proxy the subscription, skipping the session step * adjust offset types * subscribe offset type and possible value * start after the known tsns * avoid wrongly set startPosition * move * remove * refactor * typo * fix * fix changed path
82 lines
2.2 KiB
Go
82 lines
2.2 KiB
Go
package agent_client
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"github.com/seaweedfs/seaweedfs/weed/mq/schema"
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/mq_agent_pb"
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/schema_pb"
|
|
"google.golang.org/grpc"
|
|
"google.golang.org/grpc/credentials/insecure"
|
|
)
|
|
|
|
type PublishSession struct {
|
|
schema *schema.Schema
|
|
partitionCount int
|
|
publisherName string
|
|
stream grpc.BidiStreamingClient[mq_agent_pb.PublishRecordRequest, mq_agent_pb.PublishRecordResponse]
|
|
}
|
|
|
|
func NewPublishSession(agentAddress string, topicSchema *schema.Schema, partitionCount int, publisherName string) (*PublishSession, error) {
|
|
|
|
// call local agent grpc server to create a new session
|
|
clientConn, err := grpc.NewClient(agentAddress, grpc.WithTransportCredentials(insecure.NewCredentials()))
|
|
if err != nil {
|
|
return nil, fmt.Errorf("dial agent server %s: %v", agentAddress, err)
|
|
}
|
|
agentClient := mq_agent_pb.NewSeaweedMessagingAgentClient(clientConn)
|
|
|
|
resp, err := agentClient.StartPublishSession(context.Background(), &mq_agent_pb.StartPublishSessionRequest{
|
|
Topic: &schema_pb.Topic{
|
|
Namespace: topicSchema.Namespace,
|
|
Name: topicSchema.Name,
|
|
},
|
|
PartitionCount: int32(partitionCount),
|
|
RecordType: topicSchema.RecordType,
|
|
PublisherName: publisherName,
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if resp.Error != "" {
|
|
return nil, fmt.Errorf("start publish session: %v", resp.Error)
|
|
}
|
|
|
|
stream, err := agentClient.PublishRecord(context.Background())
|
|
if err != nil {
|
|
return nil, fmt.Errorf("publish record: %v", err)
|
|
}
|
|
|
|
if err = stream.Send(&mq_agent_pb.PublishRecordRequest{
|
|
SessionId: resp.SessionId,
|
|
}); err != nil {
|
|
return nil, fmt.Errorf("send session id: %v", err)
|
|
}
|
|
|
|
return &PublishSession{
|
|
schema: topicSchema,
|
|
partitionCount: partitionCount,
|
|
publisherName: publisherName,
|
|
stream: stream,
|
|
}, nil
|
|
}
|
|
|
|
func (a *PublishSession) CloseSession() error {
|
|
if a.schema == nil {
|
|
return nil
|
|
}
|
|
err := a.stream.CloseSend()
|
|
if err != nil {
|
|
return fmt.Errorf("close send: %v", err)
|
|
}
|
|
a.schema = nil
|
|
return err
|
|
}
|
|
|
|
func (a *PublishSession) PublishMessageRecord(key []byte, record *schema_pb.RecordValue) error {
|
|
return a.stream.Send(&mq_agent_pb.PublishRecordRequest{
|
|
Key: key,
|
|
Value: record,
|
|
})
|
|
}
|