记一次惨痛的Redis上线经历:ERR invalid expire time in setex

我们公司正在进行Redis替换Memcached项目,我们只是对底层的接口进行了修改,自己简单的测了测晚上就上线了,然后就没有然后了............

 

上线之后,两个系统A和B的LEO的日志报警,查看错误日志记录:ERR invalid expire time in setex,我屮艸芔茻,这是什么鬼?上网查资料,没有关于这方面的内容,自己查没有设置过期时间和非法的过期时间的调用点。

 

查了一个小时,发现几个调用点和别的调用点不一样,setex(a, b, 0); 有些人的过期时间竟然写的0,初步怀疑此处搞鬼,自己写脚本测试,果然会报错,代码中有try catch被捕获记日志了,测试环境大家没注意,就出现问题了。

 

自己思考了下,过期时间为0在memcached中是不过期,但是在Redis中认为是非法的,到期时间不能小于0,否则会报ERR invalid expire time in setex。

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值