ASP.NET Core Docker Image
This repository contains images for running published ASP.NET Core applications. These images use the
microsoft/dotnet image as its base.
What is ASP.NET Core?
ASP.NET Core is a new open-source and cross-platform framework for building modern cloud based internet connected applications, such as web apps, IoT apps and mobile backends. It consists of modular components with minimal overhead, so you retain flexibility while constructing your solutions. You can develop and run your ASP.NET Core apps cross-platform on Windows, Mac and Linux. ASP.NET Core is open source at GitHub.
This image contains:
- .NET Core so that you can run your already compiled .NET Core applications.
- A set of native images for all of the ASP.NET Core libraries. These images will be used at runtime to increase
the cold-start performance of your application. A significant amount of the time taken to JIT compile on startup of
your application is typically spent compiling ASP.NET Core libraries rather than your application code. Given that
these libraries are not going to change for a given version we include native images so that the runtime can load them
instead of running the JIT.
- microsoft/dotnet - the .NET Core image if you don't need the ASP.NET Core specific optimizations.
- microsoft/aspnetcore-build - The ASP.NET Core build image for publishing an ASP.NET Core app inside a container.
How to use this image
Create a Dockerfile for your application, the following example assumes you have already compiled your application (which is the expected use case for this image)
FROM microsoft/aspnetcore WORKDIR /app COPY . . ENTRYPOINT ["dotnet", "myapp.dll"]
Build and run your app:
$ docker build -t myapp . $ docker run -d -p 8000:80 myapp
Browse to localhost:8000 to access your app.
A note on ports
This image sets the
ASPNETCORE_URLS environment variable to
http://+:80 which means that if you have not explicity
set a URL in your application, via
app.UseUrl in your Program.cs for example, then your application will be listening
on port 80 inside the container.
How can I change the user?
I am trying this:
RUN addgroup $USER && adduser -shell /bin/bash -D -G $USER $USER
and it gives error
@liuxm6 This means the .dll file isn't where you've specified. The following things must be correct for the image to work:
The dll must be in the root
The COPY operation with . . copies from the current working directory of your PC to the working directory (/app) in the container. If your output .dll file is somewhere else you'll need to update the first . to the path where the output directory is.
For example: COPY output/mywebsite .
Alternatively, if you're using a sub directory, make sure to specify the full path in the ENTRYPOINT command.
ENTRYPOINT ["dotnet", "app/myapp.dll"]
The website must be in the /app folder.
The WORKDIR command does this. I tried renaming it, but that broke the runtime
Output directory must be a sub directory, or absolute
With the current .NET build tools (I think fixed in preview 3), the output directory of the dotnet publish command must be a sub directory of the project, or specified absolutely. If you use a relative path (../) the publish parameters will be ignored and you won't get your views, etc.
@stanuku THANK YOU SO MUCH!
This works fine instead:
COPY . /app
RUN ["dotnet", "restore"]
ENTRYPOINT ["dotnet", "run"]
I used the next set of commands:
- docker publish -c Release -o ./app
// publishing our application to app folder. The name of my application name is "hw", so I have hw.dll in app folder
- Used the next dockerfile:
COPY ./app .
ENTRYPOINT ["dotnet", "hw.dll"]
So I need to:
- Build && publish with microsoft/aspnetcore-build
- Run my published app with microsoft/aspnetcore
Is that right?
Extend the image and add your published ASP.NET Core site then make the CMD "dotnet <sitename>.dll"