PHP / CentOS - failed to open stream: Too many open files


1,我刚开始以为是代码的问题,根据提示把出现打不开文件的地方给注释了,接着刷新页面仍然出现这种问题;可以排除代码的问题。

2,我开始怀疑是不是服务器空间小了,然后进入服务器查看服务器空间,还剩5G空间,然后我把一些日志文件给删除了,把一些以前备份没有用的也给删除了,刷新页面仍然出现这问题;

3,我开始百度,百度解释:打开流失败,打开太多的文件;进入服务器:查看ulimit -a 查看最大打开文件数,已经是最大值了open files (-n) 65535 ,而系统默认的是1024;

图片描述
4,然后我这边临时性解决的方案是,重启php和mysql,重新刷新页面,没有再出现这种情况了。但是根本性问题还是没有解决。

php centos6.5

ajmd9 9 years, 6 months ago

如果你的网站确实不是流量特别大,大部分情况下应该还是你的配置问题。虽然你用 ulimit -a 命令查出来 open files 的值是 65535 ,但那是针对当前用户 root 的。一般的web进程的所属用户是 www-root 。你可以切换到 www-root 来看看 open files

如果你用的php-fpm,打开 php-fpm.conf ,加上一行这个再重启就可以了


 rlimit_files = 65535

Mikan answered 9 years, 6 months ago

Your Answer