Linux下各种最大数目

ulimit命令查看和更改系统限制

ulimit命令详解

ulimit用于shell启动进程所占用的资源,可以用来设置系统的限制;

语法格式:ulimit [-acdfHlmnpsStvw] [size]

/etc/security/limits.conf文件中定义

这里写图片描述

可以使用ulimit -a查看系统的所有限制

这里写图片描述

Linux大部分的命令设置都是临时生效的,而且ulimit命令只对当前终端有效。

如果需要永久有效的话,可以:

  • 一种是将命令写至profile和bashrc中,相当于在登陆时自动动态修改限制;
  • 还有一种就是在/etc/security/limits.conf中添加记录(需重启生效,并且在/etc/pam.d/中的seesion有使用到limit模块);

最大进程数目

Linux中进程的理论最大数计算

每个进程都要在全局段描述表GDT中占据两个表项
每个进程的局部段描述表LDT都作为一个独立的段而存在,在全局段描述表GDT中要有一个表项指向这个段的起始地址,并说明该段的长度以及其他一些 参数。除上之外,每个进程还有一个TSS结构(任务状态段)也是一样。所以,每个进程都要在全局段描述表GDT中占据两个表项。

GDT的容量有多大呢?

段寄存器中用作GDT表下标的位段宽为13位,所以GDT中可以有2^13 = 8192个描述符;

除一些系统的开销(例如GDT中的第2项和第3项分别用于内核 的代码段和数据段,第4项和第5项永远用于当前进程的代码段和数据段,第1项永远是0,等等)以外,尚有8180个表项可供使用,所以理论上系统中最大的 进程数量是8180/2=4090。

所以系统中理论上最大的进程数是4090。

系统中可创建的进程数实际值

Linux内核通过进程标识符(process identification value)—PID来标识进程,PID是一个整数,类型为pid_t,实际上就是int类型。

为了与老版本的Unix或Linux兼容,PID最大值默认是32768(short int短整型最大值)。

  • 查看
    可以使用cat /proc/sys/kernel/pid_max来查看系统中可创建的进程数实际值
  • 修改
    ulimit -u 65535

设置完之后,虽然我们设置创建进程数的硬限制和软限制都是65535,但还是不能创建65535个进程,需要在Linux设置内核参数kernel.pid_max,这个参数默认安装都是32768,所以即便是root用户,却不设置这个内核参数,整个系统最多可创建进程数就是32768,所以,需进行如下设置:
sysctl -w kernel.pid_max=65535

最大线程数

Linux系统中单个进程的最大线程数有其最大限制:PTHREAD_THREADS_MAX

这个限制可以在/usr/include/bits/local_lim.h中查看,对linuxthreads这个值一般是1024,对于nptl没有硬性的限制,仅仅受限于系统的资源,系统的资源主要就是线程的stack所占用的内存,用ulimit -s可以查看默认的线程栈的大小,一般情况下,这个值是8M = 8192KB。

Linux中单个进程理论上可以创建的最大线程数

在我们的系统(Ubuntu-14.04-LTS-64bit)中linuxthreads 上最多可以创建 381 个线程,之后就会返回 EAGAIN,而32为系统中,可以创建381个线程,这个值和理论完全符合,因为32位Linux下的用户进程空间是3G大小,也就是3072M,3072 / 8 = 384,但是实际上代码段和数据段还要占用一些空间,这个值应该向下取整到383,再减去主线程,得到382,那么为什么linuxthreads上还要少一个线程呢?因为linuxthreads还需要一个 管理线程

为了突破内存的额限制,可以有两种方法:

  • ulimit -s 1024减小默认的栈大小;
  • 调用pthread_create的时候用pthread_attr_getstacksize设置一个较小的栈大小;

要注意,即使这样的也无法突破1024个线程的硬限制,除非重新编译C库。

最大打开文件数

file-max系统最大打开文件描述符数

/proc/sys/fs/file-max中指定了系统范围内所有进程可打开的文件句柄的数量限制(系统级别, kernel-level)。

The value in file-max denotes the maximum number of file handles that the Linux kernel will allocate).

当收到”Too many open files in system”这样的错误消息时, 就应该增加这个值了。

对于2.2的内核, 还需要考虑inode-max, 一般inode-max设置为file-max的4倍. 对于2.4及以后的内核, 没有inode-max这个文件了。

查看实际值

可以使用cat /proc/sys/fs/file-max来查看当前系统中单进程可打开的文件描述符数目

这里写图片描述

设置
  • 临时性设置:echo 1000000 > /proc/sys/fs/file-max
  • 永久性设置:在/etc/sysctl.conf中设置fs.file-max = 1000000
nr_open是单个进程可分配的最大文件数

内核支持的最大file handle数量,即一个进程最多使用的file handle数

A process cannot use more than NR_OPEN file descriptors.
一个进程不能使用超过NR_OPEN文件描述符

这里写图片描述

nofile进程最大打开文件描述符数

ulimit -n

这里写图片描述

默认查看的是软资源限制值soft limit,如果想要查看系统硬件所能支持的单进程最大打开文件描述符号的数目,可以使用ulimit -Hn

这里写图片描述

设置
  • 临时性:

通过ulimit -Sn设置最大打开文件描述符数的soft limit,注意soft limit不能大于hard limit(ulimit -Hn可查看hard limit);

另外ulimit -n默认查看的是soft limit,但是ulimit -n 1800000则是同时设置soft limit和hard limit;

对于非root用户只能设置比原来小的hard limit;

  • 永久性:

上面的方法只是临时性的,注销重新登录就失效了,而且不能增大hard limit,只能在hard limit范围内修改soft limit;

若要使修改永久有效,则需要在/etc/security/limits.conf中进行设置(需要root权限),可添加如下两行,表示用户chanon最大打开文件描述符数的soft limit为1800000,hard limit为2000000。以下设置需要注销之后重新登录才能生效:

chanon           soft    nofile         102400
chanon           hard    nofile          409600

设置nofile的hard limit还有一点要注意的就是hard limit不能大于/proc/sys/fs/nr_open,假如hard limit大于nr_open,注销后无法正常登录。

file-max是内核可分配的最大文件数,nr_open是单个进程可分配的最大文件数,所以在我们使用ulimit或limits.conf来设置时,如果要超过默认的1048576值时需要先增大nr_open值(sysctl -w fs.nr_open=100000000或者直接写入sysctl.conf文件)。

  • 所有进程打开的文件描述符数不能超过/proc/sys/fs/file-max;
  • 单个进程打开的文件描述符数不能超过user limit中nofile的soft limit;
  • nofile的soft limit不能超过其hard limit;
  • nofile的hard limit不能超过/proc/sys/fs/nr_open(单个进程可分配的最大文件数);
### 回答1: Linux的Socket最大连接数量取决于多个因素,包括操作系统、硬件配置和进程限制。 在Linux操作系统中,Socket的最大连接数量由操作系统的内核参数限制。该参数通常称为`somaxconn`(Socket拥塞连接的最大数目)。该参数的默认值通常是128,但可以通过修改内核参数进行调整。 除了上述操作系统参数的限制外,还有一些因素可能会影响Socket的最大连接数量。首先,服务器的硬件配置(如网络带宽、内存和处理能力)可以限制可以支持的最大连接数量。其次,服务器的编程实现和网络架构也可能对Socket连接数产生影响。 此外,每个进程还有自己的连接限制。例如,对于单个进程使用IPv4协议,可以使用`ulimit`命令来限制连接数量。通过更改`ulimit`值,可以增加或减少进程所能支持的Socket连接数量。 总而言之,Linux操作系统中的Socket最大连接数量是一个复杂的问题,取决于多个因素。在实际应用中,需要考虑操作系统内核参数、硬件配置、进程限制和网络架构等因素,以确定最佳的Socket连接数配置。 ### 回答2: Linux的socket连接数量是没有固定的上限的,它主要取决于系统的资源限制和配置参数。 一般来说,Linux默认的最大连接数量是由文件描述符限制决定的。文件描述符(File Descriptor)是操作系统为了管理打开的文件和socket而分配的一种资源,它以整数的形式标识着这些文件和socket。在Linux中,每个进程都有一定数量的文件描述符,它们是有限的。可以通过ulimit命令查看当前用户的文件描述符限制。 socket连接数量受到可用的文件描述符数量的限制。当一个进程发起socket连接时,操作系统会为它分配一个文件描述符,所以如果系统中的文件描述符被其他进程占满了,新的socket连接就会失败。为了提高系统的性能,可以通过修改文件描述符限制来增加最大连接数量。可以通过修改/etc/security/limits.conf文件或者使用ulimit命令来修改文件描述符限制。 此外,还可以修改内核参数来增加最大连接数量。在Linux中,可以通过修改/proc文件系统的某些文件或者使用sysctl命令来修改内核参数。常见的与最大连接数量相关的内核参数有somaxconn,它表示系统监听的最大连接队列的大小;以及net.ipv4.tcp_max_syn_backlog,它表示系统SYN队列的最大长度。调整这些参数可以增加系统的最大连接数量。 综上所述,Linux的socket最大连接数量是没有固定的上限的,但受到系统资源限制和配置参数的影响。可以通过调整文件描述符限制和内核参数来增加最大连接数量。 ### 回答3: Linux中,socket的最大连接数量受到操作系统限制以及系统资源的影响。Linux系统默认情况下设置了一些限制,但是这些限制通常可以通过修改配置文件或者调用系统函数来进行调整。 在Linux中,每个进程有一个最大文件描述符数的限制,文件描述符中包括了socket。可以通过ulimit命令来查看当前进程的文件描述符限制。对于普通用户,通常文件描述符限制较低,而对于root用户,则较高。 此外,Linux内核还会限制单个端口上的并发连接数量。这个限制可以在内核中通过修改/proc/sys/net/core/somaxconn文件来进行调整。默认情况下,此限制通常为128,即单个端口上的最大连接数量为128。 另一方面,系统的物理内存和处理器等硬件资源也会对最大连接数量产生影响。如果系统资源有限,例如内存不足,那么最大连接数量可能会受到限制。 总的来说,对于Linux系统而言,最大连接数量不是固定值,而是受到多个因素的影响。可以通过修改操作系统配置、调整内核参数、增加硬件资源等方式来提升最大连接数量
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值