ulimit详解

  • 概述

  ulimit 是bash内键命令,它具有一套参数集,用于为由它生成的 shell 进程及其子进程的资源使用设置限制。可以用help ulimit 查询手册。


  • help手册

[root@web ~]# help ulimit
ulimit: ulimit [-SHacdefilmnpqrstuvx] [limit]
    Options:
      -S        use the `soft' resource limit
      -H        use the `hard' resource limit
      -a        all current limits are reported
      -b        the socket buffer size
      -c        the maximum size of core files created
      -d        the maximum size of a process's data segment
      -e        the maximum scheduling priority (`nice')
      -f        the maximum size of files written by the shell and its children
      -i        the maximum number of pending signals
      -l        the maximum size a process may lock into memory
      -m        the maximum resident set size
      -n        the maximum number of open file descriptors
      -p        the pipe buffer size
      -q        the maximum number of bytes in POSIX message queues
      -r        the maximum real-time scheduling priority
      -s        the maximum stack size
      -t        the maximum amount of cpu time in seconds
      -u        the maximum number of user processes
      -v        the size of virtual memory
      -x        the maximum number of file locks
  • 选项详解

  我们可以通过ulimit -a来查看当前系统所有的限定值。

[root@web ~]# 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) 3701
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) 10240
cpu time               (seconds, -t) unlimited
max user processes              (-u) 3701
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited
  • 选项实例


选项
例子
S ulimit -Hs 64 限制硬资源,线程栈大小为64K
H ulimit -Sn 32 限制软资源,32个文件描述符
a ulimit -a 显示当前所有limit信息
c ulimit -c unlimited 对生成的core文件大小不进行限制
d ulimit -d unlimited 对生成的数据段大小不进行限制
f ulimit -f 2048 限制进程可创建的最大文件大小为2048 blocks
l ulimit -l 32 限制最大可加锁内存大小为 kbytes
m ulimit -m unlimited 对最大内存不进行限制
n ulimit -n 128 限制最大可使用128个文件描述符
p ulimit -p 512 限制管道缓冲区的大小为512 kbytes
s ulimit -s 512 限制线程栈的大小为512 kbytes
t ulimit -t unlimited 对最大的cpu占用时间不进行限制
u ulimit -u 64 限制用户最多可以使用64个进程
v ulimit -v 200000 限制最大可用的虚拟内存为 200000 kbytes 



  • ulimit的使用方式

  1. 在用户的启动脚本里

     如果用户使用的是 bash,就可以在用户的目录下的 .bashrc 文件中,加入 ulimit �C u 64,来限制用户最多可以使用 64 个进程。此外,可以在与 .bashrc 功能相当的启动脚本中加入 ulimt。

2.  应用程序的启动脚本中

  编写个简单的启动脚本,startmyapp

#/bin/sh
ulimit -n 512
myapp.sh

以这个startmyapp启动myapp.sh时,myapp.sh这个脚本打开的文件句柄数不超过512个。

3. 直接控制台输入

[root@web ~]# ulimit -p 256

限制管道缓冲区为256k



  • ulimit使用范围

  ulimit 作为对资源使用限制的一种工作,是有其作用范围的。那么,它限制的对象是单个用户,单个进程,还是整个系统呢?事实上,ulimit 限制的是当前 shell 进程以及其派生的子进程。

  举例来说,如果用户同时运行了两个 shell 终端进程,只在其中一个环境中执行了 ulimit �C s 100,则该 shell 进程里创建文件的大小收到相应的限制,而同时另一个 shell 终端包括其上运行的子程序都不会受其影响。



  • 相关配置文件

  通过修改系统的 /etc/security/limits 配置文件。该文件不仅能限制指定用户的资源使用,还能限制指定组的资源使用。该文件的每一行都是对限定的一个描述,格式如下:

<domain>      <type>  <item>         <value>
#

#*               soft    core            0
*               hard    nofile          100
名称 含义
domain 表示用户或者组的名字,还可以使用 * 作为通配符。
type 可以有两个值,soft 和 hard。
item 则表示需要限定的资源,可以有很多候选值,如 stack,cpu,nofile 等等,分别表示最大的堆栈大小,占用的 cpu 时间,以及打开的文件数。
value 对应相应的值

上述配置语句限定了任意用户所能创建的最大文件数是 100。

注意

很多应用需要对整个系统的资源使用做一个总的限制,这时候我们需要修改 /proc 下的配置文件。





你可能感兴趣的:(ulimit,系统调优)