This .NET Core Docker sample demonstrates a best practice pattern for building Alpine based Docker images for .NET Core apps for production. The primary goal of Alpine is very small deployments. Images can be pulled quicker and will have a smaller attack surface area. The .NET Core Alpine Docker images are currently in preview. See the .NET Core Alpine Docker Image announcement for additional details.
The sample Dockerfile creates an .NET Core application Docker image based off of the .NET Core Runtime Alpine Preview Docker image.
It uses the Docker multi-stage build feature to build the sample in a container based on the larger .NET Core SDK Docker base image and then copies the final build result into a Docker image based on the smaller .NET Core Docker Runtime base image. The SDK image contains tools that are required to build applications while the runtime image does not.
This sample requires Docker 17.06 or later of the Docker client. You need the latest Windows 10 or Windows Server 2016 to use Windows containers. The instructions assume you have the Git client installed.
The easiest way to get the sample is by cloning the samples repository with git, using the following instructions. You can also just download the repository (it is small) as a zip from the .NET Core Docker samples respository.
git clone https://github.com/dotnet/dotnet-docker-samples/
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.
cd dotnetapp-prod-alpine-preview
docker build -t dotnetapp-prod-alpine-preview .
docker run --rm dotnetapp-prod-alpine-preview Hello .NET Core from Docker
Note: The instructions above work only with Linux containers.
The Alpine based .NET Core Runtime Docker image has the .NET Core 2.0 Globalization Invariant Mode enabled in order to reduce the default size of the image. Use cases that cannot tolerate Globalization Invariant Mode can reset the DOTNET_SYSTEM_GLOBALIZATION_INVARIANT
environment variable and install the required ICU package. The Globalization Dockerfile illustrates how this can be done.
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.
cd dotnetapp-prod-alpine-preview
docker build -t dotnetapp-prod-alpine-preview -f Dockerfile.globalization .
docker run --rm dotnetapp-prod-alpine-preview Hello .NET Core from Docker
Note: The instructions above work only with Linux containers.
The following Docker images are used in this sample