Offizielle .NET-Docker-Images
Tipp
Diese Inhalte sind ein Auszug aus dem eBook „.NET Microservices Architecture for Containerized .NET Applications“, verfügbar unter .NET Docs oder als kostenlos herunterladbare PDF-Datei, die offline gelesen werden kann.
Die offiziellen .NET-Docker-Images sind Docker-Images, die von Microsoft erstellt und optimiert werden. Sie sind in der Microsoft-Artefaktregistrierung öffentlich zugänglich. Sie können den Katalog durchsuchen, um alle .NET-Imagerepositorys zu finden, z. B. das .NET SDK-Repository.
Jedes Repository kann je nach .NET-Version und der Version des Betriebssystems mehrere Images enthalten (Linux Debian, Alpine Linux, Windows Nano Server, Windows Server Core usw.). Die Repositorys für Images bieten umfangreiche Taggingfunktionen, die Sie nicht nur bei der Wahl einer bestimmten Frameworkversion unterstützen, sondern auch bei der des Betriebssystems (Linux-Distribution oder Windows-Version).
.NET- und Docker-Imageoptimierungen für die Entwicklung und die Produktion im Vergleich
Beim Erstellen von Docker-Images für Entwickler standen für Microsoft die folgenden wichtigen Szenarios im Mittelpunkt:
Images zum Entwickeln und Erstellen von .NET-Apps
Images zum Ausführen von .NET-Apps
Warum mehrere Images? Beim Entwickeln, Erstellen und Ausführen von Containeranwendungen gibt es üblicherweise unterschiedliche Prioritäten. Durch das Bereitstellen verschiedener Images leistet Microsoft einen Beitrag zur Optimierung der separaten Prozesse des Entwickelns, Erstellens und Bereitstellens von Apps.
Während der Entwicklung und Erstellung
In der Entwicklungsphase zählt, wie schnell Sie Änderungen durchlaufen und Änderungen debuggen können. Die Größe des Images ist nicht so entscheidend wie die Fähigkeit, Änderungen am Code schnell vorzunehmen und anzuzeigen. Einige Tools und Build-Agent-Container verwenden während des Entwicklungs- und Buildprozesses das .NET-Entwicklungsimage (mcr.microsoft.com/dotnet/sdk:8.0). Wenn Sie Builds innerhalb eines Docker-Containers erstellen, sind die Elemente, die zum Kompilieren der App benötigt werden, das Wichtigste. Das schließt den Compiler und alle anderen .NET-Abhängigkeiten ein.
Eine weitere großartige Option sind die Entwicklungscontainer. Dabei handelt es sich um vorgefertigte, einsatzbereite Entwicklungsumgebungen, bei denen Sie sich keine Gedanken im Hinblick auf Abhängigkeiten und Konfigurationen machen müssen. Sie können sie auch einfach anpassen, um zusätzliche Tools oder Abhängigkeiten einzuschließen. Entwicklungscontainer bieten ein konsistentes und wiederholbares Setup, das Sie problemlos mit Ihrem Team teilen können. Entwicklungscontainer entsprechen der Spezifikation für Entwicklungscontainer, und werden von zahlreichen beliebten Entwicklertools, einschließlich Visual Studio Code und GitHub Codespaces, unterstützt. Die .NET-Entwicklercontainer basieren auf dem .NET SDK-Image und enthalten das .NET SDK, die Laufzeit und weitere Tools, die Sie zum Entwickeln von .NET-Anwendungen benötigen.
Warum ist diese Art von Buildimage wichtig? Sie stellen dieses Image nicht in der Produktion bereit. Damit wird ausschließlich der Inhalt erstellt, den Sie in einem Produktionsimage platzieren. Dieses Image wird dann bei Verwendung mehrstufiger Docker-Builds in der Continuous Integration- oder Buildumgebung verwendet.
In einer Produktionsumgebung
In der Produktion ist wichtig, wie schnell Sie Container basierend auf einem .NET-Produktionsimage bereitstellen und starten können. Das Image, das auf mcr.microsoft.com/dotnet/aspnet:8.0 basiert und nur die Runtime enthält, ist daher klein, damit es von der Docker-Registrierung schnell über das Netzwerk an die Docker-Hosts übertragen werden kann. Die Inhalte sind bereit zur Ausführung und ermöglichen eine minimale Zeitspanne zwischen dem Start des Containers und dem Verarbeiten der Ergebnisse. Anders als bei „dotnet build“ oder „dotnet publish“ beim Verwenden des Buildcontainers besteht im Docker-Modell keine Notwendigkeit, C#-Code zu kompilieren.
In diesem optimierten Image werden nur die Binärdateien und andere Inhalte platziert, die zum Ausführen der Anwendung erforderlich sind. Der von dotnet publish
erstellte Inhalt enthält z. B. nur die kompilierten .NET-Binärdateien, Images sowie JS- und CSS-Dateien. Im Lauf der Zeit werden Sie auf Images stoßen, die Pakete enthalten, die vorab JIT-kompiliert wurden (Kompilierung von IL zu nativ, die zur Laufzeit erfolgt).
Obwohl mehrere Versionen der .NET- und ASP.NET Core-Images verfügbar sind, haben sie alle mindestens eine Schicht gemeinsam, einschließlich der Basisschicht. Aus diesem Grund ist wenig Speicherplatz erforderlich, um ein Image zu speichern, denn es besteht nur aus dem Delta zwischen dem benutzerdefinierten Image und dem Basis-Image. So können Sie das Image schnell aus der Registrierung abrufen.
Wenn Sie sich die .NET-Imagerepositorys in der Microsoft-Artefaktregistrierung ansehen, werden Sie mehrere Imageversionen finden, die klassifiziert oder mit Tags versehen sind. Diese Tags helfen dabei, je nach benötigter Version zu entscheiden, welches Image verwendet werden sollte, so wie in der folgenden Tabelle:
Bild | Kommentare |
---|---|
mcr.microsoft.com/dotnet/aspnet:8.0 | ASP.NET Core mit Optimierungen nur für die Runtime und ASP.NET Core unter Linux und Windows (Mehrfacharchitektur) |
mcr.microsoft.com/dotnet/sdk:8.0 | .NET 8 mit enthaltenen SDKs unter Linux und Windows (Mehrfacharchitektur) |
Sie finden alle verfügbaren Docker-Images in dotnet-docker. Verwenden Sie auch die neuesten Vorschauversionen, indem Sie den nächtlichen Build mcr.microsoft.com/dotnet/nightly/*
nutzen.