Linux修改文件句柄数

1 修改文件句柄数

1.1 查看当前大小

ulimit -a

 1.2 临时修改

ulimit -n 4096

 

1.3 永久修改

vim /etc/security/limits.conf

注:需要使用 root 用户

*  soft  nofile  65536
*  hard  nofile  65536

重新登录后生效

2 修改max user processes进程数

2.1.临时修改

ulimit -u 65536

 

 2.2 永久修改

vim /etc/security/limits.conf

*  soft  nproc    65536
*  hard  nproc    65536

 

3 调整vm.max_map_count的大小

max_map_count文件包含限制一个进程可以拥有的VMA(虚拟内存区域)的数量

报错“max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]”

3.1 查看当前值

sysctl -a | grep vm.max_map_count

 3.2 临时修改

sysctl -w vm.max_map_count=262144

 3.3 永久修改

vim /etc/sysctl.conf

vm.max_map_count=262144

 输入以下命令进行生效:

sysctl -p

4 调整stack size的大小

4.1 查看当前值

ulimit -a,默认是8192,即8M

4.2 临时修改

ulimit -s 1024

4.3 永久修改

 vi /etc/security/limits.conf

soft stack 1024
hard stack 1024

5 注意

5.1 nofile

nofile表示单个进程可以打开的最大文件句柄数(默认值,软限制:1024,硬限制:4096)
/proc/sys/fs/file-max表示整个系统内核可以分配的最大文件句柄数(默认值约为物理内存转换成kb的值/10),如需修改执行命令:echo
‘fs.file-max=104857600’ >> /etc/sysctl.conf && sysctl -q -p
/proc/sys/fs/file-nr表示整个系统内核的文件句柄统计数据(只读),包含三个值,1:整个系统内核已分配的文件句柄数,2:整个系统内核已分配但未使用的文件句柄数(一般情况下为0),3:整个系统内核可以分配的最大文件句柄数(等于file-max)
/proc/sys/fs/nr_open表示单个进程可以分配的最大文件句柄数(默认值为1048576),如需修改执行命令:echo
‘fs.nr_open=2097152’ >> /etc/sysctl.conf && sysctl -q -p
nofile的值不能超过nr_open的值,如果配置文件中nofile的硬限制的值超过nr_open的值将会导致无法登录系统
单个进程可以打开的最大文件句柄数由nofile和file-max同时约束,假如一个进程已打开的文件句柄数小于nofile,但整个系统内核所有进程打开的文件句柄数已经达到file-max,此时这个进程也不能再打开文件句柄了

5.2 nproc

nproc表示单个用户创建的进程数(默认值,软限制:threads-max/2,硬限制:threads-max/2),线程的实现其实是一个轻量级的进程,所以线程也算进程
/proc/sys/kernel/threads-max表示整个系统内核可以分配的最大线程数,如需修改执行命令:echo
‘kernel.threads-max=1048576’ >> /etc/sysctl.conf && sysctl -q -p
/proc/sys/kernel/pid_max表示整个系统内核可以分配的最大进程ID(默认值为32768,2个字节的最大值),也就是说,整个系统内核最多只能分配pid_max个进程或线程,如需修改执行命令:echo
‘kernel.pid_max=1048576’ >> /etc/sysctl.conf && sysctl -q -p
/proc/sys/vm/max_map_count表示单个进程可以分配的内存映射区域的最大数量(默认值为65530),由于java中每创建一个线程需要分配2个内存映射区域,并且jvm本身也要占用部分内存映射区域,所以java程序理论上最多可以创建的线程数为略小于max_map_count/2(实际上还受jvm参数-Xms、-Xmx、-Xss以及操作系统物理内存的影响),如需修改执行命令:echo
‘vm.max_map_count=2097152’ >> /etc/sysctl.conf && sysctl -q -p
单个进程可以创建的线程数由nproc、threads-max、pid_max、max_map_count以及系统资源同时约束,达到其中一个的上限就不能再创建线程了
CentOS7中/etc/security/limits.d/20-nproc.conf(CentOS6是90-nproc.conf)会覆盖/etc/security/limits.conf中的nproc配置,前提条件是,(20|90)-nproc.conf和limits.conf的domain相同或者(20|90)-nproc.conf比limits.conf的domain更具体,优先级从高到低分别为:
/etc/security/limits.d/(20|90)-nproc.conf中domain为具体用户的配置
/etc/security/limits.conf中domain为具体用户的配置
/etc/security/limits.d/(20|90)-nproc.conf中domain为通配符()的配置
/etc/security/limits.conf中domain为通配符(
)的配置

5.3 注意事项

domain中具体用户比通配符(*)优先级高
软限制不能大于硬限制,如果配置文件中软限制设置的比硬限制高,则软限制会使用硬限制的值,通过ulimit命令设置软限制不能超过硬限制。root用户可以通过ulimit命令降低和提高硬限制(nofile的值不能超过nr_open的值)。非root用户可以通过ulimit命令降低硬限制,但不可以通过ulimit命令提高硬限制。

### 回答1: 要查看Linux系统中打开的文件句柄数,可以使用以下命令: ``` $ cat /proc/sys/fs/file-nr ``` 该命令会输出三个数字,分别表示当前已分配的文件句柄数、当前已使用的文件句柄数和系统最大允许的文件句柄数。其中,第一个数字表示已分配但未使用的文件句柄数,第二个数字表示已经使用的文件句柄数,第三个数字表示系统最大允许的文件句柄数。 ### 回答2: 在Linux中,每个进程都有一个默认的文件句柄限制,用于限制进程能够打开的文件数量。如果进程试图打开超过这个限制的文件,则会收到一个错误。在大多数情况下,这个限制被设置为1024个文件句柄,但是根据系统配置的不同,它也可能更高或更低。 在Linux中,可以使用许多不同的命令来检查当前的文件句柄限制和进程打开的文件句柄数。以下是一些最常见的命令: 1. ulimit命令 ulimit是一个用于控制操作系统资源限制的命令,包括文件句柄限制。默认情况下,ulimit -n命令将显示进程的文件句柄限制。要查看当前进程已经打开的文件句柄数,可以使用lsof命令。 2. /proc/sys/fs/file-max文件 /proc/sys/fs/file-max是一个包含系统文件句柄数文件。这个值表示系统上允许的最大文件句柄数。要查看这个值,可以使用cat /proc/sys/fs/file-max命令。 3. lsof命令 lsof命令可以列出当前进程打开的文件和网络连接。可以使用以下命令来列出当前进程打开的文件数: lsof -u username | wc -l 其中,username是进程所有者的用户名。这将返回打开的文件数。 4. ss命令 ss命令用于列出所有活动的套接字连接。可以使用以下命令来列出所有进程的文件句柄数: ss -s 这将返回所有进程当前打开的文件句柄数量。 总的来说,在Linux中查看文件句柄数可以使用既定的命令,如ulimit、/proc/sys/fs/file-max、lsof和ss等,但要注意选择合适的命令来查看所需的信息。 ### 回答3: 在Linux系统中,文件句柄数是指进程能够保持的打开文件的数量。每个进程在运行时都会分配一定数量的文件句柄,而每次使用文件时,进程都会使用其中的一个句柄来表示该文件。如果该进程打开了过多的文件,就可能会导致文件句柄耗尽,从而无法打开更多的文件。 要查看Linux系统中的文件句柄数,可以使用以下命令: 1. 查看当前用户的文件句柄数: 命令:ulimit -n 该命令将显示当前用户可以打开的文件句柄数。如果该值为默认值,则通常为1024。如果需要增加文件句柄数,可以编辑/etc/security/limits.conf文件并添加以下行: * soft nofile 65535 * hard nofile 65535 这将允许所有用户同时打开多达65535个文件。 2. 查看某个进程的文件句柄数: 命令:lsof -p <pid> | wc -l 该命令将显示指定进程的文件句柄数。要查找特定进程的PID,请使用ps或top命令。 3. 查看系统中所有进程的文件句柄数: 命令:cat /proc/sys/fs/file-nr 该命令将显示系统中所有进程使用的文件句柄数,以及系统可以分配的最大文件句柄数。这个值应该是当前文件句柄数文件句柄限制之间的最小值。如果当前的文件句柄数接近最大数量,则可能需要增加文件句柄的限制。 总之,要查看Linux系统中的文件句柄数,可以使用ulimit、lsof和cat等命令。了解文件句柄数的数量对于确保系统的稳定性和可靠性非常重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值