背景
项目由于并发很高,所以将之前连接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
无论从事什么行业,只要做好两件事就够了,一个是你的专业、一个是你的人品,专业决定了你的存在,人品决定了你的人脉,剩下的就是坚持,用善良專業和真诚赢取更多的信任。