`
jarfield
  • 浏览: 202506 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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

阅读更多

最后更新时间 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是一种高性能、...总的来说,理解和处理Memcached的过期问题对于保证缓存系统的稳定性和性能至关重要。通过深入理解源代码和选择合适的过期策略,可以有效地避免由于时间不一致或过期设置不当引发的问题。

    memcached和redis比较

    此外,Redis还支持对键值设置过期时间的功能,类似于Memcached的做法。 - **Memcached** 的最大存储对象默认为1MB,这主要是由于其内存分配机制所决定的(采用Slab Allocator)。相比之下,Redis的最大存储对象大小...

    hibernate4+spring4+memcached 工程

    【标题】"hibernate4+spring4+memcached 工程"是一个集成项目,它结合了三个关键的开源技术,旨在提供一个高效且可扩展的后端数据管理解决方案。Hibernate 4是Java领域中最流行的ORM(对象关系映射)框架,它允许...

    Memcached安装和配置

    本文将详细介绍如何在Windows环境下安装和配置Memcached,并探讨其基本操作和状态查询。 首先,安装Memcached的步骤如下: 1. 访问 http://code.jellycan.com/memcached/ 下载适用于Windows的最新版本(例如1.2.6...

    memcached源代码分析

    4. **LRU(Least Recently Used)策略**:当内存空间不足时,memcached会使用LRU策略淘汰最近最少使用的item,以腾出空间给新的请求。 5. **线程模型**:memcached采用单线程模型,通过非阻塞I/O和事件驱动模型来...

    memcached安装包以及MemCachedClient

    在 Memcached 项目中,它可能包含安装步骤、配置选项、命令行参数、常见问题解答等内容。 总结,Memcached 是一个高效的分布式缓存系统,结合 libevent 可进一步提升性能。在Java环境中,可以使用 Spymemcached ...

    Memcached 原理和使用详解

    1. **如何解决数据一致性问题**:由于Memcached的无状态性和内存存储特性,它并不保证强一致性。通常,应用层需要处理可能出现的数据不一致情况。 2. **如何处理内存不足**:当内存满时,Memcached会使用LRU策略删除...

    memcached官方jar和一些网上的资料

    描述中的“一些网上的资料”可能包括Memcached的官方文档、教程、社区论坛以及相关的技术博客等,这些都是学习和解决问题的好去处。例如: - 官方文档:https://memcached.org/ - Stack Overflow:...

    memcached 64位 window

    解压后,用户通常需要按照安装指南进行编译和安装,设置配置文件,并通过命令行工具启动和管理Memcached服务。 **集成和使用** 在Windows上部署Memcached,需要关注以下关键点: 1. **安装**:解压文件并根据官方...

    安装Memcached及Memcached配置

    - 在实际应用中,你可以根据需求调整Memcached的配置,例如调整内存分配、设置过期时间、优化缓存策略等,以最大化性能和资源利用率。 - 与其他系统集成,例如PHP、Python、Java等,可以使用相应的客户端库进行...

    windows memcached

    这个文件通常会命名为`memcached`,就像你的压缩包文件名一样。 接下来,我们需要安装和启动Memcached服务。打开命令提示符(CMD),并将当前目录切换到`memcached`文件夹。你可以使用`cd`命令来实现这一点,例如:...

    memcached全面剖析.pdf

    Lazy Expiration意味着memcached在内部记录每个数据项的过期时间,但不会主动去检查和删除过期的数据项,只有在访问过期的数据项时才会被删除。LRU则是一种典型的缓存淘汰算法,用于判断哪些数据应该被从缓存中删除...

    java使用memcached demo

    4. **连接Memcached服务器** 初始化Memcached客户端,配置服务器地址和端口。例如: ```java MemcachedClient client = new MemcachedClient(new BinaryConnectionFactory(), AddrUtil.getAddresses("127.0.0.1:...

    MemCacheD Manager

    MemCacheD Manager的功能主要包括以下几个方面: 1. **安装与配置**:MemCacheD Manager提供了便捷的安装和配置流程,帮助用户快速设置和启动MemCacheD服务。这包括设置端口、内存大小、缓存策略等关键参数,以...

    Memcached.class.php

    本文件是一个memcache操作类,附带命名空间,请使用php5.4或以上版本运行。

    Laravel开发-laravel-memcached-plus

    这个扩展针对Laravel5的内置Memcached缓存驱动进行了增强,为开发者提供了更全面的功能,包括持久连接、SASL认证以及自定义Memcached选项。 **一、Laravel与Memcached** Laravel是一款优雅的PHP Web应用框架,它...

    Memcached服务器(windows版本和Windows server版本)

    - **LRU(Least Recently Used)**: 当内存空间不足时,Memcached会采用LRU策略,优先淘汰最近最少使用的数据。 ### 5. 安全性与性能优化 - **安全性**: 默认情况下,Memcached不提供任何安全机制,所有数据都是...

    Memcached原理和使用详解

    文件详细描述了Memcached相关原理和使用方法,内容包括:Memcached原理介绍、Memcached安装和使用说明、Memcached使用的技巧等。

Global site tag (gtag.js) - Google Analytics