天天看点

解决PHP连接Redis报read error on connection错误

背景

项目由于并发很高,所以将之前连接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

参考文章:

https://github.com/phpredis/phpredis/pull/260