LINUX系统打开的最大文件数限制

首先可以通过ulimit �Ca 命令来查看
如下:
Redhat 系统
[root@120lg_3 ut]# ulimit -a
core file size         (blocks, -c) 0
data seg size          (kbytes, -d) unlimited
file size              (blocks, -f) unlimited
max locked memory      (kbytes, -l) 4
max memory size        (kbytes, -m) unlimited
open files                    (-n) 1024
pipe size           (512 bytes, -p) 8
stack size             (kbytes, -s) 10240
cpu time              (seconds, -t) unlimited
max user processes             (-u) 7168
virtual memory         (kbytes, -v) unlimited
此处的1024是每个进程打开的最大文件数,对于系统的最大限制可以这样查看
[root@120lg_3 ut]# more /proc/sys/fs/file-max
157280
file-max是整机可以打开的fd数目,对确定的进程仍然是1024个,这个值定义在limits.h里:
#define NR_OPEN           1024
只有root可以用ulimit修改这个值,象这样:
su
ulimit    -n    8096
su    urname
runprog
solaris 系统
# ulimit -a
core file size         (blocks, -c) unlimited
data seg size          (kbytes, -d) unlimited
file size              (blocks, -f) unlimited
open files                    (-n) 256
pipe size           (512 bytes, -p) 10
stack size              (kbytes, -s) 8192
cpu time              (seconds, -t) unlimited
max user processes             (-u) 29995
virtual memory         (kbytes, -v) unlimited
HP-UX 系统
# ulimit -a
core file size         (blocks, -c) 2097151
data seg size          (kbytes, -d) 1048576
file size              (blocks, -f) unlimited
max memory size        (kbytes, -m) unlimited
open files                    (-n) 512
pipe size           (512 bytes, -p) 16
stack size             (kbytes, -s) 8192
cpu time              (seconds, -t) unlimited
max user processes             (-u) 257
virtual memory         (kbytes, -v) unlimited
以上的open files都是系统默认的初始值。
对于 solaris 可以通过 plimit PID 来取得该进程的一些限制信息,如
# plimit 1
1:       /sbin/init
   resource              current         maximum
time(seconds)          unlimited       unlimited
file(blocks)           unlimited       unlimited
data(kbytes)           unlimited       unlimited
stack(kbytes)          8192            unlimited
coredump(blocks)       unlimited       unlimited
nofiles(descriptors) 256             65536
vmemory(kbytes)        unlimited       unlimited
HP-UX 也可以通过 kctune 命令来查看限制信息,如
# kctune |grep maxfiles*
Tunable                     Value Expression Changes
maxfiles                      512 Default    
maxfiles_lim                 4096 Default     Immed
# kctune |grep nfile    
nfile                       16384 Default      Auto
注意:此处的maxfiles 为每个进程可以打开的最大文件数(软件系统限制)
此处的maxfiles_lim为每个进程可以打开的最大文件数(硬件系统限制)
也就是说你可以通过改变软件限制“maxfiles”的值然后从新编译内核来达到修改的目的,但是还会受到硬件最大上限的限制。
nfile则是表示所有进程打开的最大文件数的总数限制。

你可能感兴趣的:(linux,职场,休闲)