Maison Opération et maintenance Docker Les utilisateurs ne peuvent pas être ajoutés au conteneur Docker

Les utilisateurs ne peuvent pas être ajoutés au conteneur Docker

May 13, 2023 pm 04:47 PM

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
Copier après la connexion

该命令将允许非特权用户对用户命名空间进行克隆(clone)操作。接下来,我们需要为该用户命名空间指定一个独立的UID和GID,并将容器内的root用户映射到该命名空间的用户,使用以下命令:

echo "namespace    id  range" > /etc/subuid
echo "namespace    id  range" > /etc/subgid
Copier après la connexion

其中,namespace为该用户命名空间的命名空间ID,id为该用户命名空间的初始UID和GID,range为该用户命名空间允许的用户数目。

接下来,我们需要使用adduser

Comment ajouter des utilisateurs dans le conteneur Docker ?

Pour ajouter des utilisateurs dans un conteneur Docker, nous devons effectuer quelques opérations supplémentaires. Plus précisément, nous devons activer l'espace de noms utilisateur en modifiant le fichier de configuration du conteneur, spécifier un UID et un GID indépendants pour l'espace de noms utilisateur et mapper l'utilisateur root du conteneur à l'utilisateur de l'espace de noms.

En prenant Ubuntu comme exemple, utilisez la commande suivante dans le conteneur pour activer l'espace de noms utilisateur :

adduser --uid 1000 --gid 1000 myuser
Copier après la connexion
Cette commande permettra aux utilisateurs non privilégiés de cloner l'espace de noms utilisateur. Ensuite, nous devons spécifier un UID et un GID indépendants pour l'espace de noms de l'utilisateur, et mapper l'utilisateur root dans le conteneur à l'utilisateur de l'espace de noms, utilisez la commande suivante : 🎜rrreee🎜où l'espace de noms est le nom de l'espace de noms de l'utilisateur. ID d'espace , id est l'UID et le GID initiaux de l'espace de noms utilisateur, et range est le nombre d'utilisateurs autorisés dans l'espace de noms utilisateur. 🎜🎜Ensuite, nous devons utiliser la commande 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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Questions d'entrevue Docker: Ace Your DevOps Engineering Interview Questions d'entrevue Docker: Ace Your DevOps Engineering Interview Apr 06, 2025 am 12:01 AM

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.

Volumes de docker: gérer les données persistantes dans les conteneurs Volumes de docker: gérer les données persistantes dans les conteneurs Apr 04, 2025 am 12:19 AM

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.

Comment mettre à jour l'image de Docker Comment mettre à jour l'image de Docker Apr 15, 2025 pm 12:03 PM

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)

Decker Security Durcision: protéger vos conteneurs contre les vulnérabilités Decker Security Durcision: protéger vos conteneurs contre les vulnérabilités Apr 05, 2025 am 12:08 AM

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.

Comment sortir du conteneur par Docker Comment sortir du conteneur par Docker Apr 15, 2025 pm 12:15 PM

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)

Comment copier des fichiers dans Docker à l'extérieur Comment copier des fichiers dans Docker à l'extérieur Apr 15, 2025 pm 12:12 PM

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 Docker Comment redémarrer Docker Apr 15, 2025 pm 12:06 PM

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 Comment utiliser Docker Desktop Apr 15, 2025 am 11:45 AM

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

See all articles