You can build and run the sample in Docker using the following commands. The instructions assume that you are in the root of the repository and running Windows Server 2019 for the sample.
git clone https://github.com/mzazon/aspnet-containerized
cd aspnet-containerized
docker build --pull -t aspnetapp .
docker run --name aspnet_sample --rm -it -p 443:443 aspnetapp
You should see the following console output as the application builds:
PS C:\Users\Administrator\Desktop\aspnet-containerized> docker build --pull -t aspnetapp .
Sending build context to Docker daemon 1.718MB
Step 1/13 : FROM microsoft/dotnet-framework:4.7.2-sdk AS build
4.7.2-sdk: Pulling from microsoft/dotnet-framework
65014b3c3121: Already exists
9e2f2b17be72: Already exists
e583fcdc4adc: Already exists
9870ac56a9c6: Pull complete
Digest: sha256:590e9ddadfdac37e9c2b58f2b33ebbbd4393e8102ec0da783add291ba4ace511
Status: Downloaded newer image for microsoft/dotnet-framework:4.7.2-sdk
---> 1f9f0521b131
Step 2/13 : WORKDIR /app
---> Running in 98cc90b9f18d
Removing intermediate container 98cc90b9f18d
---> 4147b08d4b91
Step 3/13 : COPY *.sln .
---> 5de8e2c1a9fc
Step 4/13 : COPY aspnetapp/*.csproj ./aspnetapp/
---> 4a581c162a8d
Step 5/13 : COPY aspnetapp/*.config ./aspnetapp/
---> d8907420bc30
Step 6/13 : RUN nuget restore
---> Running in 727b8fc48d3c
Installed:
25 package(s) to packages.config projects
Removing intermediate container 727b8fc48d3c
---> 98a072d1c02d
Step 7/13 : COPY aspnetapp/. ./aspnetapp/
---> 0236cfe1993c
Step 8/13 : WORKDIR /app/aspnetapp
---> Running in ce5ad2bae874
Removing intermediate container ce5ad2bae874
---> c16dd8b9ed4a
Step 9/13 : RUN msbuild /p:Configuration=Release
---> Running in d4248ba054e1
Microsoft (R) Build Engine version 15.9.21+g9802d43bc3 for .NET Framework
Copyright (C) Microsoft Corporation. All rights reserved.
Build started 3/6/2019 4:23:00 PM.
Done Building Project "C:\app\aspnetapp\aspnetapp.csproj" (default targets).
Build succeeded.
0 Warning(s)
0 Error(s)
Time Elapsed 00:00:05.28
Removing intermediate container d4248ba054e1
---> fc0ebee6c12d
Step 10/13 : FROM mcr.microsoft.com/dotnet/framework/aspnet:4.7.2 AS runtime
4.7.2: Pulling from dotnet/framework/aspnet
Digest: sha256:958114016f74f4ffc10b7f065ca4f340e0a0c390cb276c3659d5f8af43d388c7
Status: Downloaded newer image for mcr.microsoft.com/dotnet/framework/aspnet:4.7.2
---> c231abd0f40f
Step 11/13 : WORKDIR /inetpub/wwwroot
---> Running in 545958a64f0a
Removing intermediate container 545958a64f0a
---> aad0f811675f
Step 12/13 : COPY --from=build /app/aspnetapp/. ./
---> 2f66925575d3
Step 13/13 : RUN powershell.exe -Command " Import-Module IISAdministration; $cert = New-SelfSignedCertificate -DnsName demo.cloudreach.internal -CertStoreLocation cert:\LocalMachine\My; $certHash = $cert.GetCertHash(); $sm = Get-IISServerManager; $sm.Sites[\"Default Web Site\"].Bindings.Add(\"*:443:\", $certHash, \"My\", \"0\"); $sm.CommitChanges();"
---> Running in 310324e83afc
protocol bindingInformation sslFlags
-------- ------------------ --------
https *:443: None
Removing intermediate container 310324e83afc
---> 62a0abaa342a
Successfully built 62a0abaa342a
Successfully tagged aspnetapp:latest
PS C:\Users\Administrator\Desktop\aspnet-containerized>
You should see the following when running the application:
PS C:\Users\Administrator\Desktop\aspnet-containerized>docker run --name aspnet_sample --rm -it -p 443:443 -p 8000:80 aspnetapp
Service 'w3svc' has been stopped
Service 'w3svc' started
After the application starts, navigate to https://localhost
in your web browser!