Heim Betrieb und Instandhaltung Docker Welche Möglichkeiten der Docker-Speicherung gibt es?

Welche Möglichkeiten der Docker-Speicherung gibt es?

Feb 08, 2022 pm 04:55 PM
docker

Docker verfügt über vier Speichermethoden: 1. „Standardspeicher“, die Daten werden im laufenden Container gespeichert. 2. „Volume-Datenvolumen“; „, mounten Sie direkt ein beliebiges Verzeichnis oder eine Datei im Host-Dateisystem; 4. „tmpfs mount“.

Welche Möglichkeiten der Docker-Speicherung gibt es?

Die Betriebsumgebung dieses Tutorials: Linux5.9.8-System, Docker-1.13.1-Version, Dell G3-Computer.

Verschiedene Speichermethoden von Docker-Containern

Containerspeicher kann in zwei Hauptkategorien unterteilt werden:

Eine bezieht sich auf Bilder, was wir in „Grundlagen der Docker-Container-Technologie – Gemeinsame Datei“ besprochen haben „System OverlayFS“ Die im Artikel erwähnte Copy-On-Write-Funktion der Containerebene. Standardmäßig werden alle im Container erstellten Dateien auf der beschreibbaren Containerschicht gespeichert. Diese Methode der direkten Speicherung von Dateien auf der Containerschicht erschwert die Beibehaltung und Freigabe von Daten aufgrund der Abhängigkeit von Speichertreibern und der Verwendung des direkten Schreibens auf den Host Diese zusätzliche Abstraktion verringert die Leistung im Vergleich zum Datenvolumen.

Der andere ist der Hostspeicher, der durch Binden oder Einhängen des Hostverzeichnisses in den Container verwendet wird. Die Daten können auch nach dem Stoppen des Containers beibehalten werden. Stellen Sie hauptsächlich Letzteres vor.

Mehrere Speicher-Mounting-Methoden

Hier zeichnen wir das folgende Diagramm basierend auf den verschiedenen Speicherorten, an denen Daten auf dem Docker-Host gespeichert werden:

Welche Möglichkeiten der Docker-Speicherung gibt es?

Docker verfügt über vier Speichermethoden: Standard, Volumes, Datenvolumen, Bind-Mounts-Mounting , tmpfs mount (nur in Linux-Umgebung verfügbar), wobei Volumes und Bind-Mounts persistente Containerdaten implementieren.

1. Standardspeicher

Daten werden im laufenden Container gespeichert. Nach dem Löschen des Containers werden auch die Daten gelöscht.

2. Bind-Mounts haben im Vergleich zu Volumes eingeschränkte Funktionen. Bei Verwendung von Bind Mount wird eine Datei oder ein Verzeichnis auf dem Host in den Container gemountet. Auf die Datei oder das Verzeichnis wird durch ihren vollständigen Pfad auf dem Host verwiesen. Das Verzeichnis muss nicht bereits auf dem Docker-Host vorhanden sein. Wenn es nicht vorhanden ist, erstellt Docker es für uns. Beachten Sie, dass nur Verzeichnisse automatisch erstellt werden können.

Wir binden das Mounten eines Verzeichnisses /nginx/html über die Option -v und werfen einen Blick in den Container.

docker run -dt -v /nginx/html:/usr/share/nginx/html --name nginx nginx
Nach dem Login kopieren

Sehen Sie sich das Feld „Container-Mounts“ über Docker inspect nginx an Schreiben Sie es „Hallo Nginx“ und greifen Sie dann auf die Container-IP zu. Offensichtlich hat unser Mounten Wirkung gezeigt.

"Mounts": [
    {
        "Type": "bind",
        "Source": "/nginx/html",
        "Destination": "/usr/share/nginx/html",
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    }
],
Nach dem Login kopieren

Hier gibt es ein Problem. Wir können die Dateien über den Docker-Host ändern, um die Dateien im Container wirksam zu machen. Dasselbe gilt umgekehrt. Der Container kann den Inhalt im Host-Dateisystem ändern. Um dieses Problem zu lösen, können wir beim Erstellen des Containers die Berechtigungen des Mount-Verzeichnisses konfigurieren, z. B. die folgenden schreibgeschützten Berechtigungen:

[root@localhost ~]# echo "hello nginx" >  /nginx/html/index.html
[root@localhost ~]# curl 172.17.0.4
hello nginx
Nach dem Login kopieren

Wenn wir also Bind Mount verwenden, müssen Sie wissen, dass Sie das Host-Dateisystem bedienen Folgendes:

Welchen Inhalt enthält das von Ihnen gemountete Verzeichnis, um andere Anwendungen nicht zu beeinträchtigen?

Ob Ihr Container die Berechtigung zum Betreiben dieser Verzeichnisse haben soll.

3.Volumes-Datenvolumes

Volume-Speichervolumes werden von Docker erstellt und verwaltet. Wir können den Docker-Volume-Create-Befehl verwenden, um Volumes explizit zu erstellen, oder Volumes erstellen, wenn der Container erstellt wird.

docker run -dt -v /nginx/html:/usr/share/nginx/html:ro --name nginx nginx
Nach dem Login kopieren
Sie können sehen, dass sich der Mount-Punkt im Stammverzeichnis von Docker /var/lib/docker/volumes befindet.

Verwenden Sie Docker Volume rm/prune, um ein einzelnes oder alle nicht verwendeten Volumes zu löschen. Sie können den Docker-Befehl zum Verwalten verwenden die Lautstärke. Ein Vorteil von Bind-Mounts.

[root@localhost ~]# docker volume create nginx_volume
nginx_volume
[root@localhost volumes]# docker inspect  nginx_volume
[
    {
        "CreatedAt": "2021-08-12T01:58:04-04:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/nginx_volume/_data",
        "Name": "nginx_volume",
        "Options": {},
        "Scope": "local"
    }
]
Nach dem Login kopieren

Wenn die Quelle der Container-Montage beim Erstellen des Containers nicht angegeben wird, erstellt Docker automatisch ein anonymes Volume für uns, das sich ebenfalls im Docker-Stammverzeichnis befindet.

[root@localhost ~]# docker volume ls
DRIVER    VOLUME NAME
local     owncloud-docker-server_files
local     owncloud-docker-server_mysql
local     owncloud-docker-server_redis
[root@localhost ~]# docker volume prune
WARNING! This will remove all local volumes not used by at least one container.
Are you sure you want to continue? [y/N] y
Deleted Volumes:
owncloud-docker-server_files
owncloud-docker-server_mysql
owncloud-docker-server_redis

Total reclaimed space: 199.4MB
Nach dem Login kopieren

Nachdem wir ein Mount-Volume erstellt haben, stimmt der Speicher zu diesem Zeitpunkt mit Bind-Mounts überein. Wenn der Docker-Host jedoch eine bestimmte Verzeichnis- oder Dateistruktur nicht garantieren kann, kann uns das Volume dabei helfen, die Konfiguration des Docker-Hosts mit der zu kombinieren Containerlaufzeit. Wenn wir Daten von einem Docker-Host auf einen anderen sichern, wiederherstellen oder migrieren müssen, ist das Volume auf diese Weise sehr praktisch und kann von den Einschränkungen des Hostpfads getrennt werden.

Bei der Verwendung von Bind-Mounts und Volumes müssen wir die folgenden Propagierungsabdeckungsprinzipien beachten:

Beim Mounten eines leeren Volumes: Der Inhalt des Verzeichnisses im Container wird auf das Volume propagiert (kopiert).

Beim Binden eines gemounteten oder nicht leeren Volumes: Der Inhalt des Verzeichnisses im Container wird durch das Volume oder das gebundene Hostverzeichnis überschrieben. Welche Möglichkeiten der Docker-Speicherung gibt es?

4.tmpfs mount

tmpfs mount ist nur für Linux-Hosts verfügbar. Wenn wir tmpfs mount zum Erstellen eines Containers verwenden, kann der Container Dateien außerhalb der beschreibbaren Ebene des Containers erstellen. Behalten Sie die Daten im Speicher und wenn der Container gestoppt wird, werden auch die geschriebenen Daten entfernt. Wird hauptsächlich zur temporären Speicherung vertraulicher Dateien verwendet, die nicht auf der beschreibbaren Ebene des Hosts oder Containers verbleiben sollen.

Mounten Sie einen Speicherblock über die Option --tmpfs.

[root@localhost volumes]# docker run -dt -v /usr/share/nginx/html --name nginx_with_volume nginx
d25bdfce9c7ac7bde5ae35067f6d9cf9f0cd2c9cbea6d1bbd7127b3949ef5ac6
[root@localhost volumes]# docker volume ls 
DRIVER    VOLUME NAME
local     d8e943f57d17a255f8a4ac3ecbd6471a735aa64cc7a606c52f61319a6c754980
local     nginx_volume
[root@localhost volumes]# ls /var/lib/docker/volumes/
backingFsBlockDev  d8e943f57d17a255f8a4ac3ecbd6471a735aa64cc7a606c52f61319a6c754980  metadata.db  nginx_volume
Nach dem Login kopieren

Geben Sie Parameter in die Methode --mount ein, um die Größe des temporären Speichers anzugeben.

docker run -dt --name busybox_tmpfs --tmpfs /etc/running busybox
Nach dem Login kopieren

Speicherdatenfreigabe

在容器之间共享数据主要有两种方法,第一种比较简单,只需要将目录或者volume挂载到多个容器中即可。这里不做赘述,我们来看一下通过中间容器实现共享的方式。

我们创建一个中间容器,包含绑定挂载目录和一个卷。

docker create -v /share:/volume1 -v /volume2  --name volume_share  busybox
Nach dem Login kopieren

在我们需要共享的容器中通过选项--volumes-from拿过来用即可

docker run -d -t --volumes-from volume_share  --name container1  busybox
Nach dem Login kopieren

我们inspect检查一下Mounts字段,此时container1已经挂载到了一个bind目录和一个volume

"Mounts": [
    {
        "Type": "bind",
        "Source": "/share",
        "Destination": "/volume1",
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    },
    {
        "Type": "volume",
        "Name": "21605e49a0ba90a1b952a32c1b3f0d42735da8bfe718f0dc76c37e91f1e51c0e",
        "Source": "/var/lib/docker/volumes/21605e49a0ba90a1b952a32c1b3f0d42735da8bfe718f0dc76c37e91f1e51c0e/_data",
        "Destination": "/volume2",
        "Driver": "local",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    }
],
Nach dem Login kopieren

推荐学习:《docker视频教程

Das obige ist der detaillierte Inhalt vonWelche Möglichkeiten der Docker-Speicherung gibt es?. 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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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)

So verlassen Sie den Container mit Docker So verlassen Sie den Container mit Docker Apr 15, 2025 pm 12:15 PM

Vier Möglichkeiten zum Beenden von Docker Container: Verwenden Sie Strg D im Befehl Container Terminal ENGEBOT IM Container Terminal verwenden Sie Docker Stop & lt; container_name & gt; Befehl verwenden Sie Docker Kill & lt; container_name & gt; Befehl im Host -Terminal (Force Exit)

So kopieren Sie Dateien in Docker nach außen So kopieren Sie Dateien in Docker nach außen Apr 15, 2025 pm 12:12 PM

Methoden zum Kopieren von Dateien in externen Hosts in Docker: Verwenden Sie den Befehl Docker CP: Docker CP [Optionen] & lt; Containerpfad & gt; & lt; Host -Pfad & gt;. Verwenden von Datenvolumina: Erstellen Sie ein Verzeichnis auf dem Host und verwenden Sie den Parameter -V, um das Verzeichnis in den Container zu montieren, um den Container zu erstellen, um eine bidirektionale Dateisynchronisation zu erreichen.

So starten Sie Docker neu So starten Sie Docker neu Apr 15, 2025 pm 12:06 PM

So starten Sie den Docker -Container neu: Holen Sie sich die Container -ID (Docker PS); Stop den Container (Docker Stop & lt; Container_id & gt;); Starten Sie den Container (Docker start & lt; container_id & gt;); Stellen Sie sicher, dass der Neustart erfolgreich ist (Docker PS). Andere Methoden: Docker Compose (Docker-Compose Neustart) oder Docker-API (siehe Docker-Dokumentation).

So starten Sie MySQL von Docker So starten Sie MySQL von Docker Apr 15, 2025 pm 12:09 PM

Der Prozess des Startens von MySQL in Docker besteht aus den folgenden Schritten: Ziehen Sie das MySQL -Image zum Erstellen und Starten des Containers an, setzen

So überprüfen Sie den Namen des Docker -Containers So überprüfen Sie den Namen des Docker -Containers Apr 15, 2025 pm 12:21 PM

Sie können den Namen des Docker -Containers abfragen, indem Sie den Schritten folgen: Alle Container auflisten (Docker PS). Filtern Sie die Containerliste (unter Verwendung des GREP -Befehls). Ruft den Containernamen ab (befindet sich in der Spalte "Namen").

So aktualisieren Sie das Bild von Docker So aktualisieren Sie das Bild von Docker Apr 15, 2025 pm 12:03 PM

Die Schritte zur Aktualisierung eines Docker -Images sind wie folgt: Ziehen Sie das neueste Bild -Tag. Neues Bild Löschen Sie das alte Bild für ein bestimmtes Tag (optional) den Container neu (falls erforderlich) neu starten Sie neu (falls erforderlich).

So sehen Sie den Docker -Prozess So sehen Sie den Docker -Prozess Apr 15, 2025 am 11:48 AM

Docker Process Viewing -Methode: 1. Docker Cli -Befehl: Docker PS; 2. SYSTEMD CLI -Befehl: SystemCTL Status Docker; 3.. Docker Compose CLI Command: Docker-Compose PS; 4. Process Explorer (Windows); 5. /proc -Verzeichnis (Linux).

So ändern Sie die Docker -Bildquelle in China So ändern Sie die Docker -Bildquelle in China Apr 15, 2025 am 11:30 AM

Sie können zur Quelle der Inlandsspiegel wechseln. Die Schritte sind wie folgt: 1. Bearbeiten Sie die Konfigurationsdatei /etc/docker/daemon.json und fügen Sie die Spiegelquellenadresse hinzu; 2. Starten Sie den Docker Service Sudo SystemCtl Docker neu, um die Download -Geschwindigkeit und -stabilität des Bilddownloads zu verbessern.

See all articles