** GBase客户端连接提示local cooriditor is busy的问题**
原因是由于客户端频繁的连数据库服务器,且由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,以至于用光了可用的端口号,通过netstat,的确看到很多TIME_WAIT状态的连接。client端频繁建立连接,而端口释放较慢,导致建立新连接时无可用端口。
解决办法:
执行命令修改如下内核参数 (需要root权限)
- 调低端口释放后的等待时间,默认为60s,修改为15~30s:
sysctl -w net.ipv4.tcp_fin_timeout=30 - 修改tcp/ip协议配置, 通过配置/proc/sys/net/ipv4/tcp_tw_resue, 默认为0,修改为1,释放TIME_WAIT端口给新连接使用:
sysctl -w net.ipv4.tcp_timestamps=1 - 修改tcp/ip协议配置,快速回收socket资源,默认为0,修改为1:
sysctl -w net.ipv4.tcp_tw_recycle=1 - 允许端口重用:
sysctl -w net.ipv4.tcp_tw_reuse = 1
手动设置上述四个参数后,观察netstat, TIME_WAIT状态连接逐渐减少,该问题再未发生。
建议在客户端的/etc/sysctl.conf中增加上述四个参数。