5

我实际上是想了解为什么 memcached 不存储给定 ID 的数据。

我正在使用基于 Zend Framework 1.11.1 的 Magento EE 1.11.2.0。用来处理memcached的接口是Zend_Cache_Backend_Memcached

现在这里没有这么大的自定义代码,这是我保存缓存的自定义容器:

public function saveCache($blockContent)
{

    $lifeTime = 86400 * 30 * 6;
    $tags = array(
        My_Module_Model_PageCache_Container_Category_Blabla::CACHE_TAG
    );
    $cacheId = $this->_getCacheId();

    if ($cacheId !== false) {
        $this->_saveCache($blockContent, $cacheId, $tags, $lifeTime);
    }
    return $this;
}

我只是强迫 magento 使用我的自定义cache tag和固定lifetime(memcache 不支持自定义标签,所以我想这不是问题)我lifetime也没有在 memcached 中使用,因为我可以看到使用了默认标签。

一开始我认为这个问题是由一个过长的缓存 ID 引起的,但现在在减少它( <31 char )之后这对我没有帮助:

我可以看到该load()方法Zend_Cache_Backend_Memcached对于我的缓存 ID 总是返回 false。虽然该save()方法返回true,就像它被缓存一样。

这是我的 local.xml 配置:

<cache>
        <slow_backend_store_data>1</slow_backend_store_data>
        <auto_refresh_fast_cache>0</auto_refresh_fast_cache>
        <backend>memcached</backend>
        <slow_backend>database</slow_backend>
        <memcached>
            <servers>
                <!--<server>-->
                <!--<host><![CDATA[127.0.0.1]]></host>-->
                <!--<port><![CDATA[11213]]></port>-->
                <!--<persistent><![CDATA[1]]></persistent>-->
                <!--</server>-->

                <server>
                    <host><![CDATA[unix:///tmp/memcached.sock]]></host>
                    <port><![CDATA[0]]></port>
                    <persistent><![CDATA[0]]></persistent>
                    <weight><![CDATA[2]]></weight>
                    <timeout><![CDATA[5]]></timeout>
                </server>
            </servers>
            <compression><![CDATA[0]]></compression>
            <hashed_directory_level><![CDATA[]]></hashed_directory_level>
            <hashed_directory_umask><![CDATA[]]></hashed_directory_umask>
            <file_name_prefix><![CDATA[]]></file_name_prefix>
        </memcached>
    </cache>
    <full_page_cache>
        <backend>memcached</backend>
        <slow_backend>database</slow_backend>
        <slow_backend_store_data><![CDATA[1]]></slow_backend_store_data>
        <memcached>
            <servers>
                <server>
                    <host><![CDATA[unix:///tmp/memcached.sock]]></host>
                    <port><![CDATA[0]]></port>
                    <persistent><![CDATA[0]]></persistent>
                    <weight><![CDATA[2]]></weight>
                    <timeout><![CDATA[10]]></timeout>
                    <retry_interval><![CDATA[10]]></retry_interval>
                    <status><![CDATA[1]]></status>
                    <stats_update_factor><![CDATA[1]]></stats_update_factor>
                </server>
            </servers>
        </memcached>
    </full_page_cache>

我还尝试检查 memcached 的条目,以查看我的 id 是否已使用此命令存储:

echo 'stats cachedump 35 35' | sudo nc -U /tmp/memcached.sock

  • 关于这个原因的任何想法?
  • 我该如何调试它?(我无法Zend_Cache_Backend_Memcached使用 xdebug)
4

2 回答 2

3

您可以使用 -vv 重新启动 memcached 并查看交互。

顺便说一句,memcache 的默认端口是 11211。仅供参考

于 2013-07-22T01:45:57.193 回答
3

这里的问题是 $lifetime 和 Zend_Cache_Backend_Memcached 中的一个相对错误。

Memcached 的最大生命周期为 30 天(2592000),所以我使用它的限制太大了,这就是为什么没有存储数据的原因。

可悲的是:

  1. Zend_Cache_Backend_Memcached::save() 不检查限制是否正确 < 2592000

  2. memcached 对象上的 set() 方法返回 true,即使它不存储数据 $result = @$this->_memcache->set($id, array($data, time(), $lifetime), $标志,$终身);

于 2013-07-22T07:25:00.087 回答