Browse Source
publish to input buffer
publish to input buffer
currently, the input buffer may not exist when start to publishpull/5637/head
chrislu
12 months ago
7 changed files with 103 additions and 134 deletions
-
1weed/mq/broker/broker_grpc_lookup.go
-
5weed/mq/broker/broker_topic_conf_read_write.go
-
6weed/mq/client/cmd/weed_pub/publisher.go
-
86weed/mq/client/pub_client/lookup.go
-
28weed/mq/client/pub_client/publish.go
-
25weed/mq/client/pub_client/publisher.go
-
74weed/mq/client/pub_client/scheduler.go
@ -1,86 +0,0 @@ |
|||
package pub_client |
|||
|
|||
import ( |
|||
"context" |
|||
"fmt" |
|||
"github.com/seaweedfs/seaweedfs/weed/glog" |
|||
"github.com/seaweedfs/seaweedfs/weed/pb" |
|||
"github.com/seaweedfs/seaweedfs/weed/pb/mq_pb" |
|||
) |
|||
|
|||
func (p *TopicPublisher) doLookupAndConnect(brokerAddress string) error { |
|||
if p.config.CreateTopic { |
|||
err := pb.WithBrokerGrpcClient(true, |
|||
brokerAddress, |
|||
p.grpcDialOption, |
|||
func(client mq_pb.SeaweedMessagingClient) error { |
|||
_, err := client.ConfigureTopic(context.Background(), &mq_pb.ConfigureTopicRequest{ |
|||
Topic: &mq_pb.Topic{ |
|||
Namespace: p.namespace, |
|||
Name: p.topic, |
|||
}, |
|||
PartitionCount: p.config.CreateTopicPartitionCount, |
|||
}) |
|||
return err |
|||
}) |
|||
if err != nil { |
|||
return fmt.Errorf("configure topic %s/%s: %v", p.namespace, p.topic, err) |
|||
} |
|||
} |
|||
|
|||
err := pb.WithBrokerGrpcClient(true, |
|||
brokerAddress, |
|||
p.grpcDialOption, |
|||
func(client mq_pb.SeaweedMessagingClient) error { |
|||
lookupResp, err := client.LookupTopicBrokers(context.Background(), |
|||
&mq_pb.LookupTopicBrokersRequest{ |
|||
Topic: &mq_pb.Topic{ |
|||
Namespace: p.namespace, |
|||
Name: p.topic, |
|||
}, |
|||
}) |
|||
glog.V(0).Infof("lookup1 topic %s/%s: %v", p.namespace, p.topic, lookupResp) |
|||
if p.config.CreateTopic && err != nil { |
|||
_, err = client.ConfigureTopic(context.Background(), &mq_pb.ConfigureTopicRequest{ |
|||
Topic: &mq_pb.Topic{ |
|||
Namespace: p.namespace, |
|||
Name: p.topic, |
|||
}, |
|||
PartitionCount: p.config.CreateTopicPartitionCount, |
|||
}) |
|||
if err != nil { |
|||
return err |
|||
} |
|||
lookupResp, err = client.LookupTopicBrokers(context.Background(), |
|||
&mq_pb.LookupTopicBrokersRequest{ |
|||
Topic: &mq_pb.Topic{ |
|||
Namespace: p.namespace, |
|||
Name: p.topic, |
|||
}, |
|||
}) |
|||
glog.V(0).Infof("lookup2 topic %s/%s: %v", p.namespace, p.topic, lookupResp) |
|||
} |
|||
if err != nil { |
|||
return err |
|||
} |
|||
|
|||
for _, brokerPartitionAssignment := range lookupResp.BrokerPartitionAssignments { |
|||
glog.V(0).Infof("topic %s/%s partition %v leader %s followers %v", p.namespace, p.topic, brokerPartitionAssignment.Partition, brokerPartitionAssignment.LeaderBroker, brokerPartitionAssignment.FollowerBrokers) |
|||
// partition => publishClient
|
|||
publishClient, err := p.doConnect(brokerPartitionAssignment.Partition, brokerPartitionAssignment.LeaderBroker) |
|||
if err != nil { |
|||
return err |
|||
} |
|||
p.partition2Broker.Insert( |
|||
brokerPartitionAssignment.Partition.RangeStart, |
|||
brokerPartitionAssignment.Partition.RangeStop, |
|||
publishClient) |
|||
} |
|||
return nil |
|||
}) |
|||
|
|||
if err != nil { |
|||
return fmt.Errorf("lookup topic %s/%s: %v", p.namespace, p.topic, err) |
|||
} |
|||
return nil |
|||
} |
Reference in new issue
xxxxxxxxxx