在 raft 算法中,term 会随着选举次数持续增长,int, float, 这些数据类型都有 Max, 一旦 term 到达该数据的极限,系统会不会挂。 有什麼辦法可以解决这个办法, 因为选举比较频繁,30s 就有一次选举。term 增长的很快。
我目前想到的办法:
- 参与选举的机器 间隔一段时间后集体重启,這個辦法可以讓 term 衝初始值重新開始。
- 在定义 term 数据类型时使用:big.Int 可以延缓到达极限时间
乱想
- 不能重启机器的时候有什么办法吗, 在代码中加入一些新的逻辑,(在每次同步 leader 的信息时候重置为 1,测试不行)但是不知到怎么入手
- 在 raft 算法中还可以使用什么东西可以替代 term 的作用,还没有找到