我有一个在IIS 7.5中运行的网站。当我通过HTTP访问该网站时,一切正常。当我通过HTTPS运行网站时,我立即收到HTTP 503错误"服务不可用"。网站上使用的SSL证书是自生成/自签名的。
以下是针对类似问题的解决方案,不适用于此方案:
答案 0 :(得分:8)
评论者Chad Cothern this blog得到了答案,并与BretB的this Microsoft Blog相关联。在这种情况下的问题是端口443上的所有内容都已被保留,并且"阻止W3SVC在尝试启动站点时获得侦听端口80的权限。此外,在IIS中运行的应用程序不需要显式保留即可运行,只有非IIS应用程序必须保留URL命名空间才能使用HTTP来侦听请求。"
以下是确定这是否是问题以及如何解决的步骤:
netsh http show urlacl url=https://+:443/
netsh http delete urlacl https://+:443/
请注意,您还可以使用此方法检查端口80或任何其他端口。例如,如果保留端口80而不保留443,那么通过HTTPS的站点将起作用,而HTTP则不起作用。
答案 1 :(得分:0)
当我在 Firefox 中检查控制台时,我遇到了类似的问题,通过 HTTPS、HTTP 获取“503“服务不可用””。 IIS 端的一切看起来都很好:SSL 证书、端口、站点运行等。我检查了调制解调器端口并意识到它需要启用端口 443 转发。只有端口 80 正在转发。但是因为我使用的是品牌 CenturyLink 的调制解调器,路由器的远程 GUI 管理正在使用该端口。
经验教训,如果您使用由 CenturyLink 或其他具有相同功能的公司品牌的路由器,也许同样适用。根据此链接中的答案 here,请执行以下操作:
常见错误:“定义的端口或端口范围正被另一个端口转发或应用程序规则使用。”
如果端口 443 已被路由器的远程 GUI 管理占用。释放该端口:
结论:
这解决了我在 HTTPS 上出现的“503“服务不可用”问题。需要启用端口 443。