Mécanisme Device Mapper dans le noyau du système Linux (1) (2)
Examinons de plus près l'implémentation spécifique des trois objets ci-dessus dans le code. La structure mapped_device définie dans le fichier dm.c est utilisée pour représenter le périphérique mappé. Elle inclut principalement les verrous liés au périphérique mappé, la file d'attente des requêtes enregistrées et certains pools de mémoire ainsi que des champs tels que des pointeurs vers ses tables de mappage correspondantes. La table de mappage correspondant au périphérique mappé est représentée par la structure dm_table définie dans le fichier dm_table.c. Cette structure contient un tableau de structures dm_target décrit spécifiquement la relation de mappage entre mapped_device et l'un de ses périphériques cibles. Dans la structure dm_table, ces dm_targets sont organisés de manière B-tree pour faciliter l'opération de recherche lors du mappage des requêtes IO. La structure Dm_target enregistre spécifiquement l'adresse de début et la plage de la zone logique du périphérique mappé mappée par la structure correspondant au périphérique cible, et contient également un pointeur vers la structure target_type des opérations spécifiques liées au périphérique cible. La structure Target_type contient principalement le nom du plug-in du pilote cible correspondant au périphérique cible, les méthodes définies de construction et de suppression du périphérique cible de ce type, le remappage de la requête IO et la fin des méthodes IO correspondant au périphérique cible de ce type. , etc. Le champ représentant le périphérique cible spécifique est le champ privé dans dm_target, et le pointeur pointe vers la structure correspondant au périphérique cible spécifique mappé par le périphérique mappé. Indique que la structure spécifique du périphérique cible diffère en raison de différents types de cibles. Par exemple, la structure du type de cible de mappage linéaire le plus simple correspondant au périphérique cible est la structure Linear_c définie dans le fichier dm-linear.c. Sa définition est la suivante :
struct linear_c { struct dm_dev *dev; sector_t start; };
La définition du périphérique cible est assez simple, elle inclut uniquement le pointeur de structure dm_dev représentant le périphérique physique correspondant et le début de l'adresse de décalage en unités de secteurs dans le périphérique physique . La relation entre les structures de données ci-dessus est illustrée dans la figure 3 :
Figure 3 La relation entre plusieurs structures de données importantes dans le mappeur de périphériques
Le processus d'établissement dans le noyau
Ci-dessous, nous présentons brièvement le processus de création d'un périphérique mappé dans le noyau avec un code spécifique :
1 Selon les paramètres transmis par l'interface ioctl fournie par le noyau à l'espace utilisateur. , utilisez dm- La fonction dev_create dans le fichier ioctl.c crée la structure de périphérique mappée correspondante. Ce processus est très simple. Il s'applique principalement au noyau pour les ressources mémoire nécessaires, y compris le périphérique mappé et le pool de mémoire pré-appliqué pour les opérations d'E/S. La file d'attente de requêtes dm_request correspondant au périphérique mappé est enregistrée via la fonction blk_queue_make_request fournie par le. noyau. Et enregistrez le périphérique mappé en tant que périphérique de bloc de disque dans le noyau.
2. Appelez dm_hash_insert pour insérer le périphérique mappé créé dans une table de hachage globale dans le mappeur de périphériques. Cette table stocke tous les périphériques mappés actuellement créés dans le noyau.
Ce qui précède est le contenu du mécanisme Device Mapper (1) (2) dans le noyau du système Linux. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php.cn) !

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Les principales différences entre Centos et Ubuntu sont: l'origine (Centos provient de Red Hat, pour les entreprises; Ubuntu provient de Debian, pour les particuliers), la gestion des packages (Centos utilise Yum, se concentrant sur la stabilité; Ubuntu utilise APT, pour une fréquence de mise à jour élevée), le cycle de support (CentOS fournit 10 ans de soutien, Ubuntu fournit un large soutien de LT tutoriels et documents), utilisations (Centos est biaisé vers les serveurs, Ubuntu convient aux serveurs et aux ordinateurs de bureau), d'autres différences incluent la simplicité de l'installation (Centos est mince)

Centos sera fermé en 2024 parce que sa distribution en amont, Rhel 8, a été fermée. Cette fermeture affectera le système CentOS 8, l'empêchant de continuer à recevoir des mises à jour. Les utilisateurs doivent planifier la migration et les options recommandées incluent CentOS Stream, Almalinux et Rocky Linux pour garder le système en sécurité et stable.

Étapes d'installation de CentOS: Téléchargez l'image ISO et Burn Bootable Media; démarrer et sélectionner la source d'installation; sélectionnez la langue et la disposition du clavier; configurer le réseau; partitionner le disque dur; définir l'horloge système; créer l'utilisateur racine; sélectionnez le progiciel; démarrer l'installation; Redémarrez et démarrez à partir du disque dur une fois l'installation terminée.

La politique de sauvegarde et de récupération de GitLab dans le système CentOS afin d'assurer la sécurité et la récupérabilité des données, Gitlab on CentOS fournit une variété de méthodes de sauvegarde. Cet article introduira plusieurs méthodes de sauvegarde courantes, paramètres de configuration et processus de récupération en détail pour vous aider à établir une stratégie complète de sauvegarde et de récupération de GitLab. 1. MANUEL BACKUP Utilisez le Gitlab-RakegitLab: Backup: Créer la commande pour exécuter la sauvegarde manuelle. Cette commande sauvegarde des informations clés telles que le référentiel Gitlab, la base de données, les utilisateurs, les groupes d'utilisateurs, les clés et les autorisations. Le fichier de sauvegarde par défaut est stocké dans le répertoire / var / opt / gitlab / backups. Vous pouvez modifier / etc / gitlab

Docker utilise les fonctionnalités du noyau Linux pour fournir un environnement de fonctionnement d'application efficace et isolé. Son principe de travail est le suivant: 1. Le miroir est utilisé comme modèle en lecture seule, qui contient tout ce dont vous avez besoin pour exécuter l'application; 2. Le Système de fichiers Union (UnionFS) empile plusieurs systèmes de fichiers, ne stockant que les différences, l'économie d'espace et l'accélération; 3. Le démon gère les miroirs et les conteneurs, et le client les utilise pour l'interaction; 4. Les espaces de noms et les CGROUP implémentent l'isolement des conteneurs et les limitations de ressources; 5. Modes de réseau multiples prennent en charge l'interconnexion du conteneur. Ce n'est qu'en comprenant ces concepts principaux que vous pouvez mieux utiliser Docker.

Comment utiliser Docker Desktop? Docker Desktop est un outil pour exécuter des conteneurs Docker sur les machines locales. Les étapes à utiliser incluent: 1. Installer Docker Desktop; 2. Démarrer Docker Desktop; 3. Créer une image Docker (à l'aide de DockerFile); 4. Build Docker Image (en utilisant Docker Build); 5. Exécuter Docker Container (à l'aide de Docker Run).

Le support de disque dur CentOS est divisé en étapes suivantes: Déterminez le nom du périphérique du disque dur (/ dev / sdx); créer un point de montage (il est recommandé d'utiliser / mnt / newdisk); Exécutez la commande Mount (mont / dev / sdx1 / mnt / newdisk); modifier le fichier / etc / fstab pour ajouter une configuration de montage permanent; Utilisez la commande umount pour désinstaller l'appareil pour vous assurer qu'aucun processus n'utilise l'appareil.

Une fois CentOS arrêté, les utilisateurs peuvent prendre les mesures suivantes pour y faire face: sélectionnez une distribution compatible: comme Almalinux, Rocky Linux et CentOS Stream. Migrez vers les distributions commerciales: telles que Red Hat Enterprise Linux, Oracle Linux. Passez à Centos 9 Stream: Rolling Distribution, fournissant les dernières technologies. Sélectionnez d'autres distributions Linux: comme Ubuntu, Debian. Évaluez d'autres options telles que les conteneurs, les machines virtuelles ou les plates-formes cloud.
