如果您使用的是Linux,则必须多次遇到“打开文件过多(24)”错误。Linux操作系统提供了一种限制每个用户可以使用的文件数量的方法。本文提供有关如何增加Linux操作系统中打开的文件或文件描述符数量的见解。
ulimit命令可以控制shell或进程,并且需要以root用户身份登录。该的ulimit命令用于设置仅适用于当前会话的文件限制。
使用以下命令显示打开文件描述符的最大数量-# cat /proc/sys/fs/file-max
801841
在上面的命令中,用户可以在单个登录会话中打开801841文件。要查看文件描述符的硬值和软值,请使用以下命令:
文件描述符的硬值
硬值限制只能由root用户修改。非root用户不能超过硬限制。
我们可以使用以下命令检查硬值–$ ulimit -Hn
4096
在上面的命令中,“ H”选项表示硬值,“ n”表示文件数。
文件描述符的软值
可以通过用户进程随时修改软值限制。它用于禁用核心转储。
我们可以使用以下命令检查硬值–$ ulimit -Sn
1024
在以上命令中,“ S”选项表示软值,“ n”表示文件数。
修复“打开文件过多”错误
通过在内核变量/ proc / sys / fs / file-max中设置一个新值,可以增加打开文件的最大数量,如下所示:$ sysctl -w fs.file-max=100000
fs.file-max = 100000
上面的命令将最大打开文件数限制为100000,这适用于特定会话。如果您想终身使用此值,则需要编辑/etc/sysctl.conf文件并放入以下行–$ vi /etc/sysctl.conf
样本输出应如下所示–........
#
# Do not send ICMP redirects (we are not a router)
#net.ipv4.conf.all.send_redirects = 0
#
# Do not accept IP source route packets (we are not a router)
#net.ipv4.conf.all.accept_source_route = 0
#net.ipv6.conf.all.accept_source_route = 0
#
# Log Martian Packets
#net.ipv4.conf.all.log_martians = 1
#fs.file-max = 50000
将文件最大值替换为100000并保存。用户需要注销并再次登录才能使更改生效,或者只需键入以下命令–$ sysctl -p
要验证它,请使用以下命令–$ cat /proc/sys/fs/file-max
样本输出应如下所示–$ cat /proc/sys/fs/file-max
100000
用户级别文件描述符限制
上面的过程描述了系统级文件描述符限制。但是,我们可以设置用户级别的文件描述符限制。要指定用户级别文件描述符限制,可以通过编辑/etc/security/limits.conf文件来实现。
要编辑文件,请使用以下命令–$ vi /etc/security/limits.conf
样本输出应如下所示–.....
#* soft core 0
#root hard core 100000
#* hard rss 10000
#@student hard nproc 20
#@faculty soft nproc 20
#@faculty hard nproc 50
#ftp hard nproc 0
#ftp - chroot /ftp
#@student - maxlogins 4
将以下行追加到limits.conf文件中–#tp soft nofile 4096
#tp hard nofile 10240
这里TP是系统的用户名。保存并关闭文件。要查看限制,请使用如上所示的ulimits命令。
恭喜你!现在,您知道“如何增加打开的文件或文件描述符的最大数量”。在下一篇Linux文章中,我们将学习有关这些命令类型的更多信息。继续阅读!