mirror of
https://github.com/crawlab-team/crawlab.git
synced 2026-01-22 17:31:03 +01:00
65 lines
1.9 KiB
Go
65 lines
1.9 KiB
Go
package cmd
|
|
|
|
import (
|
|
"crawlab/apps"
|
|
"fmt"
|
|
"github.com/crawlab-team/crawlab-core/entity"
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/viper"
|
|
)
|
|
|
|
var (
|
|
runOnMaster bool
|
|
masterConfigPath string
|
|
masterGrpcAddress string
|
|
masterGrpcAuthKey string
|
|
)
|
|
|
|
func init() {
|
|
rootCmd.AddCommand(masterCmd)
|
|
|
|
masterCmd.PersistentFlags().StringVarP(&masterConfigPath, "config-path", "c", "", "Config path of master node")
|
|
_ = viper.BindPFlag("configPath", masterCmd.PersistentFlags().Lookup("configPath"))
|
|
|
|
masterCmd.PersistentFlags().StringVarP(&masterGrpcAddress, "grpc-address", "g", "", "gRPC address of master node")
|
|
_ = viper.BindPFlag("grpcAddress", masterCmd.PersistentFlags().Lookup("grpcAddress"))
|
|
|
|
masterCmd.PersistentFlags().StringVarP(&masterGrpcAuthKey, "grpc-auth-key", "a", "", "gRPC auth key of master node")
|
|
_ = viper.BindPFlag("grpcAuthKey", masterCmd.PersistentFlags().Lookup("grpcAuthKey"))
|
|
}
|
|
|
|
var masterCmd = &cobra.Command{
|
|
Use: "master",
|
|
Aliases: []string{"M"},
|
|
Short: "Start master",
|
|
Long: `Start a master instance of Crawlab
|
|
which runs api and assign tasks to worker nodes`,
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
// options
|
|
var opts []apps.MasterOption
|
|
if masterConfigPath != "" {
|
|
opts = append(opts, apps.WithMasterConfigPath(masterConfigPath))
|
|
viper.Set("config.path", masterConfigPath)
|
|
}
|
|
opts = append(opts, apps.WithRunOnMaster(runOnMaster))
|
|
if masterGrpcAddress != "" {
|
|
address, err := entity.NewAddressFromString(masterGrpcAddress)
|
|
if err != nil {
|
|
fmt.Println(fmt.Sprintf("invalid grpc-address: %s", masterGrpcAddress))
|
|
}
|
|
opts = append(opts, apps.WithMasterGrpcAddress(address))
|
|
viper.Set("grpc.address", masterGrpcAddress)
|
|
viper.Set("grpc.server.address", masterGrpcAddress)
|
|
}
|
|
if masterGrpcAuthKey != "" {
|
|
viper.Set("grpc.authKey", masterGrpcAuthKey)
|
|
}
|
|
|
|
// app
|
|
master := apps.NewMaster(opts...)
|
|
|
|
// start
|
|
apps.Start(master)
|
|
},
|
|
}
|