2016-06-03 09:09:14 +08:00
|
|
|
package command
|
2012-08-24 11:56:09 +08:00
|
|
|
|
|
|
|
import (
|
2019-10-25 22:44:37 +08:00
|
|
|
"fmt"
|
|
|
|
|
2019-03-17 04:43:16 +08:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/security"
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/shell"
|
2019-06-05 16:30:24 +08:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/util"
|
2019-03-17 04:43:16 +08:00
|
|
|
)
|
2014-10-27 02:34:55 +08:00
|
|
|
|
2019-03-17 04:43:16 +08:00
|
|
|
var (
|
2020-04-09 14:57:15 +08:00
|
|
|
shellOptions shell.ShellOptions
|
|
|
|
shellInitialFiler *string
|
2020-12-29 07:07:16 +08:00
|
|
|
shellCluster *string
|
2012-08-24 11:56:09 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2013-01-17 16:56:56 +08:00
|
|
|
cmdShell.Run = runShell // break init cycle
|
2020-12-29 07:07:16 +08:00
|
|
|
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")
|
2012-08-24 11:56:09 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
var cmdShell = &Command{
|
2013-01-17 16:56:56 +08:00
|
|
|
UsageLine: "shell",
|
2019-03-17 04:43:16 +08:00
|
|
|
Short: "run interactive administrative commands",
|
|
|
|
Long: `run interactive administrative commands.
|
2012-08-24 11:56:09 +08:00
|
|
|
|
2020-12-29 07:07:16 +08:00
|
|
|
Generate shell.toml via "weed scaffold -config=shell"
|
|
|
|
|
2012-08-24 11:56:09 +08:00
|
|
|
`,
|
|
|
|
}
|
|
|
|
|
|
|
|
func runShell(command *Command, args []string) bool {
|
2019-03-17 04:43:16 +08:00
|
|
|
|
2019-06-05 16:30:24 +08:00
|
|
|
util.LoadConfiguration("security", false)
|
2020-01-30 01:09:55 +08:00
|
|
|
shellOptions.GrpcDialOption = security.LoadClientTLS(util.GetViper(), "grpc.client")
|
2019-03-17 04:43:16 +08:00
|
|
|
|
2020-12-29 07:07:16 +08:00
|
|
|
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)
|
|
|
|
|
2020-04-09 14:57:15 +08:00
|
|
|
var err error
|
|
|
|
shellOptions.FilerHost, shellOptions.FilerPort, err = util.ParseHostPort(*shellInitialFiler)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Printf("failed to parse filer %s: %v\n", *shellInitialFiler, err)
|
2019-10-25 22:44:37 +08:00
|
|
|
return false
|
|
|
|
}
|
2020-04-09 14:57:15 +08:00
|
|
|
shellOptions.Directory = "/"
|
2019-10-25 22:44:37 +08:00
|
|
|
|
2019-03-17 04:43:16 +08:00
|
|
|
shell.RunShell(shellOptions)
|
|
|
|
|
|
|
|
return true
|
|
|
|
|
2019-10-25 22:44:37 +08:00
|
|
|
}
|