背景
项目由于并发很高,所以将之前连接redis使用短连接改成了长连接,结果导致出现了抛出了read error on connection
出现原因
php有一个配置项default_socket_timeout表示一个socket连接的超时时间,默认是60s,而phpredis这个扩展的底层连接redis是使用的socket,所以当一个连接在60秒内没有被使用的时候,下次连接就会抛出这个异常。
解决方案
方案1 修改php.ini(不推荐)
在php.ini中设置default_socket_timeout = -1,然后重启php-fpm
方案2 程序中设置
使用ini_set函数
ini_set('default_socket_timeout', -1); // 不超时
方案3 使用redis的option
在连接redis时setOption
$this->redis->setOption(Redis::OPT_READ_TIMEOUT, -1);
注意设置没有超时时间都要设置成-1 而不是0
版权属于:
蓝科迪梦
作品采用:
《
署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)
》许可协议授权
评论