RAFT 设计实现(日志文件同步)

数据库LOG进程中设计RAFTSVR模块,专门进行LOG的复制。RAFTSVR中设置一个任务,用于进行与RAFT进程的通讯,包含连接,传递共享内存句柄,传递消息。同时提供进行共享内存写入接口,读取接口。

运行过程如下:LOG 的RAFTSVR模块初始化后,通过SOCKET通讯连接 RAFT进程,成功连接后,传输共享内存句柄。传递当前FILEID + PAGEID给RAFT进程。如此时RAFT进程为LEADER的情况下,LOG进程就是主LOG,有LOGSVR模块输出PAGE内容到共享区,并记录最新发出的FILEID+PAGEID,  LOGSVR模块还保留着最新添加的FILEID+PAGEID, 此二者作为比对下一步动作的触发条件,不一致需要继续,一致则停止。

对于RAFT进程进行需要老的LOG PAGE的情况处理, 有的RAFT NODE数据比较旧,需要同步新的数据,需要获得对应的FILEID+PAGEID的数据,RAFT进程发SOCKET消息给KV进程的RAFTSVR SOCKET TASK, 任务获得消息后,解析成对应的LOGSVR的消息给到LOG任务,LOG任务读文件,将数据写入共享内存中。共享内存数据的写操作是有LOGSVR任务进行的。

另一思路是RAFT进程是否可以直接读LOG文件,只是KV的写文件和RAFT的读文件有读写冲突的情况。但还是需要进行FILEID+PAGEID 的传递,同步触发条件必须进行传递。

当RAFTNODE为FOLLOWER节点的情况,LOG进程就是接收LOG PAGE, 在SOCKET连接后,就已经将当前的FILEID+PAGEID传递给RAFT进程,RAFT进行发新的FILEID+PAGEID给进程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值