分享

redis主从不同步问题处理

 WindySky 2018-02-26

近期遇到的问题如下:

1 在主上setex的key即使过期后在从上也始终get的到。

重现:

主: setex abc 20 test

从:

get abc >> test

ttl abc >> 18

...

ttl abc >> -1

get abc >> test (这里竟然还有~!)

主:get  abc >> nil

从:get abc >> nil

所以如果只在从上获取一个key,需要根据get+ttl来判断一个key是否已经过期。

因redis会出现主从不同步问题,故先判断ttl,若ttl>0,直接取redis;若是ttl<=0,则再根据业务处理。

查了下,也有人吐槽这个问题:http://code.google.com/p/redis/issues/detail?id=519

2 在从上进行读写操作,过期时间不生效

重现:

redis 127.0.0.1:6379> get abctest 
(nil) 
redis 127.0.0.1:6379> setex abctest 20 test 
OK 
redis 127.0.0.1:6379> get abctest 
"test" 
redis 127.0.0.1:6379> ttl abctest 
(integer) 10 
redis 127.0.0.1:6379> ttl abctest 
(integer) -1 
redis 127.0.0.1:6379> get abctest 
"test"  (这里竟然还取得出来。。)

分析

这个现象就是像说从从来不负责删除key,删除key只是主负责的。而由于redis自身删除key的机制是

1 随机选取一定比例的过期key

2 get触发过期删除。

所以导致在master上设置了过期的key如果不在master上触发上面两个条件,在从中就永远会被取到。。。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多