由Apache 500错误引出的临时文件问题分析解决

 更新时间:2014年07月25日 09:22:12   投稿:hebedich  
最近老是发觉centos下的php出现各种各样的问题,先是smarty大点就中断执行,然后,运行速度好像变慢,到今晚。。。,终于罢工了--500内部错误。

查看apache日志,发觉是mod_fcgid模块异常,提示"Connection reset by peer:mod_fcgid:error reading data from FastCGI server"、"Premature end of script headers:index.php"、"process /usr/... apache/cgi-bin exit(communication error, get unexpected signal 7",说白了就是php提前终止执行,没有返回header就退出。

我依据这些错误在网上搜索了很久,始终没有找到满意答案,甚至还被人误导,以为mod_fcgid模块配置的问题。

在没有找到解决方法之前,我一直在想,php最近虽然慢了点,但至少能运行,说明配置是没有问题;而且,如果现在执行phpinfo(),程序依然能够执行。我再次梳理出错规律,发觉include多的mvc框架就会提示500内部错误。其它简单的程序就能够运行。这说明什么?!说明php已经不能include文件了,为什么?只能是请求这些资源时动了临时文件,而临时文件没有多余空间了。

运行

df -h

发觉果然如此

Filesystem  Size  Used  Avail Use%  Mounted on
/dev/sda1  6.8G  6.5G  17M  100%  /
...

系统主目录/下已经爆掉了。

于是,查找大文件

find / -type f -size +300M

发觉php插件Xdebug产生了很多性能分析文件,而且都是以100M记。

/tmp/profiler/cachegrind.out.1336
/tmp/profiler/cachegrind.out.1329
....

于是修改php.ini,将分析文件存放在其它地方,或者干脆不保存。

# close xdebug profiler in php.ini
xdebug.profiler_enable = off

再删除xdebug性能分析目录和php var跟踪目录

rm -rf /tmp/profilter
rm -rf /tmp/trace

再次查看硬盘情况,发觉已使用为26%,剩余4.9G。

Filesystem  Size  Used  Avail Use%  Mounted on
/dev/sda1  6.8G  1.7G  4.9M  26%  /
...

甚至不用重启httpd服务器,刷新web,又正常运行了!!!

为免除后患,我们需要安装一个定时清理软件--tmpwatch,设置/etc/cron.daily/tmpwatch配置里面的定时时间

usr/sbin/tmpwatch "$flags" 30d /var/tmp

改为7d(必须以天为单位)

usr/sbin/tmpwatch "$flags" 7d /var/tmp

一个星期定时清理一次。

相关文章

  • crontab执行时间与系统时间不一致问题解决

    crontab执行时间与系统时间不一致问题解决

    这篇文章主要给大家介绍了关于crontab执行时间与系统时间不一致问题的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • Linux下使用SSH远程执行命令方法收集

    Linux下使用SSH远程执行命令方法收集

    这篇文章主要介绍了Linux下使用SSH远程执行命令方法收集,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • 详解Ubuntu/CentOS下Apache多站点配置

    详解Ubuntu/CentOS下Apache多站点配置

    本篇文章主要介绍了Ubuntu/CentOS下Apache多站点配置,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • CentOS SSH无密码登录的配置

    CentOS SSH无密码登录的配置

    本篇文章主要介绍了CentOS SSH无密码登录的配置,避免了繁琐的密码验证,有需要的朋友可以了解一下。
    2016-10-10
  • Centos7开机启动自己的脚本的方法

    Centos7开机启动自己的脚本的方法

    本篇文章主要介绍了Centos7开机启动自己的脚本的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-03-03
  • centos7.0之Lnmp和Lamp详细介绍

    centos7.0之Lnmp和Lamp详细介绍

    这篇文章主要介绍了centos7.0之Lnmp和Lamp详细介绍的相关资料,这里对Lnmp和Lamp安装和简单使用做简单说明及配置防火墙,需要的朋友可以参考下
    2016-11-11
  • 解决VScode配置远程调试Linux程序的问题

    解决VScode配置远程调试Linux程序的问题

    这篇文章主要介绍了VScode配置远程调试Linux程序及问题解决办法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • linux下图形界面和命令行界面的切换方式

    linux下图形界面和命令行界面的切换方式

    在Linux系统中,可以通过快捷键[CTRL]+[ALT]+F2切换到命令行界面,通过[CTRL]+[ALT]+F7切回图形界面,如果系统默认进入命令行,可使用startx命令启动图形界面,更改系统默认界面需在/etc/inittab文件中进行配置,这些操作帮助用户根据需求选择合适的工作环境
    2024-10-10
  • Ubuntu18.04通过源码安装Odoo14的教程

    Ubuntu18.04通过源码安装Odoo14的教程

    本系列文章针对Odoo 14版,从系统安装,开发环境配置,代码结构,主要功能升级,源码赏析,Anodoo对Odoo的关键扩展等角度,预先给大家介绍即将在2020年发布的这一最新版本
    2020-02-02
  • 在Linux中如何列出和删除Iptables防火墙规则

    在Linux中如何列出和删除Iptables防火墙规则

    当涉及到网络安全时,防火墙是一个至关重要的组成部分,Iptables是一种常用的防火墙解决方案,可以帮助管理员保护他们的系统免受恶意攻击,本文将详细介绍如何列出和删除Iptables防火墙规则,以帮助您更好地管理系统的安全性
    2023-06-06

最新评论