


Les utilisateurs ne peuvent pas être ajoutés au conteneur Docker
Ces dernières années, avec le développement rapide de la technologie de cloud computing et de conteneurisation, Docker est devenue l'une des technologies de conteneurs les plus populaires. Cependant, bien que Docker ait été largement utilisé, certains problèmes courants doivent encore être résolus lors de l'utilisation de conteneurs Docker. L'un des problèmes est que les utilisateurs ne peuvent pas être ajoutés dans le conteneur Docker.
Pourquoi ne puis-je pas ajouter d'utilisateurs au conteneur Docker ?
Nous devons d’abord comprendre comment Docker fonctionne en interne. Docker utilise l'espace de noms du noyau Linux pour réaliser l'isolation entre les processus. Ces espaces de noms incluent l'espace de noms PID, l'espace de noms UTS, l'espace de noms réseau, etc. Parmi eux, l'espace de noms d'utilisateur est utilisé pour isoler les utilisateurs et les ID de groupe d'utilisateurs. Par défaut, les conteneurs Docker utilisent l'UID et le GID de l'espace de noms de l'utilisateur hôte. Cela signifie que dans le conteneur, vous ne pouvez pas utiliser de commandes telles que useradd
pour créer un utilisateur, car lorsque vous créez un nouvel utilisateur, il n'y a pas d'UID et de GID correspondants dans l'espace de noms du conteneur. useradd
等命令创建用户,因为再创建一个新用户时,容器内的命名空间中没有对应的UID和GID。
如何在Docker容器内增加用户?
要在Docker容器内增加用户,我们需要进行一些额外的操作。具体来说,我们需要通过修改容器的配置文件来启用用户namespace,并为该用户命名空间指定一个独立的UID和GID,并将容器内的root用户映射到该命名空间的用户。
以Ubuntu为例,在容器内使用以下命令即可启用用户namespace:
sysctl kernel.unprivileged_userns_clone=1
该命令将允许非特权用户对用户命名空间进行克隆(clone)操作。接下来,我们需要为该用户命名空间指定一个独立的UID和GID,并将容器内的root用户映射到该命名空间的用户,使用以下命令:
echo "namespace id range" > /etc/subuid echo "namespace id range" > /etc/subgid
其中,namespace为该用户命名空间的命名空间ID,id为该用户命名空间的初始UID和GID,range为该用户命名空间允许的用户数目。
接下来,我们需要使用adduser
adduser --uid 1000 --gid 1000 myuser
adduser
pour créer un nouvel utilisateur et ajouter l'utilisateur au conteneur : 🎜rrreee🎜 Parmi eux, les paramètres --uid et --gid ajoutent l'utilisateur à notre Dans les espaces de noms UID et GID séparés définis précédemment. 🎜🎜Résumé🎜🎜Le problème de l'impossibilité d'ajouter des utilisateurs dans un conteneur Docker peut être résolu en activant l'espace de noms utilisateur et en spécifiant un UID et un GID indépendants pour l'espace de noms. Même si cela nécessite un travail supplémentaire, l’augmentation de la sécurité et de l’isolement en vaut la peine. À mesure que la technologie des conteneurs continue de se développer, nous pensons que des solutions plus simples et plus pratiques apparaîtront à l’avenir. 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

Docker est une compétence incontournable pour les ingénieurs DevOps. 1.Docker est une plate-forme conteneurisée open source qui atteint l'isolement et la portabilité par les applications d'emballage et leurs dépendances dans les conteneurs. 2. Docker fonctionne avec les espaces de noms, les groupes de contrôle et les systèmes de fichiers fédérés. 3. L'utilisation de base comprend la création, l'exécution et la gestion des conteneurs. 4. L'utilisation avancée comprend l'utilisation de dockercosive pour gérer les applications multi-container. 5. Les erreurs courantes incluent une défaillance des conteneurs, des problèmes de cartographie des ports et des problèmes de persistance des données. Les compétences de débogage incluent la visualisation des journaux, la saisie des conteneurs et la visualisation d'informations détaillées. 6. L'optimisation des performances et les meilleures pratiques incluent l'optimisation de l'image, les contraintes de ressources, l'optimisation du réseau et les meilleures pratiques pour l'utilisation de dockerfile.

Dockervolumes garantit que les données restent sûres lorsque les conteneurs sont redémarrés, supprimés ou migrés. 1. Créer un volume: dockervolumecreatemydata. 2. Exécutez le conteneur et le volume de montage: dockerrun-it-vmydata: / app / dataubuntubash. 3. L'utilisation avancée comprend le partage de données et la sauvegarde.

Les étapes pour mettre à jour une image Docker sont les suivantes: Tirez la dernière étiquette d'image Nouvelle image Supprimer l'ancienne image pour une balise spécifique (facultative) Redémarrez le conteneur (si nécessaire)

Les méthodes d'amélioration de la sécurité Docker incluent: 1. Utilisez le paramètre - Cap-Drop pour limiter les capacités Linux, 2. Créer des conteneurs en lecture seule, 3. Définissez les balises Selinux. Ces stratégies protègent les conteneurs en réduisant l'exposition à la vulnérabilité et en limitant les capacités de l'attaquant.

Quatre façons de quitter Docker Container: Utilisez Ctrl D dans le terminal de conteneur Entrez la commande d'exit dans le terminal de conteneur Utilisez Docker Stop & lt; contener_name & gt; Commande utilise docker kill & lt; contener_name & gt; commande dans le terminal hôte (sortie de force)

Méthodes de copie de fichiers en hôtes externes dans Docker: Utilisez la commande docker cp: exécuter docker cp [options] & lt; Container Path & gt; & lt; Host Path & gt;. Utilisation de volumes de données: créez un répertoire sur l'hôte et utilisez le paramètre -v pour monter le répertoire dans le conteneur lors de la création du conteneur pour obtenir la synchronisation de fichiers bidirectionnels.

Comment redémarrer le conteneur Docker: Obtenez l'ID de conteneur (Docker PS); Arrêtez le conteneur (docker stop & lt; contener_id & gt;); Démarrer le conteneur (docker start & lt; contener_id & gt;); Vérifiez que le redémarrage réussit (Docker PS). Autres méthodes: Docker Compose (redémarrage Docker-Compose) ou API Docker (voir Docker Documentation).

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).
