« »

  前几天公司网站打开超慢,有时候甚至出现该页无法显示,找了很多原因,后来查看Apache的logs,在Apache的logs/error.log中出现如下记录:

[Fri Mar 16 17:28:49 2007] [warn] (OS 64)指定的网络名不再可用。 : winnt_accept: Asynchronous AcceptEx failed.
[Fri Mar 16 17:28:49 2007] [warn] (OS 64)指定的网络名不再可用。 : winnt_accept: Asynchronous AcceptEx failed.
[Fri Mar 16 17:28:50 2007] [warn] (OS 64)指定的网络名不再可用。 : winnt_accept: Asynchronous AcceptEx failed.

  出现这个故障内存占用很大,导致网站访问极慢。

  找到的解决方法:

  Apache 关闭 AcceptEx() ,这个在Windows平台下适用

  方法是在 httpd.conf 内加入 Win32DisableAcceptEx

  Win32DisableAcceptEx 顾名思义就是在 Windows 下关掉 AcceptEx() 功能的指令。至於 AcceptEx() 这个东西是什么,可以参考 Apache 的官方网页:

http://httpd.apache.org/docs/2.0/mod/mpm_winnt.html

QUOTE:
AcceptEx() is a Microsoft WinSock v2 API that provides some performance improvements over the use of the BSD style accept() API in certain circumstances. Some popular Windows products, typically virus scanning or virtual private network packages, have bugs that interfere with the proper operation of AcceptEx(). If you encounter an error condition like:

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

you should use this directive to disable the use of AcceptEx().

  主要是说这 AcceptEx() 是 Microsoft WinSock v2 API 一组提升网络效率 API 中的指令。而且在 Windows 上似乎蛮有可能出问题的。

  注:可能为了效能还是预设为开啟 AcceptEx()

  如果无预警的发生问题,我猜可能是 Windows Update 或是防火墙、防毒软体更新了某些网路原件,造成 Microsoft WinSock v2 API 动作不正常,这时可以把这个功能先给关掉。

  依照官方说明 , Win32DisableAcceptEx 这个功能,只有 2.0.49 版以后的才可以使用,所以我猜测 AcceptEx() 这个指令大概也是 2.0.49 才会开始支援(目前最新的就是 2.0.49)。

  关掉 AcceptEx() 的方式只要在 httpd.conf 找到

ThreadsPerChild 250
MaxRequestsPerChild 0

  区段,加入 Win32DisableAcceptEx 就可以了。
  (# ThreadsPerChild:服务进程中工作线程常数;# MaxRequestsPerChild:服务进程允许的最大请求数)

ThreadsPerChild 250
MaxRequestsPerChild 0
Win32DisableAcceptEx (添加这一行)

  然后重新启动动 Apache,“指定的网络名不再可用”再也不出现了。

日志信息 »

该日志于2008-10-16 18:37由 5JUN 发表在电脑知识分类下, 你可以发表评论。除了可以将这个日志以保留源地址及作者的情况下引用到你的网站或博客,还可以通过RSS 2.0订阅这个日志的所有评论。

相关日志 »

Leave a Reply

:wink: :-| :-x :twisted: :) 8-O :( :roll: :-P :oops: :-o :mrgreen: :lol: :idea: :-D :evil: :cry: 8) :arrow: :-? :?: :!: