首先查看当前文件打开数限制,通过ulimit和cat /proc/sys/fs/file-max命令检查用户级和系统级限制;接着可临时调整用户级限制使用ulimit -n命令,或永久修改/etc/security/limits.conf文件设置软硬限制;然后通过sysctl调整系统级fs.file-max参数以提升全局文件句柄数;对于systemd服务需单独配置LimitNOFILE;最后重新登录并验证各项限制是否生效。

如果您在运行高并发服务或处理大量文件时遇到“Too many open files”错误,可能是系统对单个进程可打开的文件数进行了限制。调整Linux系统的最大文件打开数可以有效避免此类问题。
本文运行环境:Dell PowerEdge R750,Ubuntu 22.04 Server
了解当前系统的软硬限制是调整前的必要步骤,可通过shell命令直接查询用户级和系统级的限制值。
1、执行以下命令查看当前用户的软限制:
ulimit -n
2、查看当前用户的硬限制:
ulimit -Hn
3、查看系统级别的全局最大文件句柄数:
cat /proc/sys/fs/file-max
通过ulimit命令可在当前会话中临时提升限制,适用于测试或短期任务,重启后失效。
1、设置当前会话的软限制为65536:
ulimit -n 65536
2、若需同时修改硬限制,使用:
ulimit -Hn 65536
注意:此方法仅对当前shell及其子进程生效。
编辑PAM模块配置文件/etc/security/limits.conf,可实现用户或用户组的持久化限制设置。
1、使用文本编辑器打开配置文件:
sudo nano /etc/security/limits.conf
2、在文件末尾添加以下内容以针对特定用户设置:
username soft nofile 65536
username hard nofile 65536
3、若要对所有用户生效,可使用通配符:
* soft nofile 65536
* hard nofile 65536
4、保存并退出,重新登录用户使配置生效。
调整内核参数fs.file-max可提升整个系统可分配的文件句柄总数,适用于高负载服务器。
1、临时设置系统级最大值:
sudo sysctl -w fs.file-max=2097152
2、永久生效需写入sysctl配置文件:
echo 'fs.file-max = 2097152' | sudo tee -a /etc/sysctl.conf
3、重新加载sysctl配置:
sudo sysctl -p
对于由systemd管理的服务,其文件数限制可能受unit文件控制,需单独配置。
1、创建或编辑服务的override配置目录:
sudo systemctl edit service-name
2、在打开的编辑器中添加以下内容:
[Service]
LimitNOFILE=65536
3、保存后重新加载服务:
sudo systemctl daemon-reexec
sudo systemctl restart service-name
完成配置后,需通过多种方式确认新限制已正确加载并应用到目标进程。
1、重新登录用户后执行:
ulimit -n
2、检查系统级限制:
cat /proc/sys/fs/file-max
3、查看某进程实际限制(以PID为例):
cat /proc/PID/limits | grep "Max open files"
以上就是LINUX怎么调整系统最大文件打开数_Linux系统最大文件打开数调整方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号