我们公司正在进行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。