背景
项目由于并发很高,所以将之前连接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
参考文章:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。