一个奇葩的错误
- 公司的主项目是17年开始开发,有一个微服务中,用的python的redis客户端还是2.X的
- 最近公司把所有微服务的py-redis都升级到3.5.x
- 升级之后,整个项目所有功能都运行正常,测试也没有发现有什么问题
- 两天有用户发现有一个服务运行一直失败,查看日志,在运行任务报了一个错误 ERROR Invalid input of type: 'bool'. Convert to a bytes, string, int or float first.
- 因为是一个多层级的函数调用,有多层级的try ,于是一层一层,把try 临时取消,最后才定位到
- redis.set(key, True)
原因和解决办法
1.是python-redis 升级到3.x后,仅接受用户数据为字节、字符串或数字(整数,长整数和浮点数)。
2. 在2.x的时候,可以直接在value中存Python的类型,如字典和数组以及boolean型
3. 解决办法,修改redis.set(key, 1)