一次memcached的排查

昨天收到测试组的同事报告无法修改某个业务的信息,等我看了看了看现象,发现原来数据库是修改成功的,但是缓存无法删除。我很奇怪,这套代码是线上的代码部署在测试环境的,怎么会出现问题的,问题定位在memcache的分布式上,这个业务的由两个缓存做分布式缓存,来保存缓存数据。而且这个系统比较奇特,系统由两个两个系统完成,对于memcached的使用分别使用xmemcache和memcacheClient。一开始以为是ip地址和权重配置错误,经过仔细的分析,发现没有错误,xmemcache和memcacheClient是通过特定的配置是可以兼容的。后来研究代码发现了问题:




xmemcache在发现memcache的端口是默认的时候,在计算一致性哈希的时候不会把端口计算入key。二memcacheClient会将端口计算。这样计算出来的哈希环 就出错了。

猜你喜欢

转载自blog.csdn.net/liuxuejin/article/details/49805513