redis时钟漂移造成的 key值失效
redis时钟漂移造成的 key值失效
问题现象
问题:最近客户新切了生产环境,结果有些接口不能用了,一直报“xxx失效,校验失败”,排查了一下,代码也没改动,其他环境同样也是好的。
原因
苦思不得其解,问了大佬,才知道,可能是集群内服务器时间不一样,造成redis时钟漂移,导致key值校验时已经过期了。一排查,果真如此。
那么这个redis时钟漂移到底是什么呢?为什么集群内服务器时间不一样,会导致一个设定好过期的key值提前失效呢?
详解redis时钟漂移
关键点:resis设置的过期时间,是当前服务器时间加上设定的expires时间。
场景:服务器A 在2023/6/28 00:00:00设置了 30分钟过期的key1,key1在00:30:00 失效过期,假如服务器B比服务器A快1一个小时,那么B将一直拿不到A设定的key1
解决方案
无非是让集群时间保持一致,以下将围绕这个点进行讨论
方式一:与互联网时间同步
阿里云时钟同步服务器
ntpdate ntp4.aliyun
创建 crontab 任务调度
crontab -e
*/1 * * * * /usr/sbin/ntpdate ntp4.aliyun;
输入date,测试
式二:和内网某台机器同步
参考这里
最新文章
- Report中的Drill down
- http请求digest auth认证
- int型整数的数值范围
- linux启动停止重启MySQL的命令
- 【转】解决shiro的Principal属性动态修改无效问题
- principal java
- 叶片杰伦恋夜语
- 版本控制工具VSS使用介绍
- VSS使用帮助3
- 山东省下载准考证必须用电脑吗
- 香农编码C程序及演示结果
- HashTable 使用
- GAN小结(BEGAN EBGANWGAN CycleGAN conditional GAN DCGAN PGGAN VAEGAN)
- SVM支持向量机算法
- 损失函数——均方误差(Mean Squared Error,MSE)
- CC++
- tomcat守护进程