解决phpredis 'RedisException' with message 'read error on connection'
2016-01-08 22:17
726 查看
最近一个后台常驻job通过redis的brpop阻塞读取消息时,设置的超时时间较长
但是在实际的使用中发现很短时间后就会退出,通过查看error log,发现:'RedisException' with message 'read error on connection' 提示
经过一番折腾,原来发现是php.ini文件中的一个配置项导致:
default_socket_timeout = 60
由于redis扩展也是基于php 的socket方式实现,因此该参数值同样会起作用。
找到了问题就比较好解决了:
1、直接修改php.ini,将其设置为我们想要的值(这个不推荐)
2、在我们的脚本中通过以下方式设置,这样就比较灵活,不对其他脚本产生影响
list($key,$row)=$redis->brPop($queue_name,3600); //超时时间为1小时
但是在实际的使用中发现很短时间后就会退出,通过查看error log,发现:'RedisException' with message 'read error on connection' 提示
经过一番折腾,原来发现是php.ini文件中的一个配置项导致:
default_socket_timeout = 60
由于redis扩展也是基于php 的socket方式实现,因此该参数值同样会起作用。
找到了问题就比较好解决了:
1、直接修改php.ini,将其设置为我们想要的值(这个不推荐)
2、在我们的脚本中通过以下方式设置,这样就比较灵活,不对其他脚本产生影响
ini_set('default_socket_timeout', -1); //不超时
相关文章推荐
- redis 入门笔记(一)
- redis 安装(sentinel 方式)
- CentOS 6.5下Redis安装配置记录
- redis如何利用appendonly.aof恢复数据
- spring redis 整合
- Redis状态和信息查看
- Redis学习记录之配置文件(四)
- redis - 空格引起的bug
- 用Jedis操作redis示例一,Key,value HashMap
- redis+crontab异步处理任务
- 安装php-redis扩展
- Redis配置详解
- redis使用小计
- Ubuntu的Redis安装
- java操作redis。jedis使用api
- Spring boot 手动配置redis
- Redis学习记录之配置文件(三)
- Redis详解
- redis集群报错
- Redis 安装