分布式缓存 – 一致性哈希算法

【golang】分布式缓存 - 一致性哈希算法

前言

  之前也了解到过一致性哈希算法,但是没有用go实现过,刚好最近看GeeCache,动手实现下一致性哈希算法

正文:

  我们先来想下一致性哈希算法的数据结构含有哪些内容:

  1.map 用来存储虚拟节点对应的真实节点,是一个映射表

  2.hash 哈希函数

  3.key 哈希环,存储所有虚拟节点

  4.replicas 虚拟节点的倍数

了解过一致性哈希算法的朋友,应该是能够理解为什么要有上面的内容,下面我们用代码实现下:

type Hash func([]byte) uint32
type Map struct {
    hash    Hash  // hash算法
    key     []int // hash环
    replicas int  // 虚拟节点的数量
    m      map[int]string // 虚拟节点和真实节点的映射表
}
hmoban主题是根据ripro二开的主题,极致后台体验,无插件,集成会员系统
自学咖网 » 分布式缓存 – 一致性哈希算法