mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-01-19 06:53:32 +08:00
refactor
This commit is contained in:
parent
bc8d2a01cc
commit
c616081ab9
@ -149,26 +149,17 @@ func (b *MessageQueueBroker) PublishMessage(stream mq_pb.SeaweedMessaging_Publis
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (b *MessageQueueBroker) loadLocalTopicPartitionFromFiler(t topic.Topic, p topic.Partition) (localTopicPartition *topic.LocalPartition, err error) {
|
func (b *MessageQueueBroker) loadLocalTopicPartitionFromFiler(t topic.Topic, p topic.Partition) (localTopicPartition *topic.LocalPartition, err error) {
|
||||||
|
self := b.option.BrokerAddress()
|
||||||
|
glog.V(0).Infof("broker %s load topic %v partition %v", self, t, p)
|
||||||
|
|
||||||
// load local topic partition from configuration on filer if not found
|
// load local topic partition from configuration on filer if not found
|
||||||
var conf *mq_pb.ConfigureTopicResponse
|
var conf *mq_pb.ConfigureTopicResponse
|
||||||
topicDir := fmt.Sprintf("%s/%s/%s", filer.TopicsDir, t.Namespace, t.Name)
|
conf, err = b.readTopicConfFromFiler(t, p)
|
||||||
if err = b.WithFilerClient(false, func(client filer_pb.SeaweedFilerClient) error {
|
if err != nil {
|
||||||
data, err := filer.ReadInsideFiler(client, topicDir, "topic.conf")
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("read topic %v partition %v conf: %v", t, p, err)
|
|
||||||
}
|
|
||||||
// parse into filer conf object
|
|
||||||
conf = &mq_pb.ConfigureTopicResponse{}
|
|
||||||
if err = jsonpb.Unmarshal(data, conf); err != nil {
|
|
||||||
return fmt.Errorf("unmarshal topic %v partition %v conf: %v", t, p, err)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}); err != nil {
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// create local topic partition
|
// create local topic partition
|
||||||
self := b.option.BrokerAddress()
|
|
||||||
var hasCreated bool
|
var hasCreated bool
|
||||||
for _, assignment := range conf.BrokerPartitionAssignments {
|
for _, assignment := range conf.BrokerPartitionAssignments {
|
||||||
if assignment.LeaderBroker == string(self) && p.Equals(topic.FromPbPartition(assignment.Partition)) {
|
if assignment.LeaderBroker == string(self) && p.Equals(topic.FromPbPartition(assignment.Partition)) {
|
||||||
@ -186,6 +177,25 @@ func (b *MessageQueueBroker) loadLocalTopicPartitionFromFiler(t topic.Topic, p t
|
|||||||
return localTopicPartition, nil
|
return localTopicPartition, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (b *MessageQueueBroker) readTopicConfFromFiler(t topic.Topic, p topic.Partition) (conf *mq_pb.ConfigureTopicResponse, err error) {
|
||||||
|
topicDir := fmt.Sprintf("%s/%s/%s", filer.TopicsDir, t.Namespace, t.Name)
|
||||||
|
if err = b.WithFilerClient(false, func(client filer_pb.SeaweedFilerClient) error {
|
||||||
|
data, err := filer.ReadInsideFiler(client, topicDir, "topic.conf")
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("read topic %v partition %v conf: %v", t, p, err)
|
||||||
|
}
|
||||||
|
// parse into filer conf object
|
||||||
|
conf = &mq_pb.ConfigureTopicResponse{}
|
||||||
|
if err = jsonpb.Unmarshal(data, conf); err != nil {
|
||||||
|
return fmt.Errorf("unmarshal topic %v partition %v conf: %v", t, p, err)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return conf, err
|
||||||
|
}
|
||||||
|
|
||||||
// duplicated from master_grpc_server.go
|
// duplicated from master_grpc_server.go
|
||||||
func findClientAddress(ctx context.Context) string {
|
func findClientAddress(ctx context.Context) string {
|
||||||
// fmt.Printf("FromContext %+v\n", ctx)
|
// fmt.Printf("FromContext %+v\n", ctx)
|
||||||
|
Loading…
Reference in New Issue
Block a user