linux系统级别的能够打开的文件句柄的数file-max命令

本文详细介绍了Linux系统中的文件句柄管理机制,包括系统级的file-max配置与进程级的ulimit设置。探讨了如何调整这些参数以解决Too many open files错误,并分析了设置不当可能带来的内存占用问题。
 
简单的说, max-file表示系统级别的能够打开的文件句柄的数量, 而ulimit -n控制进程级别能够打开的文件句柄的数量.

man 5 proc, 找到file-max的解释:
file-max中指定了系统范围内所有进程可打开的文件句柄的数量限制(系统级别, kernel-level). (The value in file-max denotes the maximum number of file handles that the Linux kernel will allocate).当收到”Too many open files in system”这样的错误消息时, 就应该曾加这个值了.

# cat /proc/sys/fs/file-max
185230
# echo 100000 > /proc/sys/fs/file-max

或者
# echo ""fs.file-max=65535" >> /etc/sysctl.conf
# sysctl -p

The kernel constant NR_OPEN imposes an upper limit on the value that may be placed in file-max. (这句啥子意思? 没太明白)

对于2.2的内核, 还需要考虑inode-max, 一般inode-max设置为file-max的4倍. 对于2.4及以后的内核, 没有inode-max这个文件了.

file-nr 可以查看系统中当前打开的文件句柄的数量. 他里面包括3个数字: 第一个表示已经分配了的文件描述符数量, 第二个表示空闲的文件句柄数量, 第三个表示能够打开文件句柄的最大值(跟file-max一致). 内核会动态的分配文件句柄, 但是不会再次释放他们(这个可能不适应最新的内核了, 在我的file-nr中看到第二列一直为0, 第一列有增有减)

man bash, 找到说明ulimit的那一节:
提供对shell及其启动的进程的可用资源(包括文件句柄, 进程数量, core文件大小等)的控制. 这是进程级别的, 也就是说系统中某个session及其启动的每个进程能打开多少个文件描述符, 能fork出多少个子进程等…

当达到上限时, 会报错”Too many open files”或者遇上Socket/File: Can’t open so many files等

另外需要注意的是, 每种资源都有相关的软硬限制, 软限制是内核强加给相应资源的限制值,硬限制是软限制的最大值. 非授权调用进程只可以将其软限制指定为0~硬限制范围中的某个值,同时能不可逆转地降低其硬限制.授权进程可以任意改变其软硬限 制.RLIM_INFINITY的值表示不对资源限制.

分别使用-H和-S选项来指定需要对资源是做硬限制/软限制的设置. 如果都不指定, 硬限制和软限制同时设置.

打印资源的限制值, 如果不明确指定-H, 打印的是-S

要改apache的ulimit, 可以在 /usr/sbin/apachectl 这个脚本中修改 ULIMIT_MAX_FILES 这个值

可打开文件句柄数设置的太大, 有那些危害:
If the file descriptors are tcp sockets, etc, then you risk using up a large amount of memory for the socket buffers and other kernel objects; this memory is not going to be swappable.

另外要记得的是socket connection也是文件.
### 查看 Linux 系统中最大文件句柄的方法 在 Linux 系统中,可以通过多种方式查看系统级别的最大文件句柄(即系统范围内允许打开的最大文件描述符量)以及单个进程的文件句柄限制。 #### 1. 查看系统最大文件句柄系统级限制) 系统级别的最大文件句柄通常由内核参 `fs.file-max` 控制。可以通过以下命令查看当前系统的最大文件句柄: ```bash cat /proc/sys/fs/file-max ``` 该值表示系统可以同时打开的最大文件句柄量。如果所有进程的文件句柄总和超过这个值,系统将无法分配更多的文件描述符[^2]。 #### 2. 查看当前系统已使用的文件句柄 要查看当前系统中已经使用的文件句柄量,可以使用如下命令: ```bash cat /proc/sys/fs/file-nr ``` 该命令会输出三个字: - 第一个字:当前已分配的文件句柄- 第二个字:已分配但尚未使用的文件句柄- 第三个字:系统最大文件句柄(即 `file-max` 的值)。 #### 3. 查看单个进程的文件句柄限制 每个进程也有自己的文件句柄限制,通常分为软限制(soft limit)和硬限制(hard limit)。可以使用 `ulimit` 命令查看当前 shell 会话的限制: - 查看软限制: ```bash ulimit -n ``` - 查看硬限制: ```bash ulimit -Hn ``` 要查看某个特定进程的文件句柄限制,可以查看 `/proc/<pid>/limits` 文件,例如: ```bash cat /proc/1234/limits | grep "Max open files" ``` 其中 `1234` 是进程的 PID。 #### 4. 查看系统中所有进程打开文件句柄 可以使用 `lsof` 工具统计系统中所有进程打开文件句柄: ```bash lsof | wc -l ``` 此命令会列出所有打开文件,并通过 `wc -l` 统计行,大致反映当前系统打开文件句柄量。 --- ### 永久修改文件句柄限制 如果需要永久修改文件句柄限制,需修改以下两个配置文件: 1. 系统级限制:编辑 `/etc/sysctl.conf` 文件,添加或修改如下行: ```bash fs.file-max = 100000 ``` 然后执行: ```bash sysctl -p ``` 2. 用户或进程级限制:编辑 `/etc/security/limits.conf` 文件,添加如下内容以设置软限制和硬限制: ```bash * soft nofile 10240 * hard nofile 20480 ``` 此外,对于系统级服务,可能还需要修改 `/etc/pam.d/common-session` 文件,添加: ```bash session required pam_limits.so ``` ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值