当前位置: 首页 > news >正文

在线flash相册网站源码浙江网站建设制作

在线flash相册网站源码,浙江网站建设制作,高校两学一做专题网站,如何小企业网站建设applyEntries方法的主要作用是接收待应用的 Raft 日志条目,并按顺序将其应用到系统中;确保条目的索引连续,避免丢失或重复应用条目。 一、函数完整代码 func (s *EtcdServer) applyEntries(ep *etcdProgress, apply *apply) {if len(apply.…

applyEntries方法的主要作用是接收待应用的 Raft 日志条目,并按顺序将其应用到系统中;确保条目的索引连续,避免丢失或重复应用条目。

一、函数完整代码

func (s *EtcdServer) applyEntries(ep *etcdProgress, apply *apply) {if len(apply.entries) == 0 {return}firsti := apply.entries[0].Indexif firsti > ep.appliedi+1 {lg := s.Logger()lg.Panic("unexpected committed entry index",zap.Uint64("current-applied-index", ep.appliedi),zap.Uint64("first-committed-entry-index", firsti),)}var ents []raftpb.Entryif ep.appliedi+1-firsti < uint64(len(apply.entries)) {ents = apply.entries[ep.appliedi+1-firsti:]}if len(ents) == 0 {return}var shouldstop boolif ep.appliedt, ep.appliedi, shouldstop = s.apply(ents, &ep.confState); shouldstop {go s.stopWithDelay(10*100*time.Millisecond, fmt.Errorf("the member has been permanently removed from the cluster"))}
}

二、方法完整解析

1. 检查是否有待应用的条目

if len(apply.entries) == 0 {return
}
  • 功能:检查是否有待应用的条目。
  • 作用:如果 apply.entries 为空,说明没有新条目需要应用,函数直接返回,不做任何处理。

2. 验证条目的索引是否连续

firsti := apply.entries[0].Index
if firsti > ep.appliedi+1 {lg := s.Logger()lg.Panic("unexpected committed entry index",zap.Uint64("current-applied-index", ep.appliedi),zap.Uint64("first-committed-entry-index", firsti),)
}
  • 功能:验证待应用条目的索引是否连续。
  • 作用:如果待应用的第一个条目索引大于当前已应用索引 + 1,表示条目丢失或索引跳跃,触发 panic,并记录错误日志。

3. 选择待应用的条目

var ents []raftpb.Entry
if ep.appliedi+1-firsti < uint64(len(apply.entries)) {ents = apply.entries[ep.appliedi+1-firsti:]
}
  • 功能:选择从当前已应用索引之后需要应用的条目。
  • 作用:确保条目按照顺序应用,避免跳过任何条目。ents 保存了从当前应用位置开始的所有待应用条目。

4. 检查是否有待应用的条目

if len(ents) == 0 {return
}
  • 功能:检查是否有待应用的条目。
  • 作用:如果没有待应用的条目(即所有条目都已经应用),直接返回,不继续执行后续操作。

5. 应用条目并判断是否需要停止该成员

var shouldstop bool
if ep.appliedt, ep.appliedi, shouldstop = s.apply(ents, &ep.confState); shouldstop {go s.stopWithDelay(10*100*time.Millisecond, fmt.Errorf("the member has been permanently removed from the cluster"))
}
  • 功能:调用 apply 方法应用条目,并判断是否需要停止该成员。
  • 作用:将选中的条目应用到系统中,如果发现该成员需要停止(例如,已被永久移除),则通过 stopWithDelay 方法延迟停止该成员的服务。

三、方法总结:

  • 该方法的主要作用是接收待应用的 Raft 日志条目,并按顺序将其应用到系统中。
  • 它会确保条目的索引连续,避免丢失或重复应用条目。
  • 如果发现该成员应该被移除(如它被永久移除或存在某些异常情况),函数会触发停止操作。
    下一步的阅读的主要方法为
    func (s *EtcdServer) apply方法
http://www.hengruixuexiao.com/news/49395.html

相关文章:

  • 郑州七彩网站建设公司 概况网络营销的目的和意义
  • 深圳石岩建网站营销型网站建设托管
  • 做网站要买服务器吗专业拓客公司联系方式
  • 商业类网站的设计与制作国内看不到的中文新闻网站
  • 报名网站辽宁省建设银行企业推广宣传方案
  • 多个网站给一个网站推广百度精准搜索
  • 要怎么推广网站买号链接
  • 网站成功秘诀郑州高端网站建设
  • 外国ps修图网站短链接在线生成官网
  • 做二手网站赚钱不免费发软文的网站
  • 阜沙网站建设事件营销成功案例
  • wordpress 标题字数企业seo关键词优化
  • 做笔记网站临安网站seo
  • 广州站是广州火车站吗关键词林俊杰在线听免费
  • 建设银行的网站为什么这么卡互联网营销师有什么用
  • 北京到广州快递要几天湖南seo服务电话
  • 滑县住房和城乡建设局网站个人如何做网络推广
  • wordpress所有外链本地化济南seo小黑seo
  • 岳阳建设商城网站公司微信营销方案
  • 做网投网站好软文营销是什么
  • 装潢设计师要学什么公众号排名优化软件
  • .net wap网站模板谁有推荐的网址
  • 做网站和做系统有什么区别上海全国关键词排名优化
  • 十佳深圳网站设计站长查询
  • 网站背投广告代码网盘app下载
  • 河南新闻头条最新事件福州seo网站推广优化
  • 宁波建设网证书查询平台官网深圳网站快速排名优化
  • 工作了应该浏览器哪些网站佛山市人民政府门户网站
  • 网站后台栏目根据什么做的网站建设图片
  • 网站开发公司哪家靠谱啥都能看的浏览器