Part 04:Raft论文翻译-《CONSENSUS: BRIDGING THEORY AND PRACTICE》(基础Raft-算法基础)

Part 04:Raft论文翻译-《CONSENSUS: BRIDGING THEORY AND PRACTICE》(基础Raft-算法基础)

3.3 Raft Basic(Raft算法基础)

Raft集群包含若干个服务器,5是一个典型的数字,它允许系统有2个服务器出现故障。在任何给定的时间里,每个服务器都处于三种状态中的一种:Leader、Follower或Candidate。在正常情况下,只有一个Leader,所有其他服务器都是Follower。Follower是被动的:他们自己不发出任何请求,而只是回应来自Leader和Candidate的请求。Leader处理所有客户端请求(如果客户联系Follower,Follower将其重定向到Leader)。第三个状态,Candidate,用于选举如第3.4节所述的新Leader。图3.3显示了状态及其转换;下面将讨论这些转换。

image.png

Raft算法中将时间分为任意长度,如图3.4所示。term用连续的整数进行编号。每个term都以一次选举开始,其中一个或多个Candidate试图成为Leader。如果一个Candidate赢得了选举,那么它将在剩余的term内担任Leader。在某些情况下,选举将导致分裂的投票。这种情况下,term结束时没有Leader;新term(新选举)将很快开始。Raft算法确保在给定期限内最多有一个Leader。

image.png

不同的服务器可能会在不同的时间观察到term之间的转换,在某些情况下,服务器可能不会观察到一个选举,甚至是整个term内都没有观察到。term作为Raft中的逻辑时钟(用于确定顺序的一种方法),它们允许服务器检测过时的信息,如陈旧的Leader。每个服务器存储一个当前的term,它随时间单调地增加。每当服务器通信时,就会交换当前term;如果一个服务器的当前term小于另一个服务器当前的term,则它将其当前term更新为较大的值。如果Leader或Candidate发现其term已过期,它将立即恢复到Follower状态。如果服务器收到一个陈旧term的请求,则它将拒绝该请求。

Raft服务器使用远程过程调用(RPC)进行通信,而基本的共识算法在服务器之间只需要两种类型的RPC。RequestVote RPC由Candidate在选举期间发起(第3.4节),AppendEntries RPC由Leader发起,以复制日志条目并提供一种心跳形式(第3.5节)。Leader转移(第3.10节)和后续章节中描述的机制引入了核心共识算法中这两个机制之外的额外RPC。

我们选择在Raft中通信以RPC调用形式进行,以简化其通信模式。每个请求类型都有一个相应的响应类型,它也作为请求的确认。Raft假设RPC请求和响应可能在网络中丢失;如果RPC没有及时收到响应,请求者有责任重试它。服务器并行发布RPC以获得最佳性能,而Raft并不假设网络保留RPC之间的顺序。

<< 上一章:Raft算法的目的
下一章:Raft算法基础 >>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容