目录
Linux修改最大打开文件句柄数方法
1、单个进程文件句柄限制
1.1 查看单个进程能打开的最大文件句柄数
bash
ulimit -n
1.2 临时修改
bash
ulimit -n 1000000
在当前session有效,用户退出或者系统重新后恢复默认值
1.3 修改单个进程能打开的最大文件句柄数(永久生效)
bash
vim /etc/security/limits.conf
# 在文件末尾增加如下内容:
# * 表示当前用户,soft表示到达此限制时系统警告,hard到达此限制时系统报错,nofile表示打开的最大文件数,1000000表示值
# 整体的含义就是:任何用户一个进程最多能打开100w个文件句柄
bash
* soft nofile 204800
* hard nofile 204800
修改后再使用ulimit -n查看发现文件句柄数没变,需要重启机器生效。
如果修改后没有生效,可通过修改nr_open参数接触限制
bash
sysctl -w fs.nr_open=204800
或者
bash
vim /etc/sysctl.conf
# 在文件末尾添加如下内容
bash
fs.nr_open=204800
2、整个系统内核文件句柄限制
2.1 查看系统文件句柄数量
bash
cat /proc/sys/fs/file-max
2.2 方式一:临时修改,系统重启后恢复默认
bash
echo 1000000 > /proc/sys/fs/file-max
或者
bash
sysctl -w fs.file-max=1000000
2.3 方式二:修改整个系统内核最大可以打开的文件描述符数量(永久修改)
bash
vim /etc/sysctl.conf
# 在文件末尾添加如下内容
bash
fs.file-max=1000000
执行命令生效
bash
sysctl -p
2.4 查看文件句柄数量使用的情况
bash
watch -n 1 cat /proc/sys/fs/file-nr
2.5 查看打开文件句柄数量进程的情况
bash
lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more
注:返回结果中第一列是打开文件的句柄数量,第二列是PID进程号。
2.6 查询PID对应的进程信息
bash
ps aux|grep [$PID]
3、注意
3.1 ubuntu系统下,* soft nofile 65535 无用,必须指定用户
bash
vim /etc/systemd/system.conf #modify hard limit
DefaultLimitNOFILE=65536
vim /etc/systemd/user.conf #modify soft limit
DefaultLimitNOFILE=65536
reboot
设置登录自动读取限制参数 修改文件,在文件中添加如下行
bash
vim /etc/pam.d/login #在文件中添加如下行
session required /lib/security/pam_limits.so
注:这是告诉Linux在用户完成系统登录后,应该调用pam_limits.so模块来设置系统对该用户可使用的各种资源数量的最大限制(包括用户可打开的最大文件数限制),而pam_limits.so模块就会从/etc/security/limits.conf文件中读取配置来设置这些限制值。修改完后保存此文件。
3.2 要修改容器的ulimit限制,必须要修改宿主机的ulimit
修改容器的最大文件描述符限制通常需要修改宿主机的配置。容器是在宿主机上运行的,它们共享宿主机的资源,包括文件描述符限制。因此,如果要增加或修改容器的最大文件描述符限制,需要在宿主机上进行相应的配置更改。
具体来说,可以通过修改宿主机的配置文件来调整文件描述符限制。在Linux系统中,可以通过修改/etc/security/limits.conf
文件来设置文件描述符限制。在该文件中,可以指定每个用户或用户组的最大文件描述符数量。
需要注意的是,修改宿主机的配置可能会影响到其他正在运行的容器或系统进程,因此在进行修改之前,请确保了解修改的影响,并谨慎操作。
要修改容器的最大文件描述符,可以通过以下步骤进行操作:
-
进入容器:使用docker exec命令进入正在运行的容器。例如:
docker exec -it <container_id> /bin/bash
。 -
查看当前的最大文件描述符限制:在容器内部运行
ulimit -n
命令,可以查看当前的最大文件描述符限制。 -
修改最大文件描述符限制:可以通过修改容器的ulimit值来增加最大文件描述符限制。使用
ulimit -n <new_limit>
命令来设置新的限制值。注意,这个操作需要在具有足够权限的用户下进行。 -
验证修改是否生效:再次运行
ulimit -n
命令,确认新的最大文件描述符限制已经生效。