首页 > 解决方案 > 通过 HTTPS 的 IIS 503“服务不可用”,HTTP 工作正常

问题描述

我有一个在 IIS 7.5 中运行的网站。当我通过 HTTP 访问该站点时,一切正常。当我通过 HTTPS 运行站点时,我立即收到 HTTP 503 错误“服务不可用”。站点上使用的自生成/自签名的 SSL 证书。

以下是我看到的适用于此场景的类似问题的解决方案:

标签: .nethttpiishttpsiis-7.5

解决方案


此博客上的评论者 Chad Cothern 给出了答案,并通过 BretB 链接到了此 Microsoft 博客。在这种情况下,问题是端口 443 上的所有内容都已被保留,并且“阻止 W3SVC 在尝试启动站点时获得监听端口 80 的权限。此外,在 IIS 中运行的应用程序不需要显式保留即可运行,如果非 IIS 应用程序想要使用 HTTP 来侦听请求,则它们必须保留 URL 命名空间。”

以下是确定这是否是问题以及如何解决的步骤:

  1. 打开命令提示符
  2. 跑:netsh http show urlacl url=https://+:443/
  3. 如果有什么东西,那么这就是你的问题。端口 443 已完全保留并阻止 IIS。
    • 如果需要为在 IIS 之外运行的应用程序保留 443 端口,则需要使用应用程序路径注册(即http://+:443/appPath
    • 如果那里什么都没有,那么这可能不是问题。无需继续。
  4. 跑:netsh http delete urlacl https://+:443/
  5. 再次尝试运行您的应用程序。

请注意,您还可以使用此方法检查端口 80 或任何其他端口。例如,如果保留端口 80 而未保留端口 443,则通过 HTTPS 的站点可以工作,而 HTTP 则不能。

显示上述命令和结果


推荐阅读