最近在使用redis主从的时候做了下面两件事情:1 希望redis主从从操作上分析,所有写操作都在master上写,所有读操作都在从上读。
最近在使用redis主从的时候做了下面两件事情:
1 希望redis主从从操作上分析,所有写操作都在master上写,所有读操作都在从上读。
2 由于redis的从是放在本地的,所以有的key的读写操作就直接放在从上操作了。
但是出现了下面的几个问题:
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是否已经过期
查了下,也有人吐槽这个问题:?id=519
今客CRM客户管理系统主要是为了帮助企业解决在日常工作中遇到的客户管理等难题而开发,通过今客CRM客户管理系统可以对企业事务中的不同功能进行操作,用户通过自定义字段类型可以达到适合不同企业的需求。在今客客户关系管理系统中管理着一个企业最为完整的客户信息,全面的客户信息覆盖在企业的市场营销、销售和服务与技术支持等企业整个前端办公领域的各个环节里。它为企业带来附加价值是不可限量的。今客CRM客户管理系
11
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上触发上面两个条件,在从中就永远会被取到。。。
这真是个很容易踩到的坑啊。。。
推荐阅读:
Ubuntu 12.10下安装Redis(图文详解)+ Jedis连接Redis
Redis系列-安装部署维护篇
CentOS 6.3安装Redis
分场合可以对关系数据库起到很好的补充作用。它提供了Python,Ruby,,Erlang,PHP客户端,使用很方便。
Redis 的详细介绍:请点这里
Redis 的下载地址:请点这里

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号