[MySQL FAQ]系列 -- Too many open files
错误信息如下:
..... 070813 13:10:17 [ERROR] /usr/local/mysql/bin/mysqld: Can't open file: './yejr/access.frm' (errno: 24) 070813 13:10:17 [ERROR] /usr/local/mysql/bin/mysqld: Can't open file: './yejr/accesslog.frm' (errno: 24) ...... 070813 13:10:17 [ERROR] Error in accept: Too many open files ....
注意到, 系统错误代号是 24, 用 perror 来查看一下具体的错误信息是什么:
[root@yejr]# /usr/local/mysql/bin/perror 24 OS error code 24: Too many open files
原来是打开文件太多了, 好办.用sysctl来调整一下就好了:
[root@yejr]# sysctl -w fs.file-max=43621 [root@yejr]# sysctl -a | grep fs.file-max fs.file-max = 43621
FreeBSD 下也用sysctl来调整:
[root@yejr]# sysctl -w kern.maxfiles=123280 [root@yejr]# sysctl -a | grep kern.maxfiles kern.maxfiles = 123280
最后, 还有最重要的一点是, 修改 mysqld 的配置文件 my.cnf, 增加如下一行:
open_files_limit = 4096 #根据自己的情况适当调整,系统默认值是 # max_connections*5 或 max_connections + table_cache*2
然后, 以root身份重新启动 mysqld. 在这里, 尽管 my.cnf 中指定的运行用户不是root, 一样可以以root身份来启动mysqld, 否则 open_files_limit 选项无法生效, 因为内核限制了普通用户的最多打开文件数.
评论
xlight
周一, 2007/08/20 - 16:39
Permalink
还真快 -------------------
还真快
----------------------------------
远在天边,近在眼前。幸会幸会,啥?你要走?
游客1 (未验证)
周三, 2007/08/29 - 14:27
Permalink
这个不用root也可以低~
这个不用root也可以低~~.
yejr
周三, 2007/08/29 - 17:37
Permalink
你用一下我看看? MySQ
你用一下我看看?
MySQL方案、培训、支持
MySQL 用户组
mysqlkumao (未验证)
周日, 2008/02/17 - 16:32
Permalink
真精彩!
真精彩!