You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
package broker
import ( "io"
"github.com/golang/protobuf/proto"
"github.com/chrislusf/seaweedfs/weed/glog" "github.com/chrislusf/seaweedfs/weed/pb/messaging_pb" )
func (broker *MessageBroker) Publish(stream messaging_pb.SeaweedMessaging_PublishServer) error {
// process initial request
in, err := stream.Recv() if err == io.EOF { return nil } if err != nil { return err }
// TODO look it up
topicConfig := &messaging_pb.TopicConfiguration{ IsTransient: true, }
// send init response
initResponse := &messaging_pb.PublishResponse{ Config: nil, Redirect: nil, } err = stream.Send(initResponse) if err != nil { return err } if initResponse.Redirect != nil { return nil }
// get lock
tp := TopicPartition{ Namespace: in.Init.Namespace, Topic: in.Init.Topic, Partition: in.Init.Partition, } tl := broker.topicLocks.RequestLock(tp, topicConfig, true) defer broker.topicLocks.ReleaseLock(tp, true)
updatesChan := make(chan int32)
go func() { for update := range updatesChan { if err := stream.Send(&messaging_pb.PublishResponse{ Config: &messaging_pb.PublishResponse_ConfigMessage{ PartitionCount: update, }, }); err != nil { glog.V(0).Infof("err sending publish response: %v", err) return } } }()
// process each message
for { in, err := stream.Recv() if err == io.EOF { return nil } if err != nil { return err }
if in.Data == nil { continue }
// fmt.Printf("received: %d : %s\n", len(in.Data.Value), string(in.Data.Value))
data, err := proto.Marshal(in.Data) if err != nil { glog.Errorf("marshall error: %v\n", err) continue }
tl.logBuffer.AddToBuffer(in.Data.Key, data)
} }
|