[HTTP] http: Accept error: accept tcp [::]:7373: accept4: too many open file
出现这个问题是因为服务的文件句柄超出系统限制。当Go服务程序出现这个问题,首先应该看系统设置,然后再看程序本身。
首先查看系统: ulimit -n
默认是 1024 ,要改大一些: ulimit -n 524288
这是临时的修改,要永久的修改,可修改文件 /etc/security/limits.conf 参见
如果不注意,代码里可能存在一些连接泄漏。常见的泄漏是在 http.Response 调用之后忘记调用 resp.Body.Close(),或者是放置位置不对。
空闲连接可能是另一个可能的原因。 默认情况下,会使用缓存来重用连接。访问许多主机时,这可能会留下许多打开的连接。 可以使用 Transport 的 CloseIdleConnections 方法以及MaxIdleConnsPerHost 和 DisableKeepAlives 字段来管理此行为。
如果是这种情况,可以尝试在传输句柄上显式调用 CloseIdleConnections 或减小MaxIdleConnsPerHost 的值。
还应该在 http server/client 添加超时机制来避免连接泄漏
下面的命令可以让你判断是不是连接池中的连接有没有正确关闭:
cat /proc/19213/net/sockstat
sockets: used 109
TCP: inuse 4 orphan 0 tw 14 alloc 9 mem 2
UDP: inuse 5 mem 16
UDPLITE: inuse 0
RAW: inuse 0
FRAG: inuse 0 memory 0
如果 TCP inuse 很大,就很有可能是连接没有正确关闭。