Linux怎么修改文件最大打开数_Linux系统ulimit限制与配置修改【教程】

遇到“Too many open files”错误时,需依次调整ulimit软硬限制、用户级limits.conf、systemd服务LimitNOFILE及内核fs.file-max参数。

如果您在Linux系统中运行高并发服务时遇到“Too many open files”错误,则可能是由于系统对单个进程可打开文件数的限制过低。以下是修改文件最大打开数的具体操作步骤:

一、临时修改当前会话的ulimit值

该方法仅对当前Shell会话及其子进程生效,重启终端或注销后失效,适用于快速验证或调试场景。

1、执行命令查看当前软限制和硬限制:
ulimit -Sn && ulimit -Hn

2、将软限制提升至65535(需不超过当前硬限制):
ulimit -Sn 65535

3、若需同时提高硬限制(需具备root权限):
sudo ulimit -Hn 65535

4、验证修改结果:
ulimit -n

二、永久修改用户级限制(针对特定用户)

通过编辑用户shell配置文件,使ulimit设置在每次登录时自动加载,适用于仅需为某个用户(如www-data、deploy)调整限制的场景。

1、使用文本编辑器打开该用户的shell配置文件,例如bash用户编辑 ~/.bashrc:
vim ~/.bashrc

2、在文件末尾添加以下两行:
ulimit -S n 65535
ulimit -H n 65535

3、保存并退出,执行命令使配置立即生效:
source ~/.bashrc

4、新开终端验证是否生效:
ulimit -n

三、永久修改系统级限制(全局生效)

该方式通过修改PAM模块配置与系统limits配置文件,影响所有用户(除root外默认受约束),是生产环境推荐的标准做法。

1、编辑 /etc/security/limits.conf 文件:
sudo vim /etc/security/limits.conf

2、在文件末尾追加以下四行(其中username可替换为具体用户名,或使用*代表所有普通用户):
username soft nofile 65535
username hard nofile 65535
* soft nofile 65535
* hard nofile 65535

3、确保 /etc/pam.d/common-session 或对应登录管理文件包含如下行(Debian/Ubuntu通常已存在):
session required pam_limits.so

4、重启用户会话或重新登录,执行 ulimit -n 验证结果

四、修改systemd服务的文件数限制

对于由systemd托管的服务(如nginx、redis、java应用),其进程不受/etc/security/limits.conf直接影响,必须单独配置service unit参数。

1、查找目标服务的unit文件路径:
systemctl show -p FragmentPath 服务名.service

2、创建覆盖目录并编辑override文件:
sudo systemctl edit 服务名.service

3、在打开的编辑器中输入以下内容:
[Service]
LimitNOFILE=65535

4、保存退出后重载配置并重启服务:
sudo systemctl daemon-reload
sudo systemctl restart 服务名.service

五、内核级全局限制调整(fs.file-max)

该参数定义整个系统允许打开的最大文件句柄总数,由内核维护,独立于单个进程限制,当出现系统级资源耗尽提示时需调整。

1、查看当前内核限制值:
cat /proc/sys/fs/file-max

2、临时修改(重启失效):
sudo sysctl -w fs.file-max=1048576

3、永久生效:编辑 /etc/sysctl.conf,添加一行:
fs.file-max = 1048576

4、加载新配置:
sudo sysctl -p