增加Linux中最大打开文件数

如果您使用的是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文章中,我们将学习有关这些命令类型的更多信息。继续阅读!