开发者社区> 问答> 正文

redis的php客户端为什么连接数这么大

我在网站中使用了redis作为缓存系统,并且用了它的pecl客户端(就是这个 https://github.com/nicolasff/phpredis)。使用没什么问题,但是最近再看链接数的时候发现了个问题,就是后台链接数特别高
screenshot上图可以看到netstat -na | grep 6379后的端口占用情况,其实还有几个屏幕,我就不贴了。我想问的是,这是客户端的bug还是它本身就是这样?如果它本身就是这样,那这样占用下去会不会出什么问题,还是它自己有个上限的?因为我没有看到它的配置或者初始化参数里有连接池之类的设置,所以可以肯定这应该不是连接池的hold状态。

我看到它的连接方法有connect和pconnect,我目前用的是connect,因为参照对mysql_pconnect的理解,现在请求数不是很大,也就没有必要用connect,而且它也应该在脚本结束后释放连接。现在的情况是,这些连接似乎只会在redis的server端在超时时间30秒后被自动断掉。

我担心如果以后请求数大了,30秒内就会被撑暴了。

展开
收起
a123456678 2016-06-29 09:51:36 2544 0
1 条回答
写回答
取消 提交回答
  • 我也使用的是这个插件,经过我的测试,这绝对是此redis客户端一个坑爹的设计!因为它居然要自己去关闭连接,关闭连接对php的开发者是一个几乎要遗忘的操作。

    因为一般扩展的开发者,都会在脚本结束时自己关闭已经使用的连接,但是这个插件居然没有,而是需要你自己去关闭。当然关闭连接对只对connect函数有效,pconnect是不需要关闭连接的。其具体使用方法就是在脚本结束前调用redis对象的close方法,来关闭连接。或者更省事点,用类似下面的代码

    register_shutdown_function(function () {
        global $redis;
        $redis->close();
    });

    经过测试,自己关闭连接后,用netstat -na看6379端口的连接就很少了。

    2019-07-17 19:48:45
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
阿里云栖开发者沙龙PHP技术专场-深入浅出网络编程与swoole内核-吴镇宇 立即下载
PHP安全开发:从白帽角度做安全 立即下载
PHP 2017.北京 全球开发者大会——高可用的PHP 立即下载