Magento与RedisLab Redis集群后端

时间:2016-03-17 09:07:39

标签: magento redis redislabs

Magento RedisLab群集集成问题

在部署集群redis数据库之后,FPC和Session工作正常,但是当我们使用Magento Cache部分添加集群redis(RedisLab)实例时,我们遇到了一个问题。

点击添加到购物车>> show无法添加产品

后端错误

  Next exception 'Zend_Cache_Exception' with message 'Error cleaning cache by mode matchingAnyTag: ERR CROSSSLOT Keys in request don't hash to the same slot (command='SUNION', key='zc:ti:da3_QUOTE_2156255')' in /var/www/magento/lib/Zend/Cache.php:209
    Stack trace:
    3
    #6 /var/www/magento/app/code/core/Mage/Core/Model/Abstract.php(464): Mage_Core_Model_Abstract->cleanModelCache()
    #7 /var/www/magento/app/code/core/Mage/Sales/Model/Quote.php(333): Mage_Core_Model_Abstract->_afterSave()
    #8 /var/www/magento/app/code/core/Mage/Core/Model/Abstract.php(319): Mage_Sales_Model_Quote->_afterSave()
    #9 /var/www/magento/app/code/core/Mage/Sales/Model/Quote.php(1966): Mage_Core_Model_Abstract->save()
    #10 /var/www/magento/app/code/core/Mage/Checkout/Model/Cart.php(459): Mage_Sales_Model_Quote->save()
    #11 /var/www/magento/app/code/core/Mage/Checkout/controllers/CartController.php(223): Mage_Checkout_Model_Cart->save()
    #12 /var/www/magento/app/code/core/Mage/Core/Controller/Varien/Action.php(418): Mage_Checkout_CartController->addAction()
    #13 /var/www/magento/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(254): Mage_Core_Controller_Varien_Action->dispatch('add')
    #14 /var/www/magento/app/code/core/Mage/Core/Controller/Varien/Front.php(172): Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
    #15 /var/www/magento/app/code/core/Mage/Core/Model/App.php(365): Mage_Core_Controller_Varien_Front->dispatch()
    #16 /var/www/magento/app/Mage.php(684): Mage_Core_Model_App->run(Array)
    #17 /var/www/magento/index.php(85): Mage::run('', 'store')
    #18 {main}

如果我禁用了异常,那么它的工作文件

/var/www/magento/lib/Zend/Cache.php:209

1 个答案:

答案 0 :(得分:0)

  • 刚刚得到了与您相同的异常,我相信这个案例属于您的自定义工作,试图让magento使用redis-cluster
  • 我的解决方案:
    • 首先删除redis-client.php库中的异常并返回IP:PORT
    • 通过redis-cluster.php
    • 中的byHash函数找到正确的客户端
    • 使用正确的客户端执行命令
  • 需要覆盖load,remove,_removeByMatchingTags ......