IIS 500内部错误之解决办法(com+应用程序错误)[转]
2009-02-03 16:56
以下是解决的步骤,声明,并不通用,朋友们可以先试试,如果不行请往下看。
1、启动MSDTC服务
查看服务“Distributed Transaction Coordinator”是否启动,如果并没启动,启动之。无法启动的按以下方法:
(1)删除
注册表中的键:
? HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MSDTC
? HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSDTC
? HKEY_CLASSES_ROOT\CID
(2)运行CMD,停止MSDTC服务:net stop msdtc
(3)卸载MSDTC服务:msdtc -uninstall
(4)重新安装MSDTC服务:msdtc -install
(5)启动MSDTC服务:net start msdtc
2、更改IWAM_MYSERVER账号的密码。
右键“我的电脑”——“管理”——“本地用户和组”——“用户”——右键“IWAM_MYSERVER”——“设置密码”——输入“123456”(例)
3、同步IIS metabase中IWAM_MYSERVER账号的密码
打开命令行,(“开始”——“运行”——“cmd”),键入命令:
cd c:\Inetpub\AdminScripts(回车)
adsutil SET w3svc/WAMUserPass "123456"(回车)
修改成功后,系统会有如下提示:
WAMUserPass: (String) "**********"
4、同步COM+应用程序所用的IWAM_MYSERVER的密码
使用IWAM账号同步脚本synciwam.vbs
命令行下键入:synciwam.vbs -v(c:\Inetpub\AdminScripts目录)
完成上述应该可以了,去试验一下吧,祝好运。下面是本人在
网络上转的文章 ,也许更详细些。
==================================
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内部错误就这样产生了。
解决办法
手工同步账号
知道了导致HTTP 500内部错误的原因,解决起来就比较简单了,那就是人工同步IWAM账号在Active Directory、IIS metabase数据库和COM+应用程序中的密码。
具体操作分三步,均需要以管理员身份登录计算机以提供足够的操作权限(IWAM账号以IWAM_MYSERVER为例)。
(一)更改Active Directory中IWAM_MYSERVER账号的密码
因IWAM账号的密码由系统控制,随机产生,我们并不知道是什么