Inhaltsverzeichnis
Docker kann auf einer physischen oder einer virtuellen Maschine ausgeführt werden. Die Infrastruktur befindet sich im Wesentlichen auf derselben Ebene. Container lösen hauptsächlich eine Reihe softwarezentrierter Probleme. Genau genommen befinden sich Container und virtuelle Maschinen nicht auf derselben Ebene, sondern sind eine verpackte Sammlung von Software und Umgebung.
Heim Betrieb und Instandhaltung Docker Läuft Docker auf einer physischen oder einer virtuellen Maschine?

Läuft Docker auf einer physischen oder einer virtuellen Maschine?

Jun 27, 2022 am 11:12 AM
docker

Docker kann entweder auf einer physischen Maschine oder einer virtuellen Maschine ausgeführt werden. Unabhängig davon, ob es sich um eine virtuelle Maschine oder eine physische Maschine handelt, handelt es sich um eine Bereitstellungsmethode für Hardware und Infrastruktur, bei der es sich im Wesentlichen um eine Ebene handelt, und Container werden hauptsächlich zur Lösung von Problemen verwendet Aufgrund einer Reihe softwarebezogener Probleme ist die Ausführung von Containern sowohl auf virtuellen als auch auf physischen Maschinen möglich.

Läuft Docker auf einer physischen oder einer virtuellen Maschine?

Die Betriebsumgebung dieses Tutorials: Linux7.3-System, Docker-Version 19.03, Dell G3-Computer.

Docker kann auf einer physischen oder einer virtuellen Maschine ausgeführt werden. Die Infrastruktur befindet sich im Wesentlichen auf derselben Ebene. Container lösen hauptsächlich eine Reihe softwarezentrierter Probleme. Genau genommen befinden sich Container und virtuelle Maschinen nicht auf derselben Ebene, sondern sind eine verpackte Sammlung von Software und Umgebung.

Das Ausführen von Containern in virtuellen Maschinen ist zu einer praktischen Praxis geworden. Der Containerdienst von AWS wird beispielsweise nur in virtuellen Maschinen ausgeführt. Der Docker-Daemon kann direkt mit dem Hauptbetriebssystem kommunizieren, um jedem Docker-Container Ressourcen zuzuweisen. Außerdem kann er den Container vom Hauptbetriebssystem isolieren und die einzelnen Container voneinander isolieren. Docker wird häufig verwendet, um verschiedene Anwendungen wie Front-End, Back-End und Datenbank zu isolieren.

Erweiterte Kenntnisse:

Der Docker-Daemon kann direkt mit dem Hauptbetriebssystem kommunizieren, um einzelnen Docker-Containern Ressourcen zuzuweisen; er kann außerdem Container vom Hauptbetriebssystem isolieren und einzelne Container voneinander isolieren. Docker wird häufig verwendet, um verschiedene Anwendungen wie Front-End, Back-End und Datenbank zu isolieren.

Docker zeichnet sich durch Kompaktheit, schnelle Migration und Bereitstellung sowie einen effizienten Betrieb aus, seine Isolation ist jedoch schlechter als die Servervirtualisierung: Verschiedene Container gehören zu unterschiedlichen Frachtbriefen (verschiedene Anwendungsinstanzen werden auf Docker ausgeführt) und sind unabhängig voneinander (isoliert). . Es wird jedoch vom selben Warehouse-Manager (Host-Betriebssystemkernel) verwaltet, sodass der Warehouse-Manager die relevanten Informationen aller Container sehen kann (da der Betriebssystemkernel gemeinsam genutzt wird, werden relevante Informationen gemeinsam genutzt).

Virtuelle Maschinen können die gesamte Betriebsumgebung besser vollständig isolieren. Beispielsweise verwenden Cloud-Dienstanbieter normalerweise die Technologie virtueller Maschinen, um verschiedene Benutzer zu isolieren. Der Start einer virtuellen Maschine dauert Minuten, während ein Docker-Container in Millisekunden starten kann. Ohne ein aufgeblähtes Betriebssystem kann Docker viel Speicherplatz und andere Systemressourcen sparen. Servervirtualisierung ist wie die Einrichtung mehrerer unabhängiger „kleiner Docks“ – Lagerhäuser (virtuelle Maschinen) auf dem Dock (physischer Host und Virtualisierungsebene). Es verfügt über einen völlig unabhängigen (isolierten) Raum und gehört verschiedenen Kunden (Besitzer virtueller Maschinen). Jedes Lager verfügt über einen eigenen Lagerverwalter (den Betriebssystemkern der aktuellen virtuellen Maschine) und kann keine anderen Lager verwalten. Es findet kein Informationsaustausch statt.

Daher müssen wir je nach Anwendungsszenario und Bedarf unterschiedliche Methoden anwenden, indem wir Docker-Technologie oder Servervirtualisierungstechnologie verwenden.

Vergleich der Implementierungsprinzipien von Docker und virtuellen Maschinen

Die folgenden Abbildungen zeigen die Implementierungsframeworks von virtuellen Maschinen bzw. Docker.

Vergleichen Sie die Unterschiede zwischen den beiden Bildern. Die Gastbetriebssystemebene und die Hypervisorebene der virtuellen Maschine im linken Bild werden durch die Docker Engine-Ebene in Docker ersetzt. Das Gastbetriebssystem einer virtuellen Maschine ist das auf der virtuellen Maschine installierte Betriebssystem. Die Hypervisor-Schicht der virtuellen Maschine kann einfach als Hardware-Virtualisierungsplattform verstanden werden, die als Kernel-Statustreiber vorhanden ist im Host-Betriebssystem.

Die Methode für virtuelle Maschinen zur Ressourcenisolation besteht darin, ein unabhängiges Betriebssystem zu verwenden und den Hypervisor zur Virtualisierung von CPU, Speicher, E/A-Geräten usw. zu verwenden. Bei virtuellen CPUs erstellt der Hypervisor beispielsweise eine Datenstruktur für jede virtuelle CPU, simuliert die Werte aller Register der CPU und verfolgt und ändert diese Werte gegebenenfalls. Es sollte darauf hingewiesen werden, dass der Softwarecode der virtuellen Maschine in den meisten Fällen direkt auf der Hardware ausgeführt wird, ohne dass der Hypervisor eingreifen muss. Nur bei einigen Anforderungen mit hohen Berechtigungen muss das Gastbetriebssystem den Kernelmodus ausführen, um die Registerdaten der CPU zu ändern, und der Hypervisor greift ein, um den Status der virtuellen CPU zu ändern und aufrechtzuerhalten.

Die Art und Weise, wie der Hypervisor den Speicher virtualisiert, besteht darin, eine Schattenseitentabelle zu erstellen. Unter normalen Umständen kann eine Seitentabelle zum Übersetzen vom virtuellen Speicher in den physischen Speicher verwendet werden. Da bei der Virtualisierung der sogenannte physische Speicher immer noch virtuell ist, muss die Schattenseitentabelle Folgendes tun: virtueller Speicher -> virtueller physischer Speicher -> realer physischer Speicher.

Läuft Docker auf einer physischen oder einer virtuellen Maschine?Wenn der Hypervisor bei der E/A-Gerätevirtualisierung einen Seitenfehler empfängt und feststellt, dass die virtuelle physische Speicheradresse tatsächlich einem E/A-Gerät entspricht, simuliert der Hypervisor mithilfe von Software die Arbeitsbedingungen dieses Geräts und kehrt zurück. Wenn die CPU beispielsweise auf die Festplatte schreiben möchte, schreibt der Hypervisor die entsprechenden Daten in eine Host-Betriebssystemdatei. Diese Datei simuliert tatsächlich eine virtuelle Festplatte.

Im Vergleich zur Lösung einer virtuellen Maschine zur Ressourcen- und Umgebungsisolierung ist Docker viel einfacher. Docker Engine kann einfach als Kapselung der NameSpace-, Cgroup- und Image-Management-Dateisystemoperationen von Linux betrachtet werden. Docker verwendet kein völlig unabhängiges Gastbetriebssystem, um eine Umgebungsisolierung wie eine virtuelle Maschine zu erreichen. Es verwendet die Containermethode, die derzeit vom Linux-Kernel selbst unterstützt wird, um eine Ressourcen- und Umgebungsisolierung zu erreichen. Vereinfacht ausgedrückt verwendet Docker den Namespace, um die Systemumgebung zu isolieren, und verwendet Cgroup, um Ressourcenbeschränkungen zu implementieren.

Empfohlenes Lernen: „Docker-Video-Tutorial

Das obige ist der detaillierte Inhalt vonLäuft Docker auf einer physischen oder einer virtuellen Maschine?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Architektur und Praxis verteilter PHP-Systeme Architektur und Praxis verteilter PHP-Systeme May 04, 2024 am 10:33 AM

Die verteilte PHP-Systemarchitektur erreicht Skalierbarkeit, Leistung und Fehlertoleranz durch die Verteilung verschiedener Komponenten auf mit dem Netzwerk verbundene Maschinen. Die Architektur umfasst Anwendungsserver, Nachrichtenwarteschlangen, Datenbanken, Caches und Load Balancer. Zu den Schritten zur Migration von PHP-Anwendungen auf eine verteilte Architektur gehören: Identifizieren von Dienstgrenzen, Auswählen eines Nachrichtenwarteschlangensystems, Einführung eines Microservices-Frameworks, Bereitstellung für die Containerverwaltung, Diensterkennung

Agile Entwicklung und Betrieb der PHP-Microservice-Containerisierung Agile Entwicklung und Betrieb der PHP-Microservice-Containerisierung May 08, 2024 pm 02:21 PM

Antwort: PHP-Microservices werden mit HelmCharts für eine agile Entwicklung bereitgestellt und mit DockerContainer für Isolation und Skalierbarkeit in Containern verpackt. Detaillierte Beschreibung: Verwenden Sie HelmCharts, um PHP-Microservices automatisch bereitzustellen, um eine agile Entwicklung zu erreichen. Docker-Images ermöglichen eine schnelle Iteration und Versionskontrolle von Microservices. Der DockerContainer-Standard isoliert Microservices und Kubernetes verwaltet die Verfügbarkeit und Skalierbarkeit der Container. Verwenden Sie Prometheus und Grafana, um die Leistung und den Zustand von Microservices zu überwachen und Alarme und automatische Reparaturmechanismen zu erstellen.

PI -Knotenunterricht: Was ist ein PI -Knoten? Wie installiere und richte ich einen PI -Knoten ein? PI -Knotenunterricht: Was ist ein PI -Knoten? Wie installiere und richte ich einen PI -Knoten ein? Mar 05, 2025 pm 05:57 PM

Detaillierte Erläuterungs- und Installationshandbuch für Pinetwork -Knoten In diesem Artikel wird das Pinetwork -Ökosystem im Detail vorgestellt - PI -Knoten, eine Schlüsselrolle im Pinetwork -Ökosystem und vollständige Schritte für die Installation und Konfiguration. Nach dem Start des Pinetwork -Blockchain -Testnetzes sind PI -Knoten zu einem wichtigen Bestandteil vieler Pioniere geworden, die aktiv an den Tests teilnehmen und sich auf die bevorstehende Hauptnetzwerkveröffentlichung vorbereiten. Wenn Sie Pinetwork noch nicht kennen, wenden Sie sich bitte an was Picoin ist? Was ist der Preis für die Auflistung? PI -Nutzung, Bergbau und Sicherheitsanalyse. Was ist Pinetwork? Das Pinetwork -Projekt begann 2019 und besitzt seine exklusive Kryptowährung PI -Münze. Das Projekt zielt darauf ab, eine zu erstellen, an der jeder teilnehmen kann

So installieren Sie Deepseek So installieren Sie Deepseek Feb 19, 2025 pm 05:48 PM

Es gibt viele Möglichkeiten, Deepseek zu installieren, einschließlich: kompilieren Sie von Quelle (für erfahrene Entwickler) mit vorberechtigten Paketen (für Windows -Benutzer) mit Docker -Containern (für bequem am besten, um die Kompatibilität nicht zu sorgen), unabhängig von der Methode, die Sie auswählen, bitte lesen Die offiziellen Dokumente vorbereiten sie sorgfältig und bereiten sie voll und ganz vor, um unnötige Schwierigkeiten zu vermeiden.

Wie kann die Leistung von Java-Funktionen durch Containerisierung optimiert werden? Wie kann die Leistung von Java-Funktionen durch Containerisierung optimiert werden? Apr 29, 2024 pm 03:09 PM

Die Containerisierung verbessert die Leistung von Java-Funktionen auf folgende Weise: Ressourcenisolation – Gewährleistung einer isolierten Computerumgebung und Vermeidung von Ressourcenkonflikten. Leicht – beansprucht weniger Systemressourcen und verbessert die Laufzeitleistung. Schneller Start – reduziert Verzögerungen bei der Funktionsausführung. Konsistenz – Entkoppeln Sie Anwendungen und Infrastruktur, um ein konsistentes Verhalten in allen Umgebungen sicherzustellen.

Wie verwende ich PHP CI/CD für eine schnelle Iteration? Wie verwende ich PHP CI/CD für eine schnelle Iteration? May 08, 2024 pm 10:15 PM

Antwort: Verwenden Sie PHPCI/CD, um eine schnelle Iteration zu erreichen, einschließlich der Einrichtung von CI/CD-Pipelines sowie automatisierten Test- und Bereitstellungsprozessen. Richten Sie eine CI/CD-Pipeline ein: Wählen Sie ein CI/CD-Tool aus, konfigurieren Sie das Code-Repository und definieren Sie die Build-Pipeline. Automatisierte Tests: Schreiben Sie Unit- und Integrationstests und verwenden Sie Test-Frameworks, um das Testen zu vereinfachen. Praktischer Fall: Verwendung von TravisCI: Installieren Sie TravisCI, definieren Sie die Pipeline, aktivieren Sie die Pipeline und sehen Sie sich die Ergebnisse an. Implementieren Sie Continuous Delivery: Wählen Sie Bereitstellungstools aus, definieren Sie Bereitstellungspipelines und automatisieren Sie die Bereitstellung. Vorteile: Verbessern Sie die Entwicklungseffizienz, reduzieren Sie Fehler und verkürzen Sie die Lieferzeit.

Stellen Sie JavaEE-Anwendungen mithilfe von Docker-Containern bereit Stellen Sie JavaEE-Anwendungen mithilfe von Docker-Containern bereit Jun 05, 2024 pm 08:29 PM

Stellen Sie Java EE-Anwendungen mithilfe von Docker-Containern bereit: Erstellen Sie eine Docker-Datei, um das Image zu definieren, erstellen Sie das Image, führen Sie den Container aus, ordnen Sie den Port zu und greifen Sie dann im Browser auf die Anwendung zu. Beispiel für eine JavaEE-Anwendung: Die REST-API interagiert mit der Datenbank und ist nach der Bereitstellung über Docker auf localhost zugänglich.

So installieren Sie die Docker-Erweiterung in vscode. Schritte zum Installieren der Docker-Erweiterung in vscode So installieren Sie die Docker-Erweiterung in vscode. Schritte zum Installieren der Docker-Erweiterung in vscode May 09, 2024 pm 03:25 PM

1. Klicken Sie nach dem Öffnen der Benutzeroberfläche zunächst auf die Schaltfläche mit dem Erweiterungssymbol auf der linken Seite. 2. Suchen Sie dann die Position der Suchleiste auf der geöffneten Erweiterungsseite. 3. Geben Sie dann mit der Maus das Wort Docker ein, um das Erweiterungs-Plug-in zu finden. 4 Wählen Sie abschließend das Ziel-Plug-in aus und klicken Sie einfach auf die Schaltfläche „Installieren“ in der unteren Ecke

See all articles