Device Mapper-Mechanismus im Linux-Systemkernel (1) (2)
Schauen wir uns die spezifische Implementierung der oben genannten drei Objekte im Code genauer an. Die in der Datei dm.c definierte Struktur „mapped_device“ wird zur Darstellung des zugeordneten Geräts verwendet. die registrierte Anforderungswarteschlange und einige Speicherpools und Felder wie Zeiger auf die entsprechenden Zuordnungstabellen. Die dem zugeordneten Gerät entsprechende Zuordnungstabelle wird durch die in der Datei dm_table.c definierte Struktur dm_table dargestellt. Diese Struktur enthält ein Array von dm_target-Strukturen. Die Struktur dm_target beschreibt speziell die Zuordnungsbeziehung zwischen zugeordnetem_Gerät und einem seiner Zielgeräte. In der dm_table-Struktur sind diese dm_targets in einer B-Baum-Struktur organisiert, um den Suchvorgang während der E/A-Anforderungszuordnung zu erleichtern. Die Dm_target-Struktur zeichnet insbesondere die Startadresse und den Bereich des zugeordneten logischen Gerätebereichs auf, der durch die dem Zielgerät entsprechende Struktur zugeordnet wird, und enthält außerdem einen Zeiger auf die target_type-Struktur der spezifischen zielgerätebezogenen Vorgänge. Die Target_type-Struktur enthält hauptsächlich den Namen des Zieltreiber-Plug-Ins, das dem Zielgerät entspricht, die definierten Methoden zum Erstellen und Löschen des Zielgeräts dieses Typs, die E/A-Anforderungs-Neuzuordnung und die End-E/A-Methoden, die dem Zielgerät dieses Typs entsprechen , usw. Das Feld, das das spezifische Zielgerät darstellt, ist das private Feld in dm_target, und der Zeiger zeigt auf die Struktur, die dem vom zugeordneten Gerät zugeordneten spezifischen Zielgerät entspricht. Zeigt an, dass sich die spezifische Struktur des Zielgeräts aufgrund unterschiedlicher Zieltypen unterscheidet. Beispielsweise ist die Struktur des einfachsten linearen Zuordnungszieltyps, der dem Zielgerät entspricht, die in der Datei dm-linear.c definierte Struktur linear_c. Seine Definition lautet wie folgt:
struct linear_c { struct dm_dev *dev; sector_t start; };
Die Definition des Zielgeräts ist recht einfach. Sie enthält nur den dm_dev-Strukturzeiger, der das entsprechende physische Gerät darstellt, und den Offset-Adressanfang in Einheiten von Sektoren im physischen Gerät . Die Beziehung zwischen den oben genannten Datenstrukturen ist in Abbildung 3 dargestellt:
Abbildung 3 Die Beziehung zwischen mehreren wichtigen Datenstrukturen im Device Mapper
Der Einrichtungsprozess in der Kernel
Im Folgenden stellen wir kurz den Prozess der Erstellung eines zugeordneten Geräts im Kernel mit spezifischem Code vor:
1 Gemäß den Parametern, die von der vom Kernel bereitgestellten ioctl-Schnittstelle an den Benutzerbereich übergeben werden , verwenden Sie dm- Die Funktion dev_create in der Datei ioctl.c erstellt die entsprechende zugeordnete Gerätestruktur. Dieser Prozess ist sehr einfach. Er gilt hauptsächlich für die erforderlichen Speicherressourcen im Kernel, einschließlich des zugeordneten Geräts und des für IO-Vorgänge vorab angewendeten Speicherpools. Die dem zugeordneten Gerät entsprechende Anforderungswarteschlange wird über die von bereitgestellte Funktion blk_queue_make_request registriert Kernel. Und registrieren Sie das zugeordnete Gerät als Festplattenblockgerät im Kernel.
2. Rufen Sie dm_hash_insert auf, um das erstellte zugeordnete Gerät in eine globale Hash-Tabelle im Geräte-Mapper einzufügen, die alle aktuell im Kernel erstellten zugeordneten Geräte speichert.
Das Obige ist der Inhalt des Device Mapper-Mechanismus (1) (2) im Linux-Systemkern. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die wichtigsten Unterschiede zwischen CentOS und Ubuntu sind: Ursprung (CentOS stammt von Red Hat, für Unternehmen; Ubuntu stammt aus Debian, für Einzelpersonen), Packungsmanagement (CentOS verwendet yum, konzentriert sich auf Stabilität; Ubuntu verwendet apt, für hohe Aktualisierungsfrequenz), Support Cycle (Centos) (CENTOS bieten 10 Jahre. Tutorials und Dokumente), Verwendungen (CentOS ist auf Server voreingenommen, Ubuntu ist für Server und Desktops geeignet). Weitere Unterschiede sind die Einfachheit der Installation (CentOS ist dünn)

CentOS wird 2024 geschlossen, da seine stromaufwärts gelegene Verteilung RHEL 8 geschlossen wurde. Diese Abschaltung wirkt sich auf das CentOS 8 -System aus und verhindert, dass es weiterhin Aktualisierungen erhalten. Benutzer sollten eine Migration planen, und empfohlene Optionen umfassen CentOS Stream, Almalinux und Rocky Linux, um das System sicher und stabil zu halten.

CentOS -Installationsschritte: Laden Sie das ISO -Bild herunter und verbrennen Sie bootfähige Medien. Starten und wählen Sie die Installationsquelle; Wählen Sie das Layout der Sprache und Tastatur aus. Konfigurieren Sie das Netzwerk; Partition die Festplatte; Setzen Sie die Systemuhr; Erstellen Sie den Root -Benutzer; Wählen Sie das Softwarepaket aus; Starten Sie die Installation; Starten Sie nach Abschluss der Installation von der Festplatte neu und starten Sie von der Festplatte.

Backup- und Wiederherstellungsrichtlinie von GitLab im Rahmen von CentOS -System Um die Datensicherheit und Wiederherstellung der Daten zu gewährleisten, bietet GitLab on CentOS eine Vielzahl von Sicherungsmethoden. In diesem Artikel werden mehrere gängige Sicherungsmethoden, Konfigurationsparameter und Wiederherstellungsprozesse im Detail eingeführt, um eine vollständige GitLab -Sicherungs- und Wiederherstellungsstrategie aufzubauen. 1. Manuell Backup Verwenden Sie den GitLab-RakegitLab: Backup: Befehl erstellen, um die manuelle Sicherung auszuführen. Dieser Befehl unterstützt wichtige Informationen wie GitLab Repository, Datenbank, Benutzer, Benutzergruppen, Schlüssel und Berechtigungen. Die Standardsicherungsdatei wird im Verzeichnis/var/opt/gitlab/backups gespeichert. Sie können /etc /gitlab ändern

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

Wie benutze ich Docker Desktop? Docker Desktop ist ein Werkzeug zum Ausführen von Docker -Containern auf lokalen Maschinen. Zu den zu verwendenden Schritten gehören: 1.. Docker Desktop installieren; 2. Start Docker Desktop; 3.. Erstellen Sie das Docker -Bild (mit Dockerfile); 4. Build Docker Image (mit Docker Build); 5. Docker -Container ausführen (mit Docker Run).

CentOS -Festplattenhalterung ist in die folgenden Schritte unterteilt: Bestimmen Sie den Namen der Festplattengeräte (/dev/sdx); Erstellen Sie einen Mountspunkt (es wird empfohlen, /mnt /newDisk zu verwenden). Führen Sie den Befehl montage (mont /dev /sdx1 /mnt /newdisk) aus; Bearbeiten Sie die Datei /etc /fstab, um eine permanente Konfiguration des Montings hinzuzufügen. Verwenden Sie den Befehl uMount, um das Gerät zu deinstallieren, um sicherzustellen, dass kein Prozess das Gerät verwendet.

Nachdem CentOS gestoppt wurde, können Benutzer die folgenden Maßnahmen ergreifen, um sich damit zu befassen: Wählen Sie eine kompatible Verteilung aus: wie Almalinux, Rocky Linux und CentOS Stream. Migrieren Sie auf kommerzielle Verteilungen: wie Red Hat Enterprise Linux, Oracle Linux. Upgrade auf CentOS 9 Stream: Rolling Distribution und bietet die neueste Technologie. Wählen Sie andere Linux -Verteilungen aus: wie Ubuntu, Debian. Bewerten Sie andere Optionen wie Container, virtuelle Maschinen oder Cloud -Plattformen.
