`
spartan1
  • 浏览: 367566 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

libmemcached的一致性hash算法

 
阅读更多

memcached的客户端用了一致性hash来定位每个服务器所在位置。

以libmemcached库为例,在memcached_server_by_key函数中,首先根据hashkit中指定的哈希算法从key中计算出一个哈希值来,然后根据如下算法,从所有的节点中找到一个离自己最近的节点:

如果哈希值在最后一个节点上,或在最后一个节点和倒数第二个节点之间的话,则返回第一个节点

否则返回哈希值后面里自己最近的一个节点。

代码:

      while (left < right)
      {
        middle= left + (right - left) / 2;
        if (middle->value < hash)
          left= middle + 1;
        else
          right= middle;
      }
      if (right == end)
        right= begin;
      return right->index;

 这个算法很奇怪,没有看懂,明天继续分析

分享到:
评论

相关推荐

    C/C++ 一致性hash算法

    一致性哈希算法是一种分布式哈希(Distributed Hash Table, DHT)技术,它在处理大量数据分布到多个节点上时,能保持较好的均衡性和可扩展性。在C/C++编程中,一致性哈希通常用于构建分布式系统,如负载均衡、缓存...

    libmemcached

    - **一致性哈希(Consistent Hashing)**: 通过一致性哈希算法,`libmemcached`可以在添加或删除服务器时最小化数据重新分布的影响。 - **缓存失效策略**: 提供了TTL(Time To Live)和LRU(Least Recently Used)等...

    php模块memcache和memcached区别分析

    - 对于memcache,可以在php.ini配置文件中设置`Memcache.hash_strategy`为`consistent`,以及`memcache.hash_function`为`crc32`,来启用一致性哈希。 - 对于memcached,可以通过`setOption()`方法设置`Memcached:...

    Memcached 内存分析、调优、集群

    Memcached分布式:一致性Hash 在分布式环境中,为了实现数据的高效分发,Memcached使用了一致性哈希算法。一致性哈希能够确保即使在网络中添加或删除节点时,数据迁移也尽可能少。 #### 5. Key-Value系统的比较 ...

    Memcached内存分析、调优、集群

    Memcached分布式:一致性Hash 在分布式环境中,Memcached通常使用一致性哈希算法来解决节点间的数据分布问题。一致性哈希通过虚拟节点和哈希环的概念,实现了数据的均匀分布和高效的负载均衡,同时减少了节点加入...

    php的memcached客户端memcached

    第二种是使用一致性哈希算法,这种算法能较好地解决节点增减时的数据迁移问题,但实现起来相对复杂。在PHP的`Memcached`类中,可以通过设置`Memcached::OPT_HASH`选项来尝试使用一致性哈希。 总的来说,PHP的...

Global site tag (gtag.js) - Google Analytics