首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在Magento中找到memcached密钥的来源

如何在Magento中找到memcached密钥的来源
EN

Stack Overflow用户
提问于 2015-06-23 14:48:37
回答 1查看 97关注 0票数 0

我们运行Magento 1.13,其中memcached作为我们的“快速”缓存,而redis用于“慢速”缓存。我们有一个memcached密钥,每秒得到大约70个get请求,但点击量为0%。这只发生在我们的生产站点上,它有多个前端服务器和一个单独的数据库服务器。

似乎这个特定的键从未被设置过,但是我们找不到密钥的来源。键使用md5散列"AA_B1B5D70089938E5C32F61E616FD3908D",因此这无助于缩小它的范围。

我能在哪里找到这把钥匙的来历?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-06-25 13:57:12

我想出了办法。在app/code/core/Mage/Core/Model/App.php中,查找:

代码语言:javascript
复制
public function loadCache($id)
{
    return $this->_cache->load($id);
}

在此函数中,需要添加临时检查:

代码语言:javascript
复制
public function loadCache($id)
{
    if (strstr($id, 'b1b5d70')) {
        $currentUrl = Mage::helper('core/url')->getCurrentUrl();
        $cacheId = $this->_cache->load($id);
        $stack = Varien_Debug::backtrace(true, true);
        Mage::log("Mage_Core_Model_App: " . $id, null, "memcacheKeys.log", true);
        Mage::log($currentUrl, null, "memcacheKeys.log", true);
        Mage::log($cacheId, null, "memcacheKeys.log", true);
        Mage::log($stack, null, "memcacheKeys.log", true);
    }
    return $this->_cache->load($id);
}

我们在这里检查部分memcached密钥,'b1b5d70‘。到目前为止,密钥尚未转换为大写。local.xml中定义的前缀'AA_‘也尚未添加。

保存到日志中的回溯跟踪应该告诉您在何处生成密钥。在我的例子中,它可以追溯到'app/code/core/Mage/Catalog/Block/Product/Price.php'.

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31006092

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档