报错:too many open files处理

前言
在做压力测试的时候,可能会经常报错:too many open files
因此我们有两种修改方式:临时修改、永久修改
linux 默认打开文件数linux 默认打开文件数为1024个,通过ulimit -a 可以查看open files

实验环境
LSB Version:    :base-4.0-amd64:base-4.0-noarch:core-4.0-amd64:core-4.0-noarch:graphics-4.0-amd64:graphics-4.0-noarch:printing-4.0-amd64:printing-4.0-noarch
Distributor ID: CentOS
Description:    CentOS release 6.7 (Final)
Release:        6.7
Codename:       Final
临时修改
修改这个限制可以使用ulimt -SHn 65536

永久修改
1. /etc/pam.d/login 添加pam_limits.so (有时候系统默认添加,也可以写so的绝对路径)
session    required     pam_limits.so

2. /etc/security/limits.conf 添加
* soft nofile 65536
* hard nofile 65536
语法如下:www - nofile 1006154
www 是一个用户,如果是想所有用户生效的话换成 * ,设置的数值与硬件配置有关,别设置太大了。

3. 修改 /etc/rc.local 添加
echo 8061540 > /proc/sys/fs/file-max
(此处的数据按照您实际需要调节)
此法解决的实际问题是:在高负载下squid,mysql 会发生 打开的文件数超过系统的进程限制,造成系统瓶颈。

注意
这个当中的硬限制是实际的限制。
而软限制,是warnning限制,只会做出warning。
其实ulimit命令本身就有分软硬设置,加-H就是硬,加-S就是软。
默认显示的是软限制,如果运行ulimit命令修改的时候没有加上的话,就是两个参数一起改变。

你可能感兴趣的:(报错:too many open files处理)