linux系统too many open files解决方法

一、问题

too many open files是Linux系统中常见的错误,从字面意思上看就是说程序打开的文件数过多,不过这里的files不单是文件的意思,也包括打开的通讯链接(比如socket),正在监听的端口等等,所以有时候也可以叫做句柄(handle),这个错误通常也可以叫做句柄数超出系统限制。

二、解决方法

1、修改 /etc/security/limits.conf

这个文件用于设置用户的资源限制,包括可以打开的文件数量。按照您的指示,您应该添加以下两行到该文件的末尾:

*       hard    nofile  65535

*       soft    nofile  65535

这里,* 表示对所有用户生效,hard 表示硬限制(用户不能增加),soft 表示软限制(用户可以增加,但不能超过硬限制),nofile 是限制的类型(即文件描述符的数量),65535 是新的限制值。

2、修改 /etc/sysctl.conf

这个文件用于设置系统级别的参数,包括系统级别的文件描述符限制。您需要添加或修改以下行:

 fs.file-max=65535

这表示系统级别的最大文件描述符数量被设置为65535。请注意,这个值应该大于或等于/etc/security/limits.conf中设置的硬限制值,以确保系统不会因为文件描述符的限制而阻止用户进程正常工作。

3、应用更改

修改完这些文件后,您需要让更改生效。对于​​/etc/sysctl.conf​​的更改,您可以通过运行以下命令来立即应用它们:

sysctl -p

然而,对于/etc/security/limits.conf的更改,它们将在用户下次登录时生效。如果您需要立即对当前会话生效(例如,如果您正在以root用户身份运行数据库),则可能需要使用pam_limits服务(如果可用)或重新登录。但请注意,对于已经运行的进程,这些更改不会生效,您可能需要重启数据库服务或整个系统。

4、验证更改

为了验证更改是否生效,您可以使用以下命令来检查当前会话的限制:

ulimit -Hn  # 查看硬限制

 ulimit -Sn  # 查看软限制

请注意,这些命令显示的是当前shell会话的限制,而不是系统全局的限制。对于系统全局的限制,您可能需要查看​​/proc/sys/fs/file-max​​​来确认​​fs.file-max​​的值。

cat /proc/sys/fs/file-max

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叫个啥网名好呢?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值