RAFT系统设计(LOG传递)

        设计中存在两个PAGE空间,一个是RAFTID 本身对应的空间,一个是进程间通讯的共享空间,目前没有找到统一的办法来处理,感觉还是需要两个,在KV进程执行慢的情况下,有两级的缓存设计。对应关系是RAFTID – LOGID – FD + SHAREMEM,如果操作进程间的FIFO, 必须任何时刻都是同一任务,不能多个,目前的FIFO设计是一对一无锁设计模式。通过对应关系来保证是同一个任务。也就是说RAFTSVR任务可以操作FIFO, 设计中LOGSVR的任务主要是SOCKET通讯和消息转发(一对多,或多对一)的功能,没有操作数据的权利。如果将FIFO的操作集中到LOGSVR上,会有啥问题呢?RAFTSVR和LOGSVR有控制消息和真实的数据传递,多次拷贝。

        还有一种使用的场景,就是RAFT作为LOG文件服务器的场景,没有索引的功能,只是保存LOG,当缓存服务器使用。这是另一种设计的方式,将INDEX单独作为服务,LOG数据也是单独的服务。INDEX是分布部署,LOG数据也是分布部署。现有的是INDEX和LOG同机,作为一个NODE,然后多NODE分布部署,是不同的思路。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值