فهرست منبع

Merge pull request #4779 from xiang90/cq

etcdserver: leader should stepdown when lose quorum for v3
Xiang Li 9 سال پیش
والد
کامیت
a2569c77de
1فایلهای تغییر یافته به همراه10 افزوده شده و 0 حذف شده
  1. 10 0
      etcdserver/raft.go

+ 10 - 0
etcdserver/raft.go

@@ -313,6 +313,11 @@ func startNode(cfg *ServerConfig, cl *cluster, ids []types.ID) (id types.ID, n r
 		MaxSizePerMsg:   maxSizePerMsg,
 		MaxInflightMsgs: maxInflightMsgs,
 	}
+
+	if cfg.V3demo {
+		c.CheckQuorum = true
+	}
+
 	n = raft.StartNode(c, peers)
 	raftStatusMu.Lock()
 	raftStatus = n.Status
@@ -345,6 +350,11 @@ func restartNode(cfg *ServerConfig, snapshot *raftpb.Snapshot) (types.ID, *clust
 		MaxSizePerMsg:   maxSizePerMsg,
 		MaxInflightMsgs: maxInflightMsgs,
 	}
+
+	if cfg.V3demo {
+		c.CheckQuorum = true
+	}
+
 	n := raft.RestartNode(c)
 	raftStatusMu.Lock()
 	raftStatus = n.Status