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) HasTag(CommandTag) 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: %w", 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 | |
| 
 | |
| }
 |