小知识之Linux系统中的最大进程数,最大文件描述,最大线程数
程序员文章站
2022-05-25 10:10:10
...
今天来了解一下linux里面的一些小知识:
(一)Linux系统中最大可以起多少个进程?
(1)32位系统中最多可以起32768个进程
(2)64位系统中最多可以起2的22次方(4194304)约420万个
如何查看linux系统默认的最大进程数,这里以centos7(x64)作为例子:
```` [root@es1 ~]# cat /proc/sys/kernel/pid_max 131072 [root@es1 ~]# ulimit -a | grep processes max user processes (-u) 15012 [root@es1 ~]# cat /proc/1/limits |grep processes Max processes 15012 15012 processes [root@es1 ~]# ````
上面使用了三种方法:
注意第一种才是内核级别的配置,后面的设置不能超过内核级别设置的限制,这个值是可以具体的情况修改的,centos7(x64)给的还是比较大,在centos6好像给的是32768
(二)Linux系统中的最大文件描述符?
文件描述符定义:
文件描述符在形式上是一个非负整数。实际上,它是一个索引值,指向内核为每一个进程所维护的该进程打开文件的记录表。当程序打开一个现有文件或者创建一个新文件时,内核向进程返回一个文件描述符
关于文件描述符的最大数量,其实是可以无限大的,但考虑到每一个文件描述符都需要一定数量的内存和磁盘维护,所以还是有限制的,另外一个问题,为什么linux系统要限制文件描述符的数量?
原因有两方面:
(1)系统本身的资源有限
(2)比如一个机器有多个用户,如果没有限制,某一个用户起了无限多的进程和无休止的创建文件描述符,就直接有可能导致整台机器挂掉,影响了其他正常的用户的使用,所以还是有必要给不同的用户根据所需限制文件描述的数量,避免一定程度上的fork bomb的问题出现。
下面看几个关于文件描述符的命令:
```` [root@es1 ~]# cat /proc/sys/fs/file-max 379804 [root@es1 ~]# ulimit -n 65536 [root@es1 ~]# lsof | wc -l 2201 [root@es1 ~]# ````
第一个命令代表:当前系统允许创建的最大文件描述符的数量
第二个命令代表:当前会话session的允许创建的最大文件描述符,默认每个进程允许打开的最大文件描述符数量应该是1024
第三个命令代表:统计当前所有进程的占用的文件描述符的总量
注意lsof命令默认系统是没有安装的,需要执行下面的命令安装,此外这个命令需要用root执行:
```` yum install -y lsof ````
最后再记录一个比较实用的命令,查看每个进程打开的文件描述符的数量,并按打开的数量降序排序:
```` lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr ````
结果:
```` ```` 306 637 261 651 130 1112 117 650 88 1110 68 615 62 638 62 1 55 870 ````
第一列是文件描述符数量,第二列是进程id
(三)Linux系统中的最大线程数量
其实最大线程数量也可以配置无限大,在资源充足的情况下,但一般都有会默认限制,主要影响线程的参数如下:
```` ulimit -s 栈大小设置 ulimit -i 阻塞的引号量 ulimit -u 最大的线程/进程数 /proc/sys/kernel/threads-max 最大线程数量 /proc/sys/vm/max_map_count 限制一个进程可以拥有的VMA(虚拟内存区域)的数量 /proc/sys/kernel/pid_max 最大进程数量 ````
总结:
正常的情况下,系统默认的配置已经足够我们用了,除非想进行一些极限性能测试或者性能优化,这时候可以根据具体的情况来调整上面提到的几个参数。
有什么问题可以扫码关注微信公众号:我是攻城师(woshigcs),在后台留言咨询。 技术债不能欠,健康债更不能欠, 求道之路,与君同行。
上一篇: 一些不错的博客
下一篇: Hadoop日志系统知识