码迷,mamicode.com
首页 > 系统相关 > 详细

注意区分Memcached与Memcache差别

时间:2018-03-30 10:50:21      阅读:237      评论:0      收藏:0      [点我收藏+]

标签:Memcached与Memcache差   DISTRIBUTION_CONSIS   Memcached一致性hash算法分   consistent   

  • 由于项目需要这里还是区分下Memcached与Memcache差别,谨防再步入坑中
  • 目前大多数php环境里使用的都是不带d的memcache版本,这个版本出的比较早,是一个原生版本,完全在php框架内开发的。与之对应的带d的memcached是建立在libmemcached的基础上,所以相对来说,memcached版本的功能更全一些。
    memcache:http://www.php.net/memcache
    memcached:http://php.net/memcached
    2 . Memcache是原生实现的,支持OO和非OO两套接口并存。而memcached是使用libmemcached,只支持OO接口。
  • memcached还有个非常称赞的地方,就是flag不是在操作的时候设置了,而是有了一个统一的setOption()。Memcached实现了更多的memcached协议。
  • memcached支持Binary Protocol,而memcache不支持。这意味着memcached会有更高的性能。不过memcached目前还不支持长连接。
  • 00

    另外一点也是大家比较关心的,就是所使用的算法。大家都知道“一致性hash算法”是当添加或删除存储节点时,对存储在memcached上的数据影响较小的一种算法。那么在php的两个扩展库中,都可以使用该算法,只是设置方法有所不同。


    Memcache 
    修改php.ini添加: 
    [Memcache] 
    Memcache.allow_failover = 1 
    …… 
    …… 
    Memcache.hash_strategy =consistent 
    Memcache.hash_function =crc32 
    …… 
    …… 
    或在php中使用ini_set方法: 
    Ini_set(‘memcache.hash_strategy‘,‘standard‘); 
    Ini_set(‘memcache.hash_function‘,‘crc32‘); 
    
    Memcached 
    $mem = new memcached(); 
    $mem->setOption(Memcached::OPT_DISTRIBUTION,Memcached::DISTRIBUTION_CONSISTENT); 
    $mem->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE,true);

    注意区分Memcached与Memcache差别

    标签:Memcached与Memcache差   DISTRIBUTION_CONSIS   Memcached一致性hash算法分   consistent   

    原文地址:http://blog.51cto.com/laok8/2092769

    (0)
    (0)
       
    举报
    评论 一句话评论(0
    登录后才能评论!
    © 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
    迷上了代码!