
Linux文件句柄数限制进程可打开的文件等资源数量,高并发服务需调大以防“Too many open files”错误;可通过/proc、ulimit、sysctl等命令查看和临时修改,永久配置需设置limits.conf、sysctl.conf及systemd服务LimitNOFILE参数。
Linux文件句柄数(file descriptor limit)限制了进程能同时打开的文件、socket、管道等资源数量。高并发服务(如Web服务器、数据库、消息队列)若不调大该限制,容易出现 Too many open files 错误,导致连接拒绝或服务异常。
快速定位是否已达上限:
ls /proc//fd | wc -l
cat /proc//limits | grep "Max open files"
cat /proc/sys/fs/file-max
ulimit -n(软限制),ulimit -Hn(硬限制)适用于调试或紧急扩容:
ulimit -n 65536(需小于等于硬限制)ulimit -Hn 65536,再设软限制echo 2097152 > /proc/sys/fs/file-max
需多层配置,确保服务启动时加载正确值:
pam_limits.so 已启用(检查 /etc/pam.d/common-session 或对应登录配置)sysctl -p 生效/etc/systemd/system/nginx.service.d/override.conf:systemctl daemon-reload && systemctl restart nginx
修改后务必验证实际生效效果:
/proc//limits
soft limit 可被进程自行降低,hard limit 需 root 权限才能提升docker run 中加 --ulimit nofile=65536:65536,或在 docker-compose.yml 的 ulimits 字段配置