Memcache的分布式应用

早就听说memcached是一个不错的分布式内存缓存系统,做了些功课想把这memcache用到实际当中来.因为一个好的缓存系统,能给web应用带来不小的性能提升.做了一些功课之后,做了下面几点总结:

  • memcache适合与web server安装在同一server上
  • memcache可以在n个端口开n个进程,如果和web server在同一机器的话,还能减少网络开销.
  • 配置简单,启动一个进程就行了,免去了配置文件

我更关心的是,memcache的分布式应用应该如何部署.带着这个问题,我在各搜索引擎上做了进一步的功课.最初找到的办法是,首先启动n个memcache进程,这些进程可以在不同的server的不同端口上.

然后使用perl的api可以方便的一次链接多个memcache,存储读取机制不明.不久找到php的一个MemcachedClient类,基本上就是perl里api的再实现.它使用的fscokopen或者socket系列function来直接读取memcache—-这说明只要清楚memcache的网络协议,你甚至不用装什么php的memcache extenstion.看了这个类的实现,基本上弄清楚,它的分布式应用差不多就是将不同的key保存在不同的memcache daemon,不会保留多个副本,也就不存在多memcache同步的问题了.

过了不久俺又有发现,在最新的php手册上找到了memcache::addServer()这方法,它就是为分布式应用而产生的,有了这个支持的话,php的代码就更简单:

<?php
   $memcache_obj = new Memcache;
   $memcache_obj->addServer('memcache_host', 11211);
   $memcache_obj->addServer('failed_host', 11211);
   
   $stats = $memcache_obj->getExtendedStats();
   print_r($stats);
?> 

看来php手册也要与时俱进啊,最好是能够直接使用英文版,否则也不会走这么多弯路了:)

官方站点

http://www.danga.com/memcached/

9 Replies to “Memcache的分布式应用”

  1. PECL版本的Memcache extension并没有MCache快多少,另外在负载均衡和灾难恢复上都差很多。可惜,Mache站点已经down了。估计作者离职了吧。

  2. 还没有仔细看过MCache,不知道它的性能方面的数据如何.
    另外我的同事在应用memcache之后对它的稳定性很满意,负载均衡方面有待加强,但是目前而言已经是能够接受,毕竟是内存缓存,重启之后就会没有

  3. # memcache适合与web server安装在同一server上
    # memcache可以在n个端口开n个进程,如果和web server在同一机器的话,还能减少网络开销.

    哈哈,兄弟啊,要搞清楚为什么弄缓存,而且要搞清楚为什么要搞分布式?
    如果你所有东西都跑在一台机器上搞定的话,要么说明你的应用压力很小,要么说明你的这台机器很牛。

    那么请问你还搞什么缓存,还搞什么分布式? 那不是脱裤子放P啊?

    另外,在内网,现在的网络速度不一定比硬盘的速度慢多少!

  4. 好吧,我承认这篇2006年的blog可能有些歧义。

    我在当时有n台web server,没有专门的memcache服务器,为了能用上memcache,我在每台web server上都装了memcache,然后采用hash策略去读写缓冲。

Leave a Reply

Your email address will not be published.