.gpg 进程 linux,小知识之Linux系统中的最大进程数,最大文件描述,最大线程数...
今天来了解一下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 最大进程数量
总结:
正常的情况下,系统默认的配置已经足够我们用了,除非想进行一些极限性能测试或者性能优化,这时候可以根据具体的情况来调整上面提到的几个参数。
.gpg 进程 linux,小知识之Linux系统中的最大进程数,最大文件描述,最大线程数...相关推荐
- linux时间树,linux小知识之查看系统时间
有个朋友想查看服务器一天的网卡流量,但是没有安装cacti.所以我推荐他使用ifconfig查看下网卡流量,然后看下系统运行时间,除出来参考一下.他居然问我系统时间怎么查看.好吧,那我就写篇文章记录下 ...
- zabbix5.0 High swap space usage ( less than 50% free)解决步骤。相关小知识:linux系统mem和swap的关系
zabbix5.0 系统报错High swap space usage ( less than 50% free) 一,执行free -m,看看目前内存是多少 total used ...
- linux进程管理内存管理,Linux专业知识四:Linux系统进程管理及查看内存
本文主讲Linux专业知识之Linux系统进程管理及查看内存的情况,以Redhat RHEL7操作系统为例. 一.进程 程序与进程:程序是静态的(文件),进程是动态的(运行的程序). 进程和线程:一个 ...
- 小知识-为什么Linux不需要磁盘碎片整理
ref: https://itcat.cn/post-495.html Linux不需要磁盘碎片整理的真正原因是因为Linux只是一个内核它没有磁盘可以整理. BTW,ext4已经开始提供碎片整理工具 ...
- linux查看pid对应的进程,linux系统中快速查看进程pid的方法
linux系统中快速查看进程pid的方法 一个很简单的'命令,pgrep,可以迅速定位包含某个关键字的进程的pid:使用这个命令,再也不用ps aux 以后去对哪个进程的pid了 用法: pgrep ...
- Linux系统中消息队列,共享内存、信号和线程的基本操作使用方法
Linux系统中消息队列,共享内存.信号和线程高级操作 第十一章 消息队列 10.1消息队列定义 10.2 消息队列特点 10.3 key值 10.4 创建消息队列 10.4.1 发送消息 10.4. ...
- 16进制 ksh_AIX系统中如何统计进程打开的文件数目
作者:李烨楠 中国建设银行 来自微信公众号:平台人生 环境: AIX 6.1 AIX7.1 前言: 用户有时需要统计一个进程打开的文件数目,比如,在当前打开文件句柄使用量是否超过用户资源限制(/etc ...
- 遍历系统中所有的进程,可根据名字或ID查找某一个线程
我们这根据名字查找进程,获取其ID 1 /*@brief 获取找到的与指定进程名相符的第一个进程ID 2 * @param [in] cpszExeFileName 进程可执行文件名(不带路径) 3 ...
- 【Android 逆向】修改运行中的 Android 进程的内存数据 ( Android 系统中调试器进程内存流程 | 编译内存调试动态库以及调试程序 )
文章目录 一.Android 系统中调试器进程内存流程 二.编译内存调试动态库以及调试程序 三.博客资源 一.Android 系统中调试器进程内存流程 修改游戏运行中的内存 , 游戏运行之后 , 游戏 ...
最新文章
- JQuery Deferred 对象
- 【开源推荐】AllJoyn:打造全球物联网的通用开源框架
- 3.5 Facade(外观)
- 详解linux系列之sendmail邮箱服务的安装及配置
- 精简版sprintf适合嵌入式使用
- jboss7.1.0配置数据库(mysql)
- solr配置中文IK Analyzer分词器
- xilinx FIFO的使用及各信号的讨论
- hadoop mapper从源码开始 详解
- 用友nc系统服务器端口号,用友NC数据库服务器参数配置说明
- SCM供应链管理系统实施困难及解决方案
- html怎么做一个正方形,使用HTML+CSS做一个正方体
- 嵌入式软件开发学习路线
- 详细讲解修改allure报告自定义的logo和名称中文
- 猿辅导 x DorisDB:构建统一OLAP平台,全面升级数据分析能力
- 【微分方程】微分算子法求微分方程特解
- 【C++】上下取整取整函数
- Python实现 宽度/广度优先搜索算法, 深度优先搜索算法
- Vue项目区分手机端访问还是电脑端访问
- 内网网络服务器怎么修改密码,服务器远程如何修改密码