linux中ulimit怎么用

2023-04-12 05:15:00 linux ulimit

Linux的ulimit命令可以查看和设置系统资源限制,包括进程的最大文件描述符数、最大内存、最大进程数等。

ulimit默认是打开的,可以通过修改/etc/security/limits.conf来修改ulimit的配置。

修改/etc/security/limits.conf文件,在文件末尾添加如下行:

* soft nofile 65535

* hard nofile 65535

表示对所有用户都生效,软限制为65535,硬限制为65535。

然后重新登录,使配置生效。

查看ulimit配置

ulimit -a

输出结果如下:

core file size (blocks, -c) 0

data seg size (kbytes, -d) unlimited

scheduling priority (-e) 0

file size (blocks, -f) unlimited

pending signals (-i) 16382

max locked memory (kbytes, -l) 64

max memory size (kbytes, -m) unlimited

open files (-n) 1024

pipe size (512 bytes, -p) 8

POSIX message queues (bytes, -q) 819200

real-time priority (-r) 0

stack size (kbytes, -s) 8192

cpu time (seconds, -t) unlimited

max user processes (-u) 16382

virtual memory (kbytes, -v) unlimited

file locks (-x) unlimited

可以看到,默认的ulimit配置是比较宽松的。

修改ulimit配置

ulimit -n 2048

表示将最大打开文件数修改为2048。

查看ulimit配置

ulimit -a

输出结果如下:

core file size (blocks, -c) 0

data seg size (kbytes, -d) unlimited

scheduling priority (-e) 0

file size (blocks, -f) unlimited

pending signals (-i) 16382

max locked memory (kbytes, -l) 64

max memory size (kbytes, -m) unlimited

open files (-n) 2048

pipe size (512 bytes, -p) 8

POSIX message queues (bytes, -q) 819200

real-time priority (-r) 0

stack size (kbytes, -s) 8192

cpu time (seconds, -t) unlimited

max user processes (-u) 16382

virtual memory (kbytes, -v) unlimited

file locks (-x) unlimited

可以看到,修改后的ulimit配置生效了。

相关文章