diff options
| author | chrislu <chris.lu@gmail.com> | 2022-03-26 10:21:26 -0700 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2022-03-26 10:21:26 -0700 |
| commit | a3411dd9da8361a1d2e49e935e94a2ce2ad78a51 (patch) | |
| tree | 3713819834e1e3d7e7b4ba374bde8f0541fa890f /weed/server/raft_server.go | |
| parent | 1b27f966698d18f270c10d6460d3b3c89ceb1f08 (diff) | |
| download | seaweedfs-a3411dd9da8361a1d2e49e935e94a2ce2ad78a51.tar.xz seaweedfs-a3411dd9da8361a1d2e49e935e94a2ce2ad78a51.zip | |
refactor
Diffstat (limited to 'weed/server/raft_server.go')
| -rw-r--r-- | weed/server/raft_server.go | 33 |
1 files changed, 10 insertions, 23 deletions
diff --git a/weed/server/raft_server.go b/weed/server/raft_server.go index f22b7c45d..09141ab0d 100644 --- a/weed/server/raft_server.go +++ b/weed/server/raft_server.go @@ -5,8 +5,6 @@ import ( "math/rand" "os" "path" - "sort" - "strings" "time" "google.golang.org/grpc" @@ -31,7 +29,7 @@ type RaftServerOption struct { } type RaftServer struct { - peers []pb.ServerAddress // initial peers to join with + peers map[string]pb.ServerAddress // initial peers to join with raftServer raft.Server dataDir string serverAddr pb.ServerAddress @@ -64,8 +62,12 @@ func (s StateMachine) Recovery(data []byte) error { } func NewRaftServer(option *RaftServerOption) (*RaftServer, error) { + peers := make(map[string]pb.ServerAddress) + for _, peer := range option.Peers { + peers[peer.String()] = peer + } s := &RaftServer{ - peers: option.Peers, + peers: peers, serverAddr: option.ServerAddr, dataDir: option.DataDir, topo: option.Topo, @@ -108,8 +110,8 @@ func NewRaftServer(option *RaftServerOption) (*RaftServer, error) { return nil, err } - for _, peer := range s.peers { - if err := s.raftServer.AddPeer(string(peer), peer.ToGrpcAddress()); err != nil { + for name, peer := range s.peers { + if err := s.raftServer.AddPeer(name, peer.ToGrpcAddress()); err != nil { return nil, err } } @@ -118,8 +120,8 @@ func NewRaftServer(option *RaftServerOption) (*RaftServer, error) { for existsPeerName := range s.raftServer.Peers() { exists := false var existingPeer pb.ServerAddress - for _, peer := range s.peers { - if peer.String() == existsPeerName { + for name, peer := range s.peers { + if name == existsPeerName { exists, existingPeer = true, peer break } @@ -136,11 +138,6 @@ func NewRaftServer(option *RaftServerOption) (*RaftServer, error) { s.GrpcServer = raft.NewGrpcServer(s.raftServer) - if s.raftServer.IsLogEmpty() && isTheFirstOne(option.ServerAddr, s.peers) { - // Initialize the server by joining itself. - // s.DoJoinCommand() - } - glog.V(0).Infof("current cluster leader: %v", s.raftServer.Leader()) return s, nil @@ -156,16 +153,6 @@ func (s *RaftServer) Peers() (members []string) { return } -func isTheFirstOne(self pb.ServerAddress, peers []pb.ServerAddress) bool { - sort.Slice(peers, func(i, j int) bool { - return strings.Compare(string(peers[i]), string(peers[j])) < 0 - }) - if len(peers) <= 0 { - return true - } - return self == peers[0] -} - func (s *RaftServer) DoJoinCommand() { glog.V(0).Infoln("Initializing new cluster") |
