aboutsummaryrefslogtreecommitdiff
path: root/weed/server/raft_server.go
diff options
context:
space:
mode:
authorChris Lu <chris.lu@gmail.com>2020-10-23 23:06:44 -0700
committerChris Lu <chris.lu@gmail.com>2020-10-23 23:06:44 -0700
commit1b17f71939ddf9b556521639efa706f598429a8e (patch)
tree6dcad4433975030b36a5fef6079434760360d225 /weed/server/raft_server.go
parentef9c32ea0da7baa1b8d8a968c1776714c228c597 (diff)
downloadseaweedfs-1b17f71939ddf9b556521639efa706f598429a8e.tar.xz
seaweedfs-1b17f71939ddf9b556521639efa706f598429a8e.zip
adjust election timeout to 10 seconds
Diffstat (limited to 'weed/server/raft_server.go')
-rw-r--r--weed/server/raft_server.go7
1 files changed, 4 insertions, 3 deletions
diff --git a/weed/server/raft_server.go b/weed/server/raft_server.go
index 073c1ff16..85841e409 100644
--- a/weed/server/raft_server.go
+++ b/weed/server/raft_server.go
@@ -2,6 +2,7 @@ package weed_server
import (
"encoding/json"
+ "math/rand"
"os"
"path"
"sort"
@@ -50,7 +51,7 @@ func (s StateMachine) Recovery(data []byte) error {
return nil
}
-func NewRaftServer(grpcDialOption grpc.DialOption, peers []string, serverAddr, dataDir string, topo *topology.Topology, pulseSeconds int, raftResumeState bool) (*RaftServer, error) {
+func NewRaftServer(grpcDialOption grpc.DialOption, peers []string, serverAddr, dataDir string, topo *topology.Topology, raftResumeState bool) (*RaftServer, error) {
s := &RaftServer{
peers: peers,
serverAddr: serverAddr,
@@ -84,8 +85,8 @@ func NewRaftServer(grpcDialOption grpc.DialOption, peers []string, serverAddr, d
glog.V(0).Infoln(err)
return nil, err
}
- s.raftServer.SetHeartbeatInterval(500 * time.Millisecond)
- s.raftServer.SetElectionTimeout(time.Duration(pulseSeconds) * 500 * time.Millisecond)
+ s.raftServer.SetHeartbeatInterval(time.Duration(300+rand.Intn(150)) * time.Millisecond)
+ s.raftServer.SetElectionTimeout(10 * time.Second)
if err := s.raftServer.LoadSnapshot(); err != nil {
return nil, err
}