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.

90 lines
1.7 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. package broker
  2. import (
  3. "io"
  4. "github.com/golang/protobuf/proto"
  5. "github.com/chrislusf/seaweedfs/weed/glog"
  6. "github.com/chrislusf/seaweedfs/weed/pb/messaging_pb"
  7. )
  8. func (broker *MessageBroker) Publish(stream messaging_pb.SeaweedMessaging_PublishServer) error {
  9. // process initial request
  10. in, err := stream.Recv()
  11. if err == io.EOF {
  12. return nil
  13. }
  14. if err != nil {
  15. return err
  16. }
  17. // TODO look it up
  18. topicConfig := &messaging_pb.TopicConfiguration{
  19. // IsTransient: true,
  20. }
  21. // send init response
  22. initResponse := &messaging_pb.PublishResponse{
  23. Config: nil,
  24. Redirect: nil,
  25. }
  26. err = stream.Send(initResponse)
  27. if err != nil {
  28. return err
  29. }
  30. if initResponse.Redirect != nil {
  31. return nil
  32. }
  33. // get lock
  34. tp := TopicPartition{
  35. Namespace: in.Init.Namespace,
  36. Topic: in.Init.Topic,
  37. Partition: in.Init.Partition,
  38. }
  39. tl := broker.topicLocks.RequestLock(tp, topicConfig, true)
  40. defer broker.topicLocks.ReleaseLock(tp, true)
  41. // process each message
  42. for {
  43. // println("recv")
  44. in, err := stream.Recv()
  45. // glog.V(0).Infof("recieved %v err: %v", in, err)
  46. if err == io.EOF {
  47. return nil
  48. }
  49. if err != nil {
  50. return err
  51. }
  52. if in.Data == nil {
  53. continue
  54. }
  55. // fmt.Printf("received: %d : %s\n", len(in.Data.Value), string(in.Data.Value))
  56. data, err := proto.Marshal(in.Data)
  57. if err != nil {
  58. glog.Errorf("marshall error: %v\n", err)
  59. continue
  60. }
  61. tl.logBuffer.AddToBuffer(in.Data.Key, data)
  62. if in.Data.IsClose {
  63. // println("server received closing")
  64. break
  65. }
  66. }
  67. // send the close ack
  68. // println("server send ack closing")
  69. if err := stream.Send(&messaging_pb.PublishResponse{IsClosed: true}); err != nil {
  70. glog.V(0).Infof("err sending close response: %v", err)
  71. }
  72. return nil
  73. }