最后更新时间 2009-04-10 更新人 dormando@rydia.net
这里收集了经常被问到的关于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作为命名空间:
分享到:
相关推荐
Memcached是一种高性能、...总的来说,理解和处理Memcached的过期问题对于保证缓存系统的稳定性和性能至关重要。通过深入理解源代码和选择合适的过期策略,可以有效地避免由于时间不一致或过期设置不当引发的问题。
此外,Redis还支持对键值设置过期时间的功能,类似于Memcached的做法。 - **Memcached** 的最大存储对象默认为1MB,这主要是由于其内存分配机制所决定的(采用Slab Allocator)。相比之下,Redis的最大存储对象大小...
【标题】"hibernate4+spring4+memcached 工程"是一个集成项目,它结合了三个关键的开源技术,旨在提供一个高效且可扩展的后端数据管理解决方案。Hibernate 4是Java领域中最流行的ORM(对象关系映射)框架,它允许...
本文将详细介绍如何在Windows环境下安装和配置Memcached,并探讨其基本操作和状态查询。 首先,安装Memcached的步骤如下: 1. 访问 http://code.jellycan.com/memcached/ 下载适用于Windows的最新版本(例如1.2.6...
4. **LRU(Least Recently Used)策略**:当内存空间不足时,memcached会使用LRU策略淘汰最近最少使用的item,以腾出空间给新的请求。 5. **线程模型**:memcached采用单线程模型,通过非阻塞I/O和事件驱动模型来...
在 Memcached 项目中,它可能包含安装步骤、配置选项、命令行参数、常见问题解答等内容。 总结,Memcached 是一个高效的分布式缓存系统,结合 libevent 可进一步提升性能。在Java环境中,可以使用 Spymemcached ...
1. **如何解决数据一致性问题**:由于Memcached的无状态性和内存存储特性,它并不保证强一致性。通常,应用层需要处理可能出现的数据不一致情况。 2. **如何处理内存不足**:当内存满时,Memcached会使用LRU策略删除...
描述中的“一些网上的资料”可能包括Memcached的官方文档、教程、社区论坛以及相关的技术博客等,这些都是学习和解决问题的好去处。例如: - 官方文档:https://memcached.org/ - Stack Overflow:...
解压后,用户通常需要按照安装指南进行编译和安装,设置配置文件,并通过命令行工具启动和管理Memcached服务。 **集成和使用** 在Windows上部署Memcached,需要关注以下关键点: 1. **安装**:解压文件并根据官方...
- 在实际应用中,你可以根据需求调整Memcached的配置,例如调整内存分配、设置过期时间、优化缓存策略等,以最大化性能和资源利用率。 - 与其他系统集成,例如PHP、Python、Java等,可以使用相应的客户端库进行...
这个文件通常会命名为`memcached`,就像你的压缩包文件名一样。 接下来,我们需要安装和启动Memcached服务。打开命令提示符(CMD),并将当前目录切换到`memcached`文件夹。你可以使用`cd`命令来实现这一点,例如:...
Lazy Expiration意味着memcached在内部记录每个数据项的过期时间,但不会主动去检查和删除过期的数据项,只有在访问过期的数据项时才会被删除。LRU则是一种典型的缓存淘汰算法,用于判断哪些数据应该被从缓存中删除...
4. **连接Memcached服务器** 初始化Memcached客户端,配置服务器地址和端口。例如: ```java MemcachedClient client = new MemcachedClient(new BinaryConnectionFactory(), AddrUtil.getAddresses("127.0.0.1:...
MemCacheD Manager的功能主要包括以下几个方面: 1. **安装与配置**:MemCacheD Manager提供了便捷的安装和配置流程,帮助用户快速设置和启动MemCacheD服务。这包括设置端口、内存大小、缓存策略等关键参数,以...
本文件是一个memcache操作类,附带命名空间,请使用php5.4或以上版本运行。
这个扩展针对Laravel5的内置Memcached缓存驱动进行了增强,为开发者提供了更全面的功能,包括持久连接、SASL认证以及自定义Memcached选项。 **一、Laravel与Memcached** Laravel是一款优雅的PHP Web应用框架,它...
- **LRU(Least Recently Used)**: 当内存空间不足时,Memcached会采用LRU策略,优先淘汰最近最少使用的数据。 ### 5. 安全性与性能优化 - **安全性**: 默认情况下,Memcached不提供任何安全机制,所有数据都是...
文件详细描述了Memcached相关原理和使用方法,内容包括:Memcached原理介绍、Memcached安装和使用说明、Memcached使用的技巧等。