首页 > 解决方案 > 在 docker 容器内运行 ASP.NET 4.6 应用程序 - 站点总是 404s

问题描述

我一直在尝试让 ASP.NET 4.6 应用程序在 Windows Docker 容器中运行,虽然让 IIS 与默认网站一起运行相当简单,但尝试让我的实际应用程序运行却被证明是困难的。每当我尝试加载我的应用程序时,它都会返回未找到的 404 文件。

一些背景知识:我尝试运行的应用程序必须安装在“默认网站”下,该应用程序和 SharedContent 应用程序都安装在 IIS 下,其中 SharedContent也是主应用程序下的子应用程序。

这导致 3 个调用在 IIS 下安装应用程序:

RUN ["powershell", "New-WebApplication -Name MvcCompaniesV2 -Site 'Default Web Site' -PhysicalPath C:/inetpub/wwwroot/MvcCompaniesV2 -ApplicationPool DefaultAppPool"]
RUN ["powershell", "New-WebApplication -Name SharedContent -Site 'Default Web Site' -PhysicalPath C:/inetpub/wwwroot/SharedContent -ApplicationPool DefaultAppPool"]
RUN ["powershell", "New-WebApplication -Name MvcCompaniesV2/SharedContent -Site 'Default Web Site' -PhysicalPath C:/inetpub/wwwroot/SharedContent -ApplicationPool DefaultAppPool"]

在摆弄了大约一整天后,我感到困惑。我设法安装了 IIS WebManagement 并可以使用 IIS 管理器连接到我的容器,我可以看到我的网站已正确配置,但有一个例外:从 IIS 设置中看不到来自 web.config 的连接字符串和重写规则,例如它无法访问配置文件。IIS 在 IIS APPPOOL\DefaultAppPool 用户下运行,并且 wwwroot 文件夹已将 IIS_IUSRS 添加到其 ACL(默认情况下)。

这是我的码头文件:

FROM microsoft/aspnet:4.7.2-windowsservercore-1803

EXPOSE 80
EXPOSE 8172

EXPOSE 4020 4021 4022 4023

# WebManagement stuff
RUN ["powershell.exe", "Install-WindowsFeature NET-Framework-45-ASPNET"]  
RUN ["powershell.exe", "Install-WindowsFeature Web-Asp-Net45"]
RUN ["powershell.exe", "Install-WindowsFeature web-mgmt-service"]

RUN ["powershell.exe", "Set-ItemProperty -Path 'HKLM:/SOFTWARE/Microsoft/WebManagement/Server' -Name 'EnableRemoteManagement' -Value 1"]
RUN ["powershell.exe", "set-service -Name WMSVC -StartupType Automatic"]
RUN ["powershell", "start-service WMSVC"]
RUN ["powershell", "net user patrick l0lp@ssw0rd /add"]
RUN ["powershell", "net localgroup administrators patrick /add"]

# Rewrite module
ADD https://download.microsoft.com/download/C/9/E/C9E8180D-4E51-40A6-A9BF-776990D8BCA9/rewrite_amd64.msi rewrite_amd64.msi
RUN ["powershell" , "Start-Process msiexec.exe -ArgumentList '/i', 'rewrite_amd64.msi', '/quiet', '/norestart' -NoNewWindow -Wait"]

# Remote debugger
RUN Invoke-WebRequest -OutFile c:\rtools_setup_x64.exe -Uri https://aka.ms/vs/15/release/RemoteTools.amd64ret.enu.exe;
RUN & 'c:\rtools_setup_x64.exe' /install /quiet

ADD bin C:/inetpub/wwwroot/

RUN ["powershell", "New-WebApplication -Name MvcCompaniesV2 -Site 'Default Web Site' -PhysicalPath C:/inetpub/wwwroot/MvcCompaniesV2 -ApplicationPool DefaultAppPool"]
RUN ["powershell", "New-WebApplication -Name SharedContent -Site 'Default Web Site' -PhysicalPath C:/inetpub/wwwroot/SharedContent -ApplicationPool DefaultAppPool"]
RUN ["powershell", "New-WebApplication -Name MvcCompaniesV2/SharedContent -Site 'Default Web Site' -PhysicalPath C:/inetpub/wwwroot/SharedContent -ApplicationPool DefaultAppPool"]

# ErrorPages mode to off
RUN ["powershell", "Set-WebConfigurationProperty -pspath 'MACHINE/WEBROOT' -filter 'system.web/customErrors' -name 'mode' -value 'Off'"]
RUN ["powershell", "Set-WebConfigurationProperty -filter 'system.webServer/httpErrors' -name 'errorMode' -value 'Detailed'"]
RUN ["Powershell", "Set-WebConfigurationProperty -pspath 'IIS:\Sites\Default Web Site\MvcCompaniesV2' -filter 'system.webServer/httpErrors' -name 'errorMode' -value 'Detailed'"]

ENTRYPOINT ["powershell", ""]

关于如何解决此问题的任何想法?可以看出,我将 IIS 和 .NET 的 errorPages 模式更改为详细但每当我打开 MvcCompaniesV2 时,我仍然得到非常有限的错误页面 ( https://imgur.com/a/jvj9r7f )。我有点想不出我可以尝试解决这个问题。

我尝试了一个示例 asp.net 页面(它直接在“默认网站”下运行,并且开箱即用)。

编辑:当我将远程调试器附加到我的项目时,它会在框架代码中出现 ArgumentException:

System.ArgumentException
  HResult=0x80070057
  Message=The parameter 'C:/inetpub/wwwroot/MvcCompaniesV2\' is invalid.
Parameter name: C:/inetpub/wwwroot/MvcCompaniesV2\

标签: asp.netpowershelldockeriis

解决方案


我通过修复 New-WebApplication 调用中格式错误的“PhysicalPath”解决了这个问题。调试器的 ArgumentException 放弃了它,IIS 不允许 / 在路径中。更新它们后C:\\inetpub\\wwwroot\\MvcCompaniesV2,问题就消失了。


推荐阅读