2020-03-04 08:39:47 +00:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"google.golang.org/grpc/reflection"
|
|
|
|
|
2022-07-29 07:17:28 +00:00
|
|
|
"github.com/seaweedfs/seaweedfs/weed/util/grace"
|
2020-05-05 09:05:28 +00:00
|
|
|
|
2022-07-29 07:17:28 +00:00
|
|
|
"github.com/seaweedfs/seaweedfs/weed/glog"
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/mq/broker"
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/pb"
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/mq_pb"
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/security"
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/util"
|
2020-03-04 08:39:47 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2022-07-02 04:59:50 +00:00
|
|
|
mqBrokerStandaloneOptions MessageQueueBrokerOptions
|
2020-03-04 08:39:47 +00:00
|
|
|
)
|
|
|
|
|
2022-07-02 04:59:50 +00:00
|
|
|
type MessageQueueBrokerOptions struct {
|
2022-07-10 19:11:37 +00:00
|
|
|
masters map[string]pb.ServerAddress
|
|
|
|
mastersString *string
|
|
|
|
filerGroup *string
|
|
|
|
ip *string
|
|
|
|
port *int
|
|
|
|
dataCenter *string
|
|
|
|
rack *string
|
|
|
|
cpuprofile *string
|
|
|
|
memprofile *string
|
2020-03-04 08:39:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
2022-07-02 04:59:50 +00:00
|
|
|
cmdMqBroker.Run = runMqBroker // break init cycle
|
2022-07-10 19:11:37 +00:00
|
|
|
mqBrokerStandaloneOptions.mastersString = cmdMqBroker.Flag.String("master", "localhost:9333", "comma-separated master servers")
|
2022-07-02 06:34:51 +00:00
|
|
|
mqBrokerStandaloneOptions.filerGroup = cmdMqBroker.Flag.String("filerGroup", "", "share metadata with other filers in the same filerGroup")
|
2022-07-02 04:59:50 +00:00
|
|
|
mqBrokerStandaloneOptions.ip = cmdMqBroker.Flag.String("ip", util.DetectedHostAddress(), "broker host address")
|
|
|
|
mqBrokerStandaloneOptions.port = cmdMqBroker.Flag.Int("port", 17777, "broker gRPC listen port")
|
2022-07-02 16:28:24 +00:00
|
|
|
mqBrokerStandaloneOptions.dataCenter = cmdMqBroker.Flag.String("dataCenter", "", "prefer to read and write to volumes in this data center")
|
|
|
|
mqBrokerStandaloneOptions.rack = cmdMqBroker.Flag.String("rack", "", "prefer to write to volumes in this rack")
|
2022-07-02 04:59:50 +00:00
|
|
|
mqBrokerStandaloneOptions.cpuprofile = cmdMqBroker.Flag.String("cpuprofile", "", "cpu profile output file")
|
|
|
|
mqBrokerStandaloneOptions.memprofile = cmdMqBroker.Flag.String("memprofile", "", "memory profile output file")
|
2020-03-04 08:39:47 +00:00
|
|
|
}
|
|
|
|
|
2022-07-02 04:59:50 +00:00
|
|
|
var cmdMqBroker = &Command{
|
2022-07-10 19:11:37 +00:00
|
|
|
UsageLine: "mq.broker [-port=17777] [-master=<ip:port>]",
|
2022-07-30 16:36:27 +00:00
|
|
|
Short: "<WIP> start a message queue broker",
|
2020-03-04 08:39:47 +00:00
|
|
|
Long: `start a message queue broker
|
|
|
|
|
|
|
|
The broker can accept gRPC calls to write or read messages. The messages are stored via filer.
|
|
|
|
The brokers are stateless. To scale up, just add more brokers.
|
|
|
|
|
|
|
|
`,
|
|
|
|
}
|
|
|
|
|
2022-07-02 04:59:50 +00:00
|
|
|
func runMqBroker(cmd *Command, args []string) bool {
|
2020-03-04 08:39:47 +00:00
|
|
|
|
|
|
|
util.LoadConfiguration("security", false)
|
|
|
|
|
2022-07-10 19:11:37 +00:00
|
|
|
mqBrokerStandaloneOptions.masters = pb.ServerAddresses(*mqBrokerStandaloneOptions.mastersString).ToAddressMap()
|
|
|
|
|
2022-07-02 04:59:50 +00:00
|
|
|
return mqBrokerStandaloneOptions.startQueueServer()
|
2020-03-04 08:39:47 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-07-02 04:59:50 +00:00
|
|
|
func (mqBrokerOpt *MessageQueueBrokerOptions) startQueueServer() bool {
|
2020-03-04 08:39:47 +00:00
|
|
|
|
2022-07-02 04:59:50 +00:00
|
|
|
grace.SetupProfiling(*mqBrokerStandaloneOptions.cpuprofile, *mqBrokerStandaloneOptions.memprofile)
|
2020-04-19 10:03:40 +00:00
|
|
|
|
2020-04-17 09:29:00 +00:00
|
|
|
grpcDialOption := security.LoadClientTLS(util.GetViper(), "grpc.msg_broker")
|
2020-03-04 08:39:47 +00:00
|
|
|
|
2022-07-02 06:34:51 +00:00
|
|
|
qs, err := broker.NewMessageBroker(&broker.MessageQueueBrokerOption{
|
2022-07-10 19:11:37 +00:00
|
|
|
Masters: mqBrokerOpt.masters,
|
2022-07-02 06:34:51 +00:00
|
|
|
FilerGroup: *mqBrokerOpt.filerGroup,
|
2022-07-03 07:29:25 +00:00
|
|
|
DataCenter: *mqBrokerOpt.dataCenter,
|
|
|
|
Rack: *mqBrokerOpt.rack,
|
2020-03-04 08:39:47 +00:00
|
|
|
DefaultReplication: "",
|
|
|
|
MaxMB: 0,
|
2022-07-02 04:59:50 +00:00
|
|
|
Ip: *mqBrokerOpt.ip,
|
|
|
|
Port: *mqBrokerOpt.port,
|
2020-04-17 09:29:00 +00:00
|
|
|
}, grpcDialOption)
|
2023-11-20 12:57:38 +00:00
|
|
|
if err != nil {
|
|
|
|
glog.Fatalf("failed to create new message broker for queue server: %v", err)
|
|
|
|
}
|
2020-03-04 08:39:47 +00:00
|
|
|
|
|
|
|
// start grpc listener
|
2022-07-02 04:59:50 +00:00
|
|
|
grpcL, _, err := util.NewIpAndLocalListeners("", *mqBrokerOpt.port, 0)
|
2020-03-04 08:39:47 +00:00
|
|
|
if err != nil {
|
2022-07-02 04:59:50 +00:00
|
|
|
glog.Fatalf("failed to listen on grpc port %d: %v", *mqBrokerOpt.port, err)
|
2020-03-04 08:39:47 +00:00
|
|
|
}
|
|
|
|
grpcS := pb.NewGrpcServer(security.LoadServerTLS(util.GetViper(), "grpc.msg_broker"))
|
2022-07-02 05:43:25 +00:00
|
|
|
mq_pb.RegisterSeaweedMessagingServer(grpcS, qs)
|
2020-03-04 08:39:47 +00:00
|
|
|
reflection.Register(grpcS)
|
|
|
|
grpcS.Serve(grpcL)
|
|
|
|
|
|
|
|
return true
|
|
|
|
|
|
|
|
}
|