|
|
@ -11,12 +11,14 @@ import ( |
|
|
|
var ( |
|
|
|
shellOptions shell.ShellOptions |
|
|
|
shellInitialFiler *string |
|
|
|
shellCluster *string |
|
|
|
) |
|
|
|
|
|
|
|
func init() { |
|
|
|
cmdShell.Run = runShell // break init cycle
|
|
|
|
shellOptions.Masters = cmdShell.Flag.String("master", "localhost:9333", "comma-separated master servers") |
|
|
|
shellInitialFiler = cmdShell.Flag.String("filer", "localhost:8888", "filer host and port") |
|
|
|
shellOptions.Masters = cmdShell.Flag.String("master", "", "comma-separated master servers, e.g. localhost:9333") |
|
|
|
shellInitialFiler = cmdShell.Flag.String("filer", "", "filer host and port, e.g. localhost:8888") |
|
|
|
shellCluster = cmdShell.Flag.String("cluster", "", "cluster defined in shell.toml") |
|
|
|
} |
|
|
|
|
|
|
|
var cmdShell = &Command{ |
|
|
@ -24,6 +26,8 @@ var cmdShell = &Command{ |
|
|
|
Short: "run interactive administrative commands", |
|
|
|
Long: `run interactive administrative commands. |
|
|
|
|
|
|
|
Generate shell.toml via "weed scaffold -config=shell" |
|
|
|
|
|
|
|
`, |
|
|
|
} |
|
|
|
|
|
|
@ -32,6 +36,23 @@ func runShell(command *Command, args []string) bool { |
|
|
|
util.LoadConfiguration("security", false) |
|
|
|
shellOptions.GrpcDialOption = security.LoadClientTLS(util.GetViper(), "grpc.client") |
|
|
|
|
|
|
|
if *shellOptions.Masters == "" && *shellInitialFiler == "" { |
|
|
|
util.LoadConfiguration("shell", false) |
|
|
|
v := util.GetViper() |
|
|
|
cluster := v.GetString("cluster.default") |
|
|
|
if *shellCluster != "" { |
|
|
|
cluster = *shellCluster |
|
|
|
} |
|
|
|
if cluster == "" { |
|
|
|
*shellOptions.Masters, *shellInitialFiler = "localhost:9333", "localhost:8888" |
|
|
|
} else { |
|
|
|
*shellOptions.Masters = v.GetString("cluster." + cluster + ".master") |
|
|
|
*shellInitialFiler = v.GetString("cluster." + cluster + ".filer") |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
fmt.Printf("master: %s filer: %s\n", *shellOptions.Masters, *shellInitialFiler) |
|
|
|
|
|
|
|
var err error |
|
|
|
shellOptions.FilerHost, shellOptions.FilerPort, err = util.ParseHostPort(*shellInitialFiler) |
|
|
|
if err != nil { |
|
|
|