日期:2014-05-16  浏览次数:21525 次

IIS HTTP 500 出现内部服务器错误解决方法

原文地址:http://www.lizhongda.net/info/news_detail.asp?newsid=528

?

第一种解决办法:

1. 运行:regsvr32 %windir%/system32/vbscript.dll
2. 运行:msdtc -resetlog
3. 重新安装IIS


注释:
1. 微软只随IIS5提供了一个管理脚本adsutil.vbs,这个脚本位于

C:\inetpub\adminscripts子目录下,首先注册vbscript.dll。
2. msdtc.exe是微软分布式传输协调程序。该进程调用系统Microsoft Personal

Web Server和Microsoft SQL Server,该服务用于管理多个服务器,必须确保该

服务正常启动。
(1)控制面板->管理工具->组件服务

(2)找到“组件服务”->“计算机”->“我的电脑”->“COM+应用程序”->

“IIS Out-Of-Process Pooled Applications”

?

?

3. 如果找不到“IIS Out-Of-Process Pooled Applications”,或在点击不能打

开“COM+应用程序”,执行完“msdtc -resetlog”后,重新安装IIS即可。

IIS500错误,是因为微软的一个BUG所造成的。下面是解决办法:

主要是由于IWAM账号(在我的计算机即是IWAM_MYSERVER账号)的密码错误造成了

HTTP 500内部错误。

在详细分析HTTP500内部错误产生的原因之前,先对IWAM账号进行一下简要的介绍

:IWAM账号是安装IIS5时系统自动建立的一个内置账号,主要用于启动进程之外

的应用程序的Internet信息服务。IWAM账号的名字会根据每台计算机NETBIOS名字

的不同而有所不同,通用的格式是 IWAM_MACHINE,即由“IWAM”前缀、连接线“

_”加上计算机的NETBIOS名字组成。我的计算机的NETBIOS名字是 MYSERVER,因

此我的计算机上IWAM账号的名字就是IWAM_MYSERVER,这一点与IIS匿名账号

ISUR_MACHINE的命名方式非常相似。

IWAM账号建立后被Active Directory、IIS metabase数据库和COM+应用程序三方

共同使用,账号密码被三方分别保存,并由操作系统负责这三方保存的IWAM密码

的同步工作。按常理说,由操作系统负责的工作我们大可放心,不必担心出错,

但不知是BUG还是其它什么原因,系统的对IWAM账号的密码同步工作有时会失败,

使三方IWAM账号所用密码不统一。当IIS或COM+应用程序使用错误IWAM的密码登录

系统,启动IIS Out-Of-Process Pooled Applications时,系统会因密码错误而

拒绝这一请求,导致IIS Out-Of-Process Pooled Applications启动失败,也就

是我们在ID10004错误事件中看到的“不能运行服务器{3D14228D-FBE1-11D0-

995D- 00C04FD919C1} ”(这里{3D14228D-FBE1-11D0-995D-00C04FD919C1} 是

IIS Out-Of-Process Pooled Applications的KEY),不能转入IIS5应用程序,

HTTP 500内部错误就这样产生了。

?