raft cluster

wip: raft does not care about migrating

wip: optimize code

wip: raft election

wip

wip: fix raft leader missing log entries

wip

fix a dead lock

batch set slot route

wip: raft persist

wip

refactor cluster suite

remove relay

rename relay2

refactor: allow customizing client factory

test raft

refactor re-balance

avoid errors caused by inconsistent status on follower nodes during raft commits

test raft election
This commit is contained in:
finley
2023-01-02 21:27:06 +08:00
parent df672d4c92
commit bf7f628810
54 changed files with 3122 additions and 703 deletions

View File

@@ -6,8 +6,8 @@ import (
)
// FlushDB removes all data in current database
func FlushDB(cluster *Cluster, c redis.Connection, args [][]byte) redis.Reply {
replies := cluster.broadcast(c, args)
func FlushDB(cluster *Cluster, c redis.Connection, cmdLine [][]byte) redis.Reply {
replies := cluster.broadcast(c, modifyCmd(cmdLine, "FlushDB_"))
var errReply protocol.ErrorReply
for _, v := range replies {
if protocol.IsErrorReply(v) {