使用 PHP 检查 memcache 集群中是不是存在密钥

Posted

技术标签:

【中文标题】使用 PHP 检查 memcache 集群中是不是存在密钥【英文标题】:Check if key exists in memcache cluster using PHP使用 PHP 检查 memcache 集群中是否存在密钥 【发布时间】:2011-05-17 18:04:40 【问题描述】:

我正在调试 php 应用程序的缓存层。它使用一组 memcache 服务器来缓存值。我想验证特定对象是否被正确清除。

我的想法是使用 telnet 连接到正确的 memcache 服务器并手动检查密钥是否存在。 我知道传递给Memcache::set 的密钥,但不知道要连接到哪个服务器。我如何知道数据存储在哪个 memcache 服务器上?

【问题讨论】:

【参考方案1】:

我只是参考了文档。 Memcached 客户端对密钥进行哈希处理以确定要查询的服务器。所以,我猜 Memcached 是分片的。您可能必须查看客户端的来源(或者可能是文档)以了解 hashing->sever 是如何完成的。否则,您可以只使用命令行中的客户端来查询该值。

【讨论】:

是的,它是分片的,散列是在PHP扩展中实现的。看来我必须从源中提取哈希算法。【参考方案2】:

供将来参考:我编写了一个小型 Python 脚本,用于检查内存缓存服务器列表中的给定键 https://gist.github.com/721965

【讨论】:

【参考方案3】:

如果它是集群而不是在所有实例中同步数据或有一个集中的数据存储(内部实现 - 对您来说并不重要)。您将获得所有情况下的数据。

【讨论】:

以上是关于使用 PHP 检查 memcache 集群中是不是存在密钥的主要内容,如果未能解决你的问题,请参考以下文章

nginx+PHP+memcached+MySQL+ip-hash做memcached集群

Apache+php+memcache集群搭建

Apache+php+memcache集群搭建

集群三 php+memcached缓存服务器

memcached

php memcached怎么用