ulimit 设置


系统在做高并发测试时,有时发现连接数怎么也上不去,可以检查下系统的ulimit,如ulimit -n限制了可以打开的文件描述符的最大值。

ulimit 命令的格式为:ulimit [options] [limit]

具体的 options 含义以及简单示例可以参考以下表格。

选项 [options]含义例子
-H设置硬资源限制,一旦设置不能增加。ulimit – Hs 64;限制硬资源,线程栈大小为 64K。
-S设置软资源限制,设置后可以增加,但是不能超过硬资源设置。ulimit – Sn 32;限制软资源,32 个文件描述符。
-a显示当前所有的 limit 信息。ulimit – a;显示当前所有的 limit 信息。
-c最大的 core 文件的大小, 以 blocks 为单位。ulimit – c unlimited; 对生成的 core 文件的大小不进行限制。
-d进程最大的数据段的大小,以 Kbytes 为单位。ulimit -d unlimited;对进程的数据段大小不进行限制。
-f进程可以创建文件的最大值,以 blocks 为单位。ulimit – f 2048;限制进程可以创建的最大文件大小为 2048 blocks。
-l最大可加锁内存大小,以 Kbytes 为单位。ulimit – l 32;限制最大可加锁内存大小为 32 Kbytes。
-m最大内存大小,以 Kbytes 为单位。ulimit – m unlimited;对最大内存不进行限制。
-n可以打开最大文件描述符的数量。ulimit – n 128;限制最大可以使用 128 个文件描述符。
-p管道缓冲区的大小,以 Kbytes 为单位。ulimit – p 512;限制管道缓冲区的大小为 512 Kbytes。
-s线程栈大小,以 Kbytes 为单位。ulimit – s 512;限制线程栈的大小为 512 Kbytes。
-t最大的 CPU 占用时间,以秒为单位。ulimit – t unlimited;对最大的 CPU 占用时间不进行限制。
-u用户最大可用的进程数。ulimit – u 64;限制用户最多可以使用 64 个进程。
-v进程最大可用的虚拟内存,以 Kbytes 为单位。ulimit – v 200000;限制最大可用的虚拟内存为 200000 Kbytes。


临时修改:直接在shell命令行通过ulimit命令修改,shell关闭后失效。

永久修改:编辑/etc/security/limits.conf,例如添加:

*                hard    nofile          10000
*                soft    nofile          10000

重新打开shell生效。虽然生效但是在做网络压力测试时仍然可能会有问题,建议修改此文件后重启,能够保证生效。

软限制可以限制用户/组对资源的使用,硬限制的作用是控制软限制,硬限制设定后,设定软限制时只能是小于或等于硬限制.

ulimit不加-H或者-S时看到的是软限制。如果ulimit不限定使用-H或-S,会同时把两类限制都改掉.


例如:

[root@AS01 ~]# ulimit -n
1024
[root@AS01 ~]# ulimit -n -H
4096
[root@AS01 ~]# ulimit -n 100000
[root@AS01 ~]# ulimit -n
100000
[root@AS01 ~]# ulimit -n -H
100000
[root@AS01 ~]#

另外,请注意,ulimit -n设置的值为单个进程打开的最大文件数,整个操作系统能够打开的最大文件数由/proc/sys/fs/file-max控制



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值