apache php 调优_记一次apache+php调优

近日手头拿到了一个调优问题,详细一看,发现是apache+php问题,问题的具体表现如下:

正常运行的服务常常停止响应, 一旦停止响应, 维护人员就不得己需要去重启apache服务

对php不熟,调查过程也顺便学习一下php的基本配置。

2015-3-11 调试

首先去服务器进程看了看,发现有一个 http.exe 在后台一直占用%50左右的 cpu,即使通过 Moniter 结束了服务,这个进程也依然坚挺,始终占用固定的CPU, 打开perfmon.exe,发现 内存换页频繁,且都是硬错误,估计就是那个进程导致的,直接结束之。 结果cpu一下子就下来了。

又研究了部分参数设置,尤其是 mpm_module 相关的设置

通过以下命令可以查看加载的模块

httpd -l

发现mpm_module的的加载情况和实际配置不符,windows系统中,其实只加载了后者,实际配置如下:

# 配置了mpm_winnt_module以后,mpm_prefork_module就不起作用了

# 可以通过 httpd -l查看当前加载的模块

StartServers 5

MinSpareServers 5

MaxSpareServers 10

MaxClients 256

MaxRequestsPerChild 500

# mpm_winnt_module 该多路处理模块(MPM)是Windows NT上的默认值。它使用一个单独的父进程产生一个单独的子进程,在这个子进程中轮流产生多个线程来处理请求。StartServers定义的进行启动

# ThreadsPerChild 200 启动的线程数,公司bbs平常都在20+,暂时这样配置节省内存资源

# MaxRequestsPerChild 10000 这个模式只启动两个进程(httpd.exe)一主一子,子进程执行10000个请求以后会被终止,然后另起一个

# Win32DisableAcceptEx Use accept() rather than AcceptEx() to accept network connections,

# 另外重启apache时候,先关闭,并且结束所有httpd.exe,再启动,不要直接restart,会遗留下httpd的进程不关

ThreadsPerChild 400

MaxRequestsPerChild 10000

Win32DisableAcceptEx

AcceptEx()是一个微软的WinSock2 API ,通过使用BSD风格的accept() API提供了性能改善。一些流行的Windows产品,比如防病毒软件或虚拟专用网络软件,会干扰AcceptEx()的正确操作。如果遇到类似于如下的错误:

[error] (730038)An operation was attempted on something that is not a socket.: winnt_accept: AcceptEx failed. Attempting to recover.

就需要使用这个指令来禁止使用AcceptEx() 。

对于windows操作系统,可以使用专用的mpm_winnt_module,来提高性能,但是参数配置要注意。

2015-3-18 调试

观察了几天,发现还是有问题,找错误日志去看了看,发现了一个问题

FATAL: erealloc(): Unable to allocate 98304 bytes

每次运行到一个阶段,apache就会出现无法回收内存的严重问题,这样一来,用不了多久就得重启了

经过调查,从apache的 bug 一路找过去,最后发现这个是php的一个 bug,但是都没有解决。。。

最后又找了一阵子,发现一个 论坛 中有讨论,找到一句靠谱的话

Looks like php related.

You are using outdated/legacy PHP 4 and Apache 2.0, not anymore supported for quite some time.

It is a known issue with a PHP before 5.3 that it has memory management and stability issues.

#The most common solution for this kinfd of errors was using PHP with Fast CGI (mod_fcgid). I do not know there is still somewhere a version for Apache 2.0.

Also I see also PHP warnings: Undefined variable: id_vue libelle_vue.

随后我找了一个php5.2.7稳定版进行升级,升级以后,做了简单的并发访问,没有打印异常。

继续观察观察

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值