如果❤️我的文章有帮助,欢迎点赞、关注。这是对我继续技术创作最大的鼓励。[更多系列文章在我博客] https://coderdao.github.io/
Golang 实现一致性哈希负载均衡
哈希负载均衡
个人理解:一致性哈希算法
- 根据每一台服务器不同的 ip:port根据自己的key生成算法,生成一个唯一的 key 值
- key => ip:port把机器唯一的- key映射机器访问地址- ip:port设置到一个- 有序的循环圆上
- 请求过来的时候,根据请求内容生成按 自己的key生成算法也生成一个 请求的key
- 请求的key和有序的循环圆上 机器的key循环对比,第一个 机器的key大于 请求的key就是最优解,由它来处理该请求
- 如果 请求的key比有序的循环圆上 机器的key都大,那么由圆上第一条机器处理
- 有序的循环圆上机器,根据访问情况。近实时增删机器映射
一致性哈希负载均衡 具体编码实现

负载轮询测试代码

测试结果

