原文:http://blog.csdn.net/jarfield/article/details/4341819
最后更新时间 2009-04-10 更新人 [email protected]
这里收集了经常被问到的关于memcached的问题
性能方面的问题
Memcached没有我的数据库快,为什么?
在一对一比较中,memcached可能没有您的SQL查询快。但是,这不是memcached的设计目标。Memcached的目标是可伸缩性。当连接和请求增加的时候,memcached的性能将比大多数数据库好。您可以先在高负载的环境(并发的连接和请求)中测试您的代码,然后再决定memcached是否适合您。
客户端库
memcached有哪些客户端库?
看看上面的"如何访问memcached"小节。
使用不同的客户端库,可以访问到memcached中相同的数据吗?
从技术上说,是可以的。但是您可能会遇到下面三个问题:
什么是一致性哈希的客户端?
一致性哈希算法是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的选项
如果您想要学习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作为命名空间: