GitXplorerGitXplorer
x

dotnet-docker-heroku

public
2 stars
1 forks
1 issues

Commits

List of commits on branch master.

No commits found

There are no commits on branch master.

README

The README file for this repository.

ASP.NET Core Docker Sample on Heroku

this repo demonstrates how to set the necessary environment variables on Heroku

Please note: this doesn't confer any kind of official support from myself or Heroku

By default, this application will attempt to bind to port 80 however when running on Heroku the port number is randomly assigned and accessible via the $PORT environment variable.

There are several issues that arise as a result of how Docker expects to format CMD - the various modes are described here: https://docs.docker.com/engine/reference/builder/#cmd

In order to work around these, one option is to create a script to set the necessary environment variables:

RUN echo "ASPNETCORE_URLS=http://0.0.0.0:\$PORT\nDOTNET_RUNNING_IN_CONTAINER=true" > /app/setup_heroku_env.sh && chmod +x /app/setup_heroku_env.sh ```

This creates a script at /app/setup_heroku_env.sh that can later be sourced to set the environment variables correctly at runtime.

Finally you should be able to change the final CMD entry to the following:

CMD /bin/bash -c "source /app/setup_heroku_env.sh && dotnet aspnetapp.dll"

An example of this repo is running here: https://infinite-tundra-97916.herokuapp.com/

You can clone this app and follow the process here https://devcenter.heroku.com/articles/container-registry-and-runtime to deploy your own version

You can clone this app and follow the process here https://devcenter.heroku.com/articles/container-registry-and-runtime to deploy your own version.

Normal README follows

This sample Dockerfile demonstrates how to use ASP.NET Core and Docker together. The sample works with both Linux and Windows containers and can also be used without Docker. There are also instructions that demonstrate how to push the sample to Azure Container Registry and test it with Azure Container Instance. You can configure ASP.NET Core to use HTTPS with Docker.

The sample builds the application in a container based on the larger .NET Core SDK Docker image. It builds the application and then copies the final build result into a Docker image based on the smaller ASP.NET Core Docker Runtime image.

This sample requires Docker 17.06 or later of the Docker client.

Try a pre-built ASP.NET Core Docker Image

You can quickly run a container with a pre-built sample ASP.NET Core Docker image, based on this sample.

Type the following command to run a sample with Docker:

docker run --name aspnetcore_sample --rm -it -p 8000:80 microsoft/dotnet-samples:aspnetapp

After the application starts, navigate to http://localhost:8000 in your web browser. On Windows, you may need to navigate to the container via IP address. See ASP.NET Core apps in Windows Containers for instructions on determining the IP address, using the value of --name that you used in docker run.

See Hosting ASP.NET Core Images with Docker over HTTPS to use HTTPS with this image.

Getting the sample

The easiest way to get the sample is by cloning the samples repository with git, using the following instructions:

git clone https://github.com/dotnet/dotnet-docker/

You can also download the repository as a zip.

Build and run the sample with Docker

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 samples
cd aspnetapp
docker build --pull -t aspnetapp .
docker run --name aspnetcore_sample --rm -it -p 8000:80 aspnetapp

You should see the following console output as the application starts.

C:\git\dotnet-docker\samples\aspnetapp>docker run --name aspnetcore_sample --rm -it -p 8000:80 aspnetapp
Hosting environment: Production
Content root path: /app
Now listening on: http://[::]:80
Application started. Press Ctrl+C to shut down.

After the application starts, navigate to http://localhost:8000 in your web browser. On Windows, you may need to navigate to the container via IP address. See ASP.NET Core apps in Windows Containers for instructions on determining the IP address, using the value of --name that you used in docker run.

Note: The -p argument maps port 8000 on your local machine to port 80 in the container (the form of the port mapping is host:container). See the Docker run reference for more information on commandline parameters. In some cases, you might see an error because the host port you select is already in use. Choose a different port in that case.

Additional Samples

Multiple variations of this sample have been provided, as follows. Some of these example Dockerfiles are demonstrated later. Specify an alternate Dockerfile via the -f argument.

Deploying with HTTPS

ASP.NET Core 2.1 uses HTTPS by default. You can configure ASP.NET Core to use HTTPS with Docker.

Build and run the sample for Alpine X64 with Docker

You can build and run the sample for Alpine using the following instructions. Make sure Docker is set to Linux containers if you are on Windows.

cd samples
cd aspnetapp
docker build --pull -t aspnetapp -f Dockerfile.alpine-x64 .
docker run --name aspnetcore_sample --rm -it -p 8000:80 aspnetapp

After the application starts, navigate to http://localhost:8000 in your web browser.

Build and run the sample for Ubuntu 18.04 with Docker

You can also build for Ubuntu 18.04, with a bionic tag. The bionic tags are documented at microsoft/dotnet. You would switch to the following tags:

  • SDK: 2.1-sdk-bionic
  • Runtime:-2.1-aspnetcore-runtime-bionic

Build and run the sample for Linux ARM32 with Docker

You can build and run the sample for ARM32 and Raspberry Pi with Build ASP.NET Core Applications for Raspberry Pi with Docker instructions.

Develop ASP.NET Core Applications in a container

You can develop applications without a .NET Core installation on your machine with the Develop ASP.NET Core applications in a container instructions. These instructions are also useful if your development and production environments do not match.

Deploying to Production vs Development

The approach for running containers differs between development and production.

In production, you will typically start your container with docker run -d. This argument starts the container as a service, without any console interaction. You then interact with it through other Docker commands or APIs exposed by the containerized application.

In development, you will typically start containers with docker run --rm -it. These arguments enable you to see a console (important when there are errors), terminate the container with CTRL-C and cleans up all container resources when the container is termiantes. You also typically don't mind blocking the console. This approach is demonstrated in prior examples in this document.

We recommend that you do not use --rm in production. It cleans up container resources, preventing you from collecting logs that may have been captured in a container that has either stopped or crashed.

Build and run the sample locally

You can build and run the sample locally with the .NET Core 2.1 SDK using the following commands. The commands assume that you are in the root of the repository.

cd samples
cd aspnetapp
dotnet run

After the application starts, visit http://localhost:5000 in your web browser.

You can produce an application that is ready to deploy to production locally using the following command.

dotnet publish -c Release -o out

You can run the application using the following commands.

cd out
dotnet aspnetapp.dll

Note: The -c Release argument builds the application in release mode (the default is debug mode). See the dotnet publish reference for more information on commandline parameters.

.NET Core Resources

More Samples

Docs and More Information:

Related Repositories

.NET Core Docker Hub repos:

.NET Framework Docker Hub repos: