Agence web » Actualités du digital » Comment exécuter une application .NET dans Docker

Comment exécuter une application .NET dans Docker

Docker est un service de conteneurisation, utilisé pour exécuter des applications dans des environnements isolés emballés avec toutes les dépendances et le code dont il a besoin pour fonctionner. Il peut exécuter toutes sortes d'applications, y compris des programmes basés sur .NET à l'aide d'images d'exécution fournies par Microsoft.

Dockerizing .NET

Microsoft fournit des images de base prédéfinies pour exécuter des applications .NET. Vous n’avez pas besoin de gérer l’installation du runtime ou du SDK .NET dans votre conteneur Docker, car vous pouvez simplement étendre l’image de base de Microsoft à la version de .NET utilisée par votre application.

À moins que vous ne prévoyiez de déployer des conteneurs Windows sur un serveur Windows, vous devrez utiliser .NET Core ou .NET 5. L'ancien environnement d'exécution .NET Framework n'est pas multiplateforme et ne fonctionnera pas sur les conteneurs Linux.

Si Docker n'est pas installé sur votre machine de développement, vous devrez installer Docker Desktop pour avoir accès à la CLI. Si vous utilisez WSL sous Windows, vous souhaiterez activer le moteur basé sur WSL 2, qui offre de meilleures performances.

Pour tester les choses, nous allons créer une nouvelle application API ASP.NET. La même procédure générale s'appliquera à tout type d'application, car tout ce que Docker fait est d'exécuter une compilation chaque fois que vous créez le conteneur et de démarrer votre application avec une commande entrypoint.

Créez un nouveau fichier appelé Dockerfile à la racine de votre projet, là où se trouve votre solution. Collez dans la configuration suivante:

FROM mcr.microsoft.com/dotnet/core/sdk AS build-env
WORKDIR /app

# Copy csproj and restore
COPY *.csproj ./
RUN dotnet restore

# Copy everything else and build
COPY . ./
RUN dotnet publish -o out

# Build runtime image
FROM mcr.microsoft.com/dotnet/core/runtime
WORKDIR /app
COPY --from=build-env /app/out .
ENTRYPOINT ("dotnet", "DockerTest.dll")

Ce Dockerfile extrait l'image du SDK .NET Core pour effectuer la génération. Il copie le .csproj over et restaure, puis copie tout le reste et exécute une construction. Ensuite, il crée une nouvelle image à partir de l'image .NET Runtime et copie les artefacts de génération.

Enfin, le point d'entrée est défini ici comme dotnet DockerTest.dll. Cela démarrera le serveur Web ASP.NET, même si vous devrez peut-être modifier les paramètres de votre application ou spécifier une commande de point d'entrée entièrement différente.

Vous pouvez tester l'exécution de votre conteneur avec docker container run, en le passant dans l'ID du conteneur de construction:

docker container run containerid

Pour une application ASP.NET, vous devrez ouvrir des ports en mappant un port sur l'hôte à un port sur le conteneur:

docker run -p 80:80 containerid

Vous pouvez lire notre guide sur l'utilisation de Docker et Dockerfiles pour en savoir plus.

★★★★★