PHP自写程序,w3wp.exe长期100%。结束后5分钟内就又会上来。求各种可能性错误

麻烦各位把各种可能性和解决方案都说一下。答对加分~
本机测试无论访问什么页面都是正常的,开启时有CPU占用完成后归0。服务器上CPU就只升不降了。
另外本机是winxp+apache+mysql+php
服务器是win2003+iis+mysql+php
最新回答
゛﹏花凋为谁祭

2024-09-17 13:20:36

w3wp.exe是IIS的一个进程,Apache没有w3wp.exe这个进程,所以本机参试都是正常的。

可能的原因:1、程序存在死循环;2、没有分页或分页程序有问题;3、数据库有问题。

更详细的判定是哪个网站的应用程序池的问题,可以用下面的判定方法:
1 在任务管理器中增加显示 pid 字段。就可以看到占用内存或者 cpu 最高的进程 pid !
2 在命令提示符下运行 iisapp -a。注意,第一次运行,会提示没有js支持,点击确定。然后再次运行就可以了。这样就可以看到 pid 对应的应用程序池。
3 到 iis 中察看该应用程序池对应的网站就可以了!然后真对站点排除错误!(如果运行后出现 error - no no results 这样的提示,说明你的站点没有开启或还没有被访问过!)

解决方法:
1 尝试删除系统路径\System32\Logfiles\W3SVC1 下当天的错误日志文件,如:ex090404.log,然后重新启动IIS,等待一段时间,看看有没有问题。
注:有时非法重启或者写入日志错误都有可能造成 w3wp.exe 进程锁死。

2 设置应用程序池的CPU监视,不超过25%,每分钟刷新,超过限制时自动关闭。
注:此方法只能用来做为测试,在真正的环境下,这个可能会引起网站时好时坏。不推荐长期使用。

3 检查你的程序代码,或者网页调用,程序没写好或者有死循环,是最容易造成 w3wp.exe 锁死的。
注:方法是先停止IIS,再删除当天的网站日志(系统路径\System32\Logfiles\对应的网站目录下),然后开启IIS,等待CPU高占用的出现,这时在1分钟内打开新建的日志文件,按出现时间,对应检查里面所罗列出现的文件,检查代码是否有问题。

4 检查数据库完整性和 ODBC 的有效性。
注:有些写得不好的 ASP 程序,在访问数据库无法做到容错性,所以有些时候数据库损坏或者 ODBC 传送数据不正常,都有可能造成多次强制查询,从而体现为 w3wp.exe 高 CPU 占用。

5 检查文件的权限。
注:不要奇怪,某些时候真的出现这种事情,一个文件无法写入或者无法读取,都会引起很大的问题。

我使用的解决办法:根据目前所使用的方法,启用“应用程序池”的进程回收。所谓的“CPU监视--停止”方法实际上不是很稳定,在windows2003+php下很容易导致“PHP has encountered an Access Violation at 7C95C853”的错误。同时关闭“启用快速失败保护”。
舀一瓢月色

2024-09-17 11:07:36

1.你写的脚本代码有 循环体没有跳出循环!直到web容器解析,超时而限定!
2.环境 搭建不当,环境文件被注入(这个很少有)
看不见的坚强

2024-09-17 16:12:04

我的服务器出了开发语言和你不一样,其他都一样。
我也遇到这个问题,不过没有你的那么厉害,可能原因不一样~
我的解决办法就是:使用应用连接池对IIS中的程序分别进行管理。