linux最大线程数

#查系统支持的最大线程数
/proc/sys/kernel/pid_max 
sysctl kernel.pid_max
/proc/sys/kernel/threads-max 
sysctl kernel.threads-max
#查看当前用户最大进程或线程数(max_user_process)
ulimit -u
如果当前用户线程数超过该设置值,会报如下错误(Java工程):
Caused by: java.lang.OutOfMemoryError:unable to create new native thread
#修改当前用户最大进程数
vi /etc/security/limits.d/20-nproc.conf(centos6 是 90-nproc.conf)
修改* soft nproc 1024中的1024为要修改的值

扩展知识:
1、Ulimit命令
设置限制,可以把命令加到profile文件里
命令参数
-a     显示所有限制
-c     core文件大小的上限
-d     进程数据段大小的上限
-f     shell所能创建的文件大小的上限
-m     驻留内存大小的上限
-s     堆栈大小的上限
-t     每秒可占用的CPU时间上限
-p     管道大小
-n     打开文件数的上限
-u     进程数的上限
-v     虚拟内存的上限
例如:临时修改堆栈大小的上限
ulimit -s 1024

sysctl命令
-a 显示所有内核参数
-w 临时生效内核参数 例如sysctl -w vm.max_map_count=262144
-p 生效/etc/sysctl.conf中的内核参数

ps hH p <PID> 查看当前PID的线程数

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

3、nproc
nproc表示单个用户创建的进程数(默认值,软限制:threads-max/2,硬限制:threads-max/2),线程的实现其实是一个轻量级的进程,所以线程也算进程
/proc/sys/kernel/threads-max表示整个系统内核可以分配的最大线程数,可修改。
/proc/sys/kernel/pid_max表示整个系统内核可以分配的最大进程ID(默认值为32768,2个字节的最大值),也就是说,整个系统内核最多只能分配pid_max个进程或线程,如需修改执行命令,可修改。
/proc/sys/vm/max_map_count表示单个进程可以分配的内存映射区域的最大数量(默认值为65530),由于java中每创建一个线程需要分配2个内存映射区域,并且jvm本身也要占用部分内存映射区域,所以java程序理论上最多可以创建的线程数为略小于max_map_count/2(实际上还受jvm参数-Xms、-Xmx、-Xss以及操作系统物理内存的影响),如果超过这个值会报错“max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]”,可修改;
max_map_count,默认值为65536,该值表示文件包含限制一个进程可以拥有的VMA(虚拟内存区域)的数量。虚拟内存区域是一个连续的虚拟地址空间区域。在进程的生命周期中,每当程序尝试在内存中映射文件,链接到共享内存段,或者分配堆空间的时候,这些区域将被创建。调优这个值将限制进程可拥有VMA的数量。限制一个进程拥有VMA的总数可能导致应用程序出错,因为当进程达到了VMA上线但又只能释放少量的内存给其他的内核进程使用时,操作系统会抛出内存不足的错误。如果你的操作系统在NORMAL区域仅占用少量的内存,那么调低这个值可以帮助释放内存给内核用
单个进程可以创建的线程数由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为通配符()的配置

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值