Linux 下ulimit命令, limits.conf 和file-max对比介绍
2013-06-21 17:07
447 查看
在Linux下用ulimit命令可以调整可以打开的最大文件数目,而编辑/etc/security/limit.conf和 修改/proc/sys/fs/file-max也能调整可以打开的最大文件数目,那它们之间有什么区别呢?本文试图对此进行说明。
首先要说明的是, /etc/security/limit.conf文件和/proc/sys/fs/file-max只有超级用户才能更改。普通用户只能使用ulimit -n 命令。
/proc/sys/fs/file-max表示kernel中维护的最大文件描述符数目。不管这个系统上有多少了用户登录,有多少个进程在运行,所有打开的文件数目总合都不能超过这个数字。
/etc/security/limit.conf用来设置每个用户最多可以打开的文件数目。
普通用户可以通过ulimit -n 命令来设置hard limit(只能改小) 和soft limit(可以改大和改小).
把上面的内容概括成3条就是:
(1)/proc/sys/fs/file-max 控制整个系统。
(2)/etc/security/limit.conf控制每个用户, 且受到(1)的限制。
(3)ulimit -n用来控制shell及其子进程, 且受到(2)的限制。
下面举个例子进行说明。
使用root在/etc/security/limit.conf中添加下面一行
John soft nofile 8192
John hard nofile 10000
那么John在登陆以后,打开一个shell, 分别察看soft limit 和hard limit。
John@ubuntu:~$ ulimit -Sn
8192
John@ubuntu:~$ ulimit -Hn
10000
可以看到,这个结果正是我们在/etc/security/limit.conf设置的值。
下面用limit -n命令修改soft limit然后找出可以打开的最大文件描述符数目。
John@ubuntu:~/test$ ulimit -Sn 1024
John@ubuntu:~/test$ ulimit -Sn
1024
John@ubuntu:~/test$ ulimit -Hn
10000
John@ubuntu:~/test$ ./a.out
max_fd.c,main,17 successful to open 1021 files
如果john登陆以后打开了多个shell,而且多个shell同时打开文件,那么是应该是每个shell打开的最大文件数目不应该超过ulimit -Sn,而所有shell打开的文件数目总合
可以超过/etc/security/limit.conf设置的soft limit, 但是不能超过/proc/sys/fs/file-max. 我们用下面的一段代码来验证.
john@ubuntu:~/test$ ulimit -Sn
8192
john@ubuntu:~/test$ ulimit -Hn
10000
只在一个shell上执行这段代码,输出结果:
John@ubuntu:~/test$ ./a.out
max_fd.c,main,17 successful to open 8189 files
我们来验证所有shell打开的文件数目总合可以超过/etc/security/limit.conf设置的soft limit。
在两个shell上同时执行这段代码,两个shell都输出下面的信息:
john@ubuntu:~/test$ ./a.out
max_fd.c,main,17 successful to open 8189 files
最后我们要验证所有shell打开的文件数目总合不能超过/proc/sys/fs/file-max。
首先用root用户设置file-max:
echo 28000>/proc/sys/fs/file-max
在3个shell上把limit设置为10000.
john@ubuntu:~/test$ ulimit -n 10000
john@ubuntu:~/test$ ulimit -n
10000
在3个shell上执行测试代码:
john@ubuntu:~/test$ ./a.out //第一个shell
max_fd.c,main,17 successful to open 9997 files
john@ubuntu:~/test$ ./a.out //第二个shell
max_fd.c,main,17 successful to open 9997 files
john@ubuntu:~/test$ ./a.out //第三个shell
max_fd.c,main,17 successful to open 3595 files
总数不足28000,猜测是因为那些文件描述符已经被kernel或者别的进程占用了。
首先要说明的是, /etc/security/limit.conf文件和/proc/sys/fs/file-max只有超级用户才能更改。普通用户只能使用ulimit -n 命令。
/proc/sys/fs/file-max表示kernel中维护的最大文件描述符数目。不管这个系统上有多少了用户登录,有多少个进程在运行,所有打开的文件数目总合都不能超过这个数字。
/etc/security/limit.conf用来设置每个用户最多可以打开的文件数目。
普通用户可以通过ulimit -n 命令来设置hard limit(只能改小) 和soft limit(可以改大和改小).
把上面的内容概括成3条就是:
(1)/proc/sys/fs/file-max 控制整个系统。
(2)/etc/security/limit.conf控制每个用户, 且受到(1)的限制。
(3)ulimit -n用来控制shell及其子进程, 且受到(2)的限制。
下面举个例子进行说明。
使用root在/etc/security/limit.conf中添加下面一行
John soft nofile 8192
John hard nofile 10000
那么John在登陆以后,打开一个shell, 分别察看soft limit 和hard limit。
John@ubuntu:~$ ulimit -Sn
8192
John@ubuntu:~$ ulimit -Hn
10000
可以看到,这个结果正是我们在/etc/security/limit.conf设置的值。
#include <stdlib.h> #include <stdio.h> #define NUM 800000U int fd_array[NUM] = {0}; int main(int argc, char * argv[]) { int fd_num = 0; while(fd_num < NUM) { fd_array[fd_num] = open("testfd.txt","w"); if (fd_array[fd_num] < 0) { break; } fd_num++; } printf("\n%s,%s,%d successful to open %d files\n", __FILE__,__FUNCTION__,__LINE__, fd_num); sleep(6); int i = 0; while(i < fd_num) { fd_array[i] = 0; close(fd_array[i]); i++; } return 0; }
下面用limit -n命令修改soft limit然后找出可以打开的最大文件描述符数目。
John@ubuntu:~/test$ ulimit -Sn 1024
John@ubuntu:~/test$ ulimit -Sn
1024
John@ubuntu:~/test$ ulimit -Hn
10000
John@ubuntu:~/test$ ./a.out
max_fd.c,main,17 successful to open 1021 files
如果john登陆以后打开了多个shell,而且多个shell同时打开文件,那么是应该是每个shell打开的最大文件数目不应该超过ulimit -Sn,而所有shell打开的文件数目总合
可以超过/etc/security/limit.conf设置的soft limit, 但是不能超过/proc/sys/fs/file-max. 我们用下面的一段代码来验证.
john@ubuntu:~/test$ ulimit -Sn
8192
john@ubuntu:~/test$ ulimit -Hn
10000
只在一个shell上执行这段代码,输出结果:
John@ubuntu:~/test$ ./a.out
max_fd.c,main,17 successful to open 8189 files
我们来验证所有shell打开的文件数目总合可以超过/etc/security/limit.conf设置的soft limit。
在两个shell上同时执行这段代码,两个shell都输出下面的信息:
john@ubuntu:~/test$ ./a.out
max_fd.c,main,17 successful to open 8189 files
最后我们要验证所有shell打开的文件数目总合不能超过/proc/sys/fs/file-max。
首先用root用户设置file-max:
echo 28000>/proc/sys/fs/file-max
在3个shell上把limit设置为10000.
john@ubuntu:~/test$ ulimit -n 10000
john@ubuntu:~/test$ ulimit -n
10000
在3个shell上执行测试代码:
john@ubuntu:~/test$ ./a.out //第一个shell
max_fd.c,main,17 successful to open 9997 files
john@ubuntu:~/test$ ./a.out //第二个shell
max_fd.c,main,17 successful to open 9997 files
john@ubuntu:~/test$ ./a.out //第三个shell
max_fd.c,main,17 successful to open 3595 files
总数不足28000,猜测是因为那些文件描述符已经被kernel或者别的进程占用了。
相关文章推荐
- linux /proc/sys/fs/file-nr /proc/sys/fs/file-max /etc/security/limits.conf 三者的关联
- 使用ulimit命令和limits.conf限制系统资源的利用
- 使用ulimit命令和limits.conf限制系统资源的利用
- Linux下ulimit和/etc/security/limits.conf的区别及使用注意
- 使用ulimit命令和limits.conf限制系统资源的利用
- Linux 重命名命令自制详细介绍
- linux命令之 df file fsck fuser
- Linux patch命令举例介绍
- When the nofile is set to unlimited in /etc/security/limits.conf file the user cannot login
- 介绍一个在线的Linux,没有安装Linux或者虚拟机不喜欢用的童鞋可以简单的用这个jslinux测试各种命令
- Linux学习笔记——wc命令和file命令
- linux几个常用命令的介绍
- 浅谈Linux下各种压缩 解压命令和压缩比率对比
- 12个Linux进程管理命令介绍
- Linux命令 - ulimit
- Linux 查看磁盘分区、文件系统、使用情况的命令和相关工具介绍
- tempfile命令_Linux tempfile 命令用法详解:shell中给临时文件命名
- Linux 格式化分区 报错Could not stat --- No such file or directory 和 partprobe 命令
- linux下configure命令详细介绍
- file-max与ulimit的关系与差别