seaweedfs/weed/messaging/msgclient/pub_chan.go

77 lines
1.6 KiB
Go
Raw Normal View History

2020-05-05 17:05:28 +08:00
package msgclient
import (
2020-05-09 15:43:53 +08:00
"crypto/md5"
"hash"
2020-05-05 17:05:28 +08:00
"io"
"log"
2020-05-08 17:47:22 +08:00
"google.golang.org/grpc"
2020-05-05 17:05:28 +08:00
"github.com/chrislusf/seaweedfs/weed/messaging/broker"
"github.com/chrislusf/seaweedfs/weed/pb/messaging_pb"
)
type PubChannel struct {
2020-05-08 17:47:22 +08:00
client messaging_pb.SeaweedMessaging_PublishClient
grpcConnection *grpc.ClientConn
2020-05-09 15:43:53 +08:00
md5hash hash.Hash
2020-05-05 17:05:28 +08:00
}
func (mc *MessagingClient) NewPubChannel(chanName string) (*PubChannel, error) {
tp := broker.TopicPartition{
Namespace: "chan",
Topic: chanName,
Partition: 0,
}
grpcConnection, err := mc.findBroker(tp)
if err != nil {
return nil, err
}
pc, err := setupPublisherClient(grpcConnection, tp)
if err != nil {
return nil, err
}
return &PubChannel{
2020-05-08 17:47:22 +08:00
client: pc,
grpcConnection: grpcConnection,
2020-05-09 15:43:53 +08:00
md5hash: md5.New(),
2020-05-05 17:05:28 +08:00
}, nil
}
func (pc *PubChannel) Publish(m []byte) error {
2020-05-09 15:43:53 +08:00
err := pc.client.Send(&messaging_pb.PublishRequest{
2020-05-05 17:05:28 +08:00
Data: &messaging_pb.Message{
Value: m,
},
})
2020-05-09 15:43:53 +08:00
if err == nil {
pc.md5hash.Write(m)
}
return err
2020-05-05 17:05:28 +08:00
}
func (pc *PubChannel) Close() error {
2020-05-08 17:47:22 +08:00
// println("send closing")
if err := pc.client.Send(&messaging_pb.PublishRequest{
Data: &messaging_pb.Message{
IsClose: true,
},
}); err != nil {
log.Printf("err send close: %v", err)
}
// println("receive closing")
if _, err := pc.client.Recv(); err != nil && err != io.EOF {
log.Printf("err receive close: %v", err)
}
// println("close connection")
if err := pc.grpcConnection.Close(); err != nil {
log.Printf("err connection close: %v", err)
}
return nil
2020-05-05 17:05:28 +08:00
}
2020-05-09 15:43:53 +08:00
func (pc *PubChannel) Md5() []byte {
return pc.md5hash.Sum(nil)
}