介绍:
ulimit命令是显示和设置core文件最大值、数据段最大值、文件最大值、管道缓冲区的最大值、CPU使用时间的最大上限等限制的命令。
语法:
ulimit [-acdfHlmnpsStv] [size]
选项介绍:
-a 显示当前所有的资源限制;
-c size: 设置core文件的最大值,单位:blocks;
-d size: 设置数据段的最大值,单位:kbytes;
-f size: 设置创建文件的最大值,单位:blocks;
-H: 设置硬件资源限制;
-l size: 设置在内存中锁定进程的最大值,单位:kbytes;
-m size: 设置可以使用的常驻内存的最大值,单位:kbytes;
-n size: 设置内核可以同时打开的文件描述符的最大值;
-p size: 设置管道缓冲区的最大值,单位:kbytes;
-s size: 设置堆栈的最大值,单位:kbytes;
-S: 设置软件资源限制;
-t size: 设置CPU使用时间的最大上限,单位:seconds;
-v size: 设置虚拟内存的最大值.单位:kbytes;
注意:size的值不一定要求是数字,可以是unlimited,表示没有限制。
执行范例:
当你执行一个程序,发现Can’t open so many files类似的错误,则是因为你的程序打开的文件数超过系统默认的最大文件数。解决方案:
$ ulimit -n 20000 $ ulimit -a core file size (blocks, -c) unlimited data seg size (kbytes, -d) unlimited file size (blocks, -f) unlimited pending signals (-i) 1024 max locked memory (kbytes, -l) 32 max memory size (kbytes, -m) unlimited open files (-n) 20000 pipe size (512 bytes, -p) 8 POSIX message queues (bytes, -q) 819200 stack size (kbytes, -s) 10240 cpu time (seconds, -t) unlimited max user processes (-u) 16381 virtual memory (kbytes, -v) unlimited file locks (-x) unlimited
ulimit命令限制资源的使用,设置文件在:
/etc/security/limits.conf
比如:
xok_la hard cpu 1
xok_la hard fsize 50000
xok_la hard memlock 1000
xok_la hard nofile 50
xok_la hard nproc 50
这种方式限制是可以的,他是基于用户来限制的,可以限制内存,CPU占用时间,打开的文件数等等.前提是你要登陆到这个系统上.如果只是以这个用户来单独运行文件的话,就不行……
扩展阅读:
Linux下进程最大文件数为1024。
通常一个c,c++的可执行文件出错时,通过调core dump会快速定位到代码出错的位置。因此,你需要用ulimit -c xxx设置core文件最大值。默认为0。
转载于:https://blog.51cto.com/njqyu/404938