|
@ -3,6 +3,8 @@ package broker |
|
|
import ( |
|
|
import ( |
|
|
"context" |
|
|
"context" |
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/mq_pb" |
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/mq_pb" |
|
|
|
|
|
"google.golang.org/grpc/codes" |
|
|
|
|
|
"google.golang.org/grpc/status" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
// FindTopicBrokers returns the brokers that are serving the topic
|
|
|
// FindTopicBrokers returns the brokers that are serving the topic
|
|
@ -17,30 +19,25 @@ import ( |
|
|
// 2.2 if the topic is found, return the brokers
|
|
|
// 2.2 if the topic is found, return the brokers
|
|
|
//
|
|
|
//
|
|
|
// 3. unlock the topic
|
|
|
// 3. unlock the topic
|
|
|
func (broker *MessageQueueBroker) LookupTopicBrokers(ctx context.Context, request *mq_pb.LookupTopicBrokersRequest) (*mq_pb.LookupTopicBrokersResponse, error) { |
|
|
|
|
|
ret := &mq_pb.LookupTopicBrokersResponse{} |
|
|
|
|
|
// TODO lock the topic
|
|
|
|
|
|
|
|
|
func (broker *MessageQueueBroker) LookupTopicBrokers(ctx context.Context, request *mq_pb.LookupTopicBrokersRequest) (resp *mq_pb.LookupTopicBrokersResponse, err error) { |
|
|
|
|
|
if broker.currentBalancer == "" { |
|
|
|
|
|
return nil, status.Errorf(codes.Unavailable, "no balancer") |
|
|
|
|
|
} |
|
|
|
|
|
if !broker.lockAsBalancer.IsLocked() { |
|
|
|
|
|
proxyErr := broker.withBrokerClient(false, broker.currentBalancer, func(client mq_pb.SeaweedMessagingClient) error { |
|
|
|
|
|
resp, err = client.LookupTopicBrokers(ctx, request) |
|
|
|
|
|
return nil |
|
|
|
|
|
}) |
|
|
|
|
|
if proxyErr != nil { |
|
|
|
|
|
return nil, proxyErr |
|
|
|
|
|
} |
|
|
|
|
|
return resp, err |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// find the topic partitions on the filer
|
|
|
|
|
|
// if the topic is not found
|
|
|
|
|
|
// if the request is_for_publish
|
|
|
|
|
|
// create the topic
|
|
|
|
|
|
// if the request is_for_subscribe
|
|
|
|
|
|
// return error not found
|
|
|
|
|
|
// t := topic.FromPbTopic(request.Topic)
|
|
|
|
|
|
|
|
|
ret := &mq_pb.LookupTopicBrokersResponse{} |
|
|
ret.Topic = request.Topic |
|
|
ret.Topic = request.Topic |
|
|
ret.BrokerPartitionAssignments = []*mq_pb.BrokerPartitionAssignment{ |
|
|
|
|
|
{ |
|
|
|
|
|
LeaderBroker: "localhost:17777", |
|
|
|
|
|
FollowerBrokers: []string{"localhost:17777"}, |
|
|
|
|
|
Partition: &mq_pb.Partition{ |
|
|
|
|
|
RingSize: MaxPartitionCount, |
|
|
|
|
|
RangeStart: 0, |
|
|
|
|
|
RangeStop: MaxPartitionCount, |
|
|
|
|
|
}, |
|
|
|
|
|
}, |
|
|
|
|
|
} |
|
|
|
|
|
return ret, nil |
|
|
|
|
|
|
|
|
ret.BrokerPartitionAssignments, err = broker.Balancer.LookupOrAllocateTopicPartitions(ret.Topic, request.IsForPublish) |
|
|
|
|
|
return ret, err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// CheckTopicPartitionsStatus check the topic partitions on the broker
|
|
|
// CheckTopicPartitionsStatus check the topic partitions on the broker
|
|
|