前言

linux系统对文件句柄数量是有限制的。一般是系统限制、用户限制和程序限制。

/proc/sys/fs/file-max

这个文件保存着当前系统的文件句柄的个数。这个是系统级别的限制,针对的是整个系统,并不是针对用户。

这个参数可以通过sysctl.conf进行配置:

fs.file-max = 1601172

/etc/security/limits.conf

限制一个用户的所有shell能打开的最大数。

* soft nofile 65535

* hard nofile 65535

修改以后,需要重新登录终端才能生效。

ulimit  -n

控制进程级别能够打开的文件句柄的数量。提供对shell及其启动的进程的可用文件句柄的控制。这是进程级别的。

查看已经启动程序的文件句柄限制

cat /proc/[pid]/limits 
Limit                     Soft Limit           Hard Limit           Units     
Max cpu time              unlimited            unlimited            seconds   
Max file size             unlimited            unlimited            bytes     
Max data size             unlimited            unlimited            bytes     
Max stack size            8388608              unlimited            bytes     
Max core file size        unlimited            unlimited            bytes     
Max resident set          unlimited            unlimited            bytes     
Max processes             62717                62717                processes 
Max open files            1048576              1048576              files     
Max locked memory         16777216             16777216             bytes     
Max address space         unlimited            unlimited            bytes     
Max file locks            unlimited            unlimited            locks     
Max pending signals       62717                62717                signals   
Max msgqueue size         819200               819200               bytes     
Max nice priority         0                    0                    
Max realtime priority     0                    0                    
Max realtime timeout      unlimited            unlimited            us        

supervisor控制的程序

CentOS上使用系统自带的supervisor,使用systemd启动supervisord的服务。被supervisor管理的程序,继承的是systemd对应的限制,如果需要修改的话,就需要在启动.service文件里面修改对应的限制

vim  /usr/lib/systemd/system/supervisord.service
[Unit]

Description=Process Monitoring and Control Daemon

After=network.target

[Service]

Type=forking

LimitNOFILE=40960

LimitNPROC=40960

ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf

ExecReload=/usr/bin/supervisorctl reload

ExecStop=/usr/bin/supervisorctl shutdown

[Install]

WantedBy=multi-user.target

总结

现在很多的golang程序也是直接使用systemd管理服务,所以也会涉及到文件句柄的限制,也是同样的解决方法。