Welcome 微信登录

首页 / 数据库 / MySQL / Redis主从遇到的两个问题解决

最近在使用redis主从的时候做了下面两件事情:1 希望redis主从从操作上分析,所有写操作都在master上写,所有读操作都在从上读。2 由于redis的从是放在本地的,所以有的key的读写操作就直接放在从上操作了。但是出现了下面的几个问题:1 在主上setex的key即使过期后在从上也始终get的到。重现:主: setex abc 20 test从:get abc >> testttl abc >> 18...ttl abc >> -1get abc >> test (这里竟然还有~!)主:get  abc >> nil从:get abc >> nil所以如果只在从上获取一个key需要根据get+ttl来判断一个key是否已经过期查了下,也有人吐槽这个问题:http://code.google.com/p/redis/issues/detail?id=5192 在从上进行读写操作,过期时间不生效重现: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上触发上面两个条件,在从中就永远会被取到。。。这真是个很容易踩到的坑啊。。。推荐阅读:Ubuntu 12.10下安装Redis(图文详解)+ Jedis连接Redis http://www.linuxidc.com/Linux/2013-06/85816.htmRedis系列-安装部署维护篇 http://www.linuxidc.com/Linux/2012-12/75627.htmCentOS 6.3安装Redis http://www.linuxidc.com/Linux/2012-12/75314.htm分场合可以对关系数据库起到很好的补充作用。它提供了Python,Ruby,Erlang,PHP客户端,使用很方便。Redis 的详细介绍:请点这里
Redis 的下载地址:请点这里Redis应用场景MySQL索引学习笔记相关资讯      Redis  Redis主从 
  • Redis 主从配置实例、注意事项、及  (今 07:34)
  • Redis 非关系型数据库 ( Nosql )  (07月01日)
  • Java中使用Jedis操作Redis  (04月08日)
  • PHP7对Redis的扩展及Redis主从搭建  (今 07:30)
  • 关于 Redis的订阅发布  (04月15日)
  • MongoDB仲裁节点的理解及Memcached  (02月13日)
本文评论 查看全部评论 (0)
表情: 姓名: 字数