linux增加用户_Linux:谁能打开多少个文件,可以精准控制!只需这行配置。

530a519e5a95795aa8c95bd7894338d2.png

引言

在Linux中,可以更改打开文件的最大数量。使用ulimit命令修改这个限制值,从而控制文件资源的访问阈值。

在本文中,我们将展示如何检查当前打开的文件和文件描述的限制,但有个前提,你得有root权限。root用户本身,或者sudoer组成员。

首先,让我们看看如何找出Linux系统上打开的文件描述符的最大数量。

查找Linux打开文件限制

该值存储在下面的文件内

87859a1ab99a4899b8134566636008d2.png

可以看到,该数值显示了用户在每个登录会话中可以打开的文件数量。根据不同的系统,结果可能会有所不同。

例如,在有的CentOS服务器上,限制设置为818354,而在有的Ubuntu服务器上,默认限制设置为176772。

如果你想看到硬和软的限制,可以使用以下命令:

查看硬限制

ulimit -Hn

查看软限制

ulimit -Sn

想要查看其它用户的限制措施,可以使用 su 指令切换过去,再执行 ulimit 查看。

如何在Linux中检查系统范围的文件描述符限制

如果服务器正在运行,但是一些应用程序可能需要对打开的文件描述符数量调高。比如,运行中的MySQL/MariaDB服务,或Apache web服务器就是一个很好的例子。

那么可以通过编辑内核指令fs.file-max来增加Linux中打开文件的限制。为此,我们需要使用sysctl程序。

sysctl用于在运行状态中配置内核参数。

例如,要将打开文件的限制增加到500000,可以使用root执行以下命令:

sysctl -w fs.file-max=500000

然后使用以下命令检查其当前值:

cat /proc/sys/fs/file-max

使用上述命令,你所做的更改将仅在下一次重新启动之前保持。如果你想永久有效,则必须编辑以下文件:

vi /etc/sysctl.conf

追加如下行:

fs.file-max=500000

当然,也可以根据需要更改数值。要再次验证更改是否生效,请使用:

cat /proc/sys/fs/file-max

用户需要注销并再次登录才能使更改生效。如果想立即使限制起作用,运行以下命令:

sysctl -p

Linux中根据用户级别设置限制

上面的示例演示了如何设置全局限制,但是你可能希望对每个用户应用限制。你需要root身份编辑以下文件:

vi /etc/security/limits.conf

如果是一名Linux管理员,需要对该文件烂熟于胸。网上也有很多示例,介绍了通过限制不同级别的用户/组,在管理系统资源方面大大地提高了灵活性。

配置文件列参数如下:

<domain>        <type>  <item>  <value>

下面是一个为用户tony设置软限制和硬限制的例子:

tony        hard nofile 4096
tony        soft nofile 1024

写在最后

这篇简短的文章展示了一个基本示例,演示如何配置全局限制,和用户级别的限制,从而控制打开文件的最大数量。

上面我们只是说了浅浅的表面知识。我强烈建议你详细地了解/etc/sysctl.conf和/etc/security/limit .conf,并学习如何使用。

总有一天它们会对你有极大帮助的。

Happy coding :)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值