今天来了解一下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),在后台留言咨询。 技术债不能欠,健康债更不能欠, 求道之路,与君同行。
分享到:
相关推荐
### Linux高级编程知识点总结——进程线程 #### 进程与程序的区别及PCB - **进程与程序的区别**...以上就是关于Linux进程和线程的高级编程知识点总结,涉及到了进程的基础概念、创建、管理以及特殊状态等方面的内容。
在Linux操作系统中,多线程编程是实现并发执行任务的有效方式。本示例涉及的知识点主要集中在如何在Linux环境下利用C语言创建并管理线程,以及如何使用信号量来实现线程间的同步,确保数据安全地被读取和显示。我们...
4. LWP(轻量级进程,Lightweight Process):LWP是Linux系统实现多线程的一种方式,它与传统意义上的进程有所不同,因为它们共享很多资源,如地址空间、文件描述符等。LWP在Linux中主要通过clone()系统调用来实现,...
在Linux系统编程中,一个重要的概念是文件描述符,它是一个非负整数,用于表示打开的文件或者其他资源。文件描述符是内核为了高效管理已经打开的文件所使用的一个索引值。 Linux系统编程中的文件操作通常涉及对普通...
文件中还提及了线程数量的限制,如PTHREAD_THREADS_MAX,它定义了可以创建的最大线程数。 SMP(对称多处理)支持: Linux支持SMP架构,这意味着操作系统可以在多核处理器上执行多任务,提供更好的并行处理能力,...
在Linux环境中,系统调用是用户空间进程请求操作系统服务的接口,允许程序执行特权操作,如文件I/O、进程管理、内存管理等。本篇将深入探讨Linux内核中的系统调用机制及其相关知识。 一、系统调用的基本概念 1. ...
6. **性能优化**:在设计多线程扫描器时,还需要考虑系统资源的限制,如CPU核心数和打开的文件描述符数。适当调整线程数量和扫描策略,以达到最佳性能。 7. **权限与隐蔽性**:端口扫描可能涉及到隐私和安全问题,...
- **1.4.1 文件与文件描述符**:文件是Linux系统中最基本的资源之一,而文件描述符则是用来标识文件的整数。 - **1.4.2 特殊文件**:如设备文件、管道等特殊类型的文件。 - **1.4.3 设备**:Linux中的设备通常被...
Linux系统的多线程程序,特别是那些使用NPTL的程序,会受到系统中pthread的限制,比如PTHREAD_THREADS_MAX定义了系统支持的最大线程数。文件提到,早期Linux系统对线程数量有1024的上限,但随着NPTL的引入,这个限制...
文件描述符是Linux中文件操作的核心概念,每个打开的文件都有一个唯一的数字标识。 2. Files and Directories:Linux系统使用目录结构组织文件。`mkdir`, `rmdir`, `ls`, `cd`, `touch`, `rm`等命令用于管理目录和...
### Linux系统编程知识点详解 #### 一、绪论与核心概念 **1.1 什么是系统编程** 系统编程是指直接与计算机硬件交互的编程活动,它通常涉及底层操作系统的功能,如文件管理、进程控制等。系统编程的目标是提供一个...
本篇内容涵盖了Linux环境下使用C语言进行系统编程的基础知识和技术要点,包括编译器使用、Makefile编写、进程管理、文件操作、时间处理、消息循环、线程管理和网络编程等方面。这些知识点是深入理解和掌握Linux系统...
在Linux系统中,`flock`是一种用于实现文件锁定机制的方法,主要用于控制对共享文件的访问,确保同一时间只有一个进程能够对文件进行写操作,从而避免数据不一致的问题。`flock`结构体定义在`<sys/flock.h>`头文件中...