一次memcached的排查

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




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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值