You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.3 KiB
59 lines
1.3 KiB
package shell
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"fmt"
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/master_pb"
|
|
"io"
|
|
)
|
|
|
|
func init() {
|
|
Commands = append(Commands, &commandRaftClusterPs{})
|
|
}
|
|
|
|
type commandRaftClusterPs struct {
|
|
}
|
|
|
|
func (c *commandRaftClusterPs) Name() string {
|
|
return "cluster.raft.ps"
|
|
}
|
|
|
|
func (c *commandRaftClusterPs) Help() string {
|
|
return `check current raft cluster status
|
|
|
|
cluster.raft.ps
|
|
`
|
|
}
|
|
|
|
func (c *commandRaftClusterPs) IsResourceHeavy() bool {
|
|
return false
|
|
}
|
|
|
|
func (c *commandRaftClusterPs) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) {
|
|
|
|
raftClusterPsCommand := flag.NewFlagSet(c.Name(), flag.ContinueOnError)
|
|
if err = raftClusterPsCommand.Parse(args); err != nil {
|
|
return nil
|
|
}
|
|
|
|
err = commandEnv.MasterClient.WithClient(false, func(client master_pb.SeaweedClient) error {
|
|
resp, err := client.RaftListClusterServers(context.Background(), &master_pb.RaftListClusterServersRequest{})
|
|
if err != nil {
|
|
return fmt.Errorf("raft list cluster: %v", err)
|
|
}
|
|
fmt.Fprintf(writer, "the raft cluster has %d servers\n", len(resp.ClusterServers))
|
|
for _, server := range resp.ClusterServers {
|
|
suffrage := server.Suffrage
|
|
if server.IsLeader {
|
|
suffrage = "Leader"
|
|
}
|
|
fmt.Fprintf(writer, " * %s %s (%s)\n", server.Id, server.Address, suffrage)
|
|
}
|
|
|
|
return nil
|
|
})
|
|
|
|
return err
|
|
|
|
}
|