Memcached FAQ(3) 性能和客户端库方面的问题

原文:http://blog.csdn.net/jarfield/article/details/4341819

最后更新时间 2009-04-10    更新人 [email protected]
这里收集了经常被问到的关于memcached的问题

  • 性能方面的问题
    • memcached没有我的database快,为什么?
  • 客户端库方面的问题
    • memcached有哪些客户端库?
    • 使用不同的客户端库,能够访问到memcached中相同的数据吗? (不同客户端库的可以协作吗?)
    • 什么是一致性哈希的客户端?
  • 客户端FAQ

性能方面的问题 

Memcached没有我的数据库快,为什么? 
在一对一比较中,memcached可能没有您的SQL查询快。但是,这不是memcached的设计目标。Memcached的目标是可伸缩性。当连接和请求增加的时候,memcached的性能将比大多数数据库好。您可以先在高负载的环境(并发的连接和请求)中测试您的代码,然后再决定memcached是否适合您。

客户端库 

memcached有哪些客户端库? 
看看上面的"如何访问memcached"小节。

使用不同的客户端库,可以访问到memcached中相同的数据吗? 
从技术上说,是可以的。但是您可能会遇到下面三个问题:

  • 不同的库采用不同的方式序列化数据。举个例子,perl的Cache::Memcached使用Storable来序列化结构复杂的数据(比如hash references, objects, 等)。其他语言的客户端库很可能不能读取这种格式的数据。如果您要存储复杂的数据并且想被多种客户端库读取,那么您应该以简单的string格式来存储,并且这种格式可以被JSON、XML等外部库解析。
  • 同样,从某个客户端来的数据被压缩了,从另一个客户端来的却没被压缩。
  • 各个客户端库可能使用不同的哈希算法(阶段一哈希)。在连接到多个memcached服务器端的情况下,客户端库根据自身实现的哈希算法把key映射到某台memcached上。正是因为不同的客户端库使用不同的哈希算法,所以被Perl客户端库映射到memcached A的key,可能又会被Python客户端库映射到memcached B,等等。Perl客户端库还允许为每台memcached指定不同的权重(weight),这也是导致这个问题的一个因素。

什么是一致性哈希的客户端?

一致性哈希算法是a new approach to managing the first-layer hashing system for memcached clients。这里有一篇文章很好地解释了它的用处:http://www.last.fm/user/RJ/journal/2007/04/10/392555 。

 

客户端FAQ

目前有一些记录:
客户端可以通过"前缀"来给key设置一个域(命名空间)。例如,在一个共享主机的环境中,您可以将客户姓名作为"前缀",为key创建一个特定的域。在存储数据的时候,"前缀"可以用在key上,但是不应该参与哈希计算。目前,memcached自己还没有实现针对复杂结构数据的序列化方法,JSON则是一种被广泛使用的对象序列化格式。


Memcached FAQ(4) 选项、Item过期和命名空间方面的问题

最后更新时间 2009-04-10    更新人 [email protected]
这里收集了经常被问到的关于memcached的问题

  • memcached的选项
  • Item的过期
    • 过期的item什么时候才会从cached中删除
  • 命名空间
    • 使用key的"前缀"来模拟命名空间
    • 根据命名空间来删除

memcached的选项

如果您想要学习memcached的选项,在命令行下运行"memcached -h"即可。这个命令将会显示一个简单的选项说明。您可以随便试试这些选项,看看他们的功能。

 

另外,memcached发行版中还带有一个memcached(1)的man帮助页。

 

Item的过期

 

过期的item什么时候才会从cached中删除?

memcached采用了一种"懒过期"的策略,这种策略不消耗额外的CPU时间去专门处理过期的item。当一个item被请求(get命令)时,memcached会检查这个item的过期时间;如果已经过期,这个item将不会被返回给客户端。

 

同样,向cache中添加一个item时,如果cache已经满了,memcached首先替换已经过期的条目,然后替换最近未使用的item(the least used item, LRU淘汰算法)。 

 

命名空间

 

memcached不支持命名空间。但是有一些方法可以模拟命名空间。

 

使用key的"前缀"来模拟命名空间

如果您想为不同类型的数据避免key冲突,可以给key添加一个有意义的字符串作为前缀。例如:"user_12345", "article_76890"。

 

根据命名空间来删除

尽管memcached不支持任何类型的通配符删除(wildcard deleting)或根据命名空间删除(deletion by namespace, 因为根本就没有命名空间),这里还是有一些技巧来模拟它们。不过这些技巧需要走点弯路。

 

例如,在PHP中,以foo作为命名空间:

[php]  view plain copy
  1. $ns_key = $memcache->get("foo_namespace_key");  
  2. // if not set, initialize it  
  3. if($ns_key===false) $memcache->set("foo_namespace_key", rand(1, 10000));  
  4. // cleverly use the ns_key  
  5. $my_key = "foo_".$ns_key."_12345";  
  6. $my_val = $memcache->get($my_key);  
  7. //To clear the namespace do:  
  8. $memcache->increment("foo_namespace_key");  



你可能感兴趣的:(算法,数据库,cache,memcached,perl,wildcard)