Bonne nouvelle: le nouveau docker (version 19.03 (actuellement expérimentale)) pourra fonctionner sans racine, annulant les problèmes pouvant survenir avec un utilisateur root. Plus besoin de jouer avec les autorisations élevées, la racine et tout ce qui pourrait ouvrir votre machine lorsque vous ne le vouliez pas.
Vidéo à ce sujet de [DockerCon 2019] Durcissement du démon Docker avec le mode sans racine
Quelques mises en garde concernant le mode Docker sans racine
Les ingénieurs de Docker affirment que le mode sans racine ne peut pas être considéré comme un remplacement pour la suite complète des fonctionnalités du moteur Docker. Certaines limitations au mode sans racine incluent:
- contrôles de ressources de groupes de contrôle, profils de sécurité d'apparmor, point de contrôle / restauration, réseaux de superposition, etc. ne fonctionne pas en mode sans racine.
- L'exposition des ports à partir de conteneurs nécessite actuellement un processus manuel d'assistance socat.
- Seules les distributions basées sur Ubuntu prennent en charge les systèmes de fichiers superposés en mode sans racine.
- Le mode sans racine n'est actuellement fourni que pour les versions nocturnes qui peuvent ne pas être aussi stables que vous en avez l'habitude.
Depuis docker 19.3, c'est obsolète (et plus dangereux que nécessaire):
Le manuel docker a ceci à dire à ce sujet:
Donner un accès non root
Le démon docker s'exécute toujours en tant qu'utilisateur root, et depuis la version 0.5.2 de Docker, le démon docker se lie à un socket Unix au lieu d'un port TCP. Par défaut, ce socket Unix appartient à l'utilisateur root, et donc, par défaut, vous pouvez y accéder avec sudo.
À partir de la version 0.5.3, si vous (ou votre installateur Docker) créez un groupe Unix appelé docker et y ajoutez des utilisateurs, le démon docker rendra la propriété du socket Unix lisible/inscriptible par le groupe docker au démarrage du démon. Le démon docker doit toujours s'exécuter en tant qu'utilisateur root, mais si vous exécutez le client docker en tant qu'utilisateur du groupe docker, vous n'avez pas besoin d'ajouter sudo à toutes les commandes client. À partir de la version 0.9.0, vous pouvez spécifier qu'un groupe autre que docker doit posséder le socket Unix avec l'option-G.
Avertissement: Le groupe docker (ou le groupe spécifié avec-G) est équivalent à root; voir Détails de la Surface d'attaque du Démon Docker et ce billet de blog sur Pourquoi nous ne laissons pas les utilisateurs non root exécuter Docker dans CentOS, Fedora ou RHEL (merci michael-n).
Dans la récente publication du mode expérimental sans racine sur GitHub, les ingénieurs mentionnent que le mode sans racine permet d'exécuter dockerd en tant qu'utilisateur non privilégié, en utilisant user_namespaces(7), mount_namespaces(7), network_namespaces(7).
Les utilisateurs doivent exécuter dockerd-rootless.sh au lieu de dockerd.
$ dockerd-rootless.sh --experimental
Comme le mode sans racine est expérimental, les utilisateurs doivent toujours exécuter dockerd-rootless.sh avec-expérimental.
Important à lire: étapes de post-installation pour Linux (il renvoie également à Détails de la Surface d'attaque du Démon Docker).
Gérer Docker en tant qu'utilisateur non root
Le démon docker se lie à un socket Unix au lieu d'un port TCP. Par défaut, ce socket Unix appartient à l'utilisateur root et les autres utilisateurs ne peuvent y accéder qu'en utilisant sudo. Le démon docker s'exécute toujours en tant qu'utilisateur root.
Si vous ne souhaitez pas utiliser sudo lorsque vous utilisez la commande docker, créez un groupe Unix appelé docker et ajoutez-y des utilisateurs. Lorsque le démon docker démarre, il rend la propriété du socket Unix lisible en lecture/écriture par le groupe docker.
-
Ajoutez le groupe docker s'il n'existe pas déjà:
sudo groupadd docker
-
Ajoutez l'utilisateur connecté" USER USER & quot; au groupe docker. Modifiez le nom d'utilisateur pour qu'il corresponde à votre utilisateur préféré si vous ne souhaitez pas utiliser votre utilisateur actuel:
sudo gpasswd -a $USER docker
Soit faire un newgrp docker
ou déconnectez-vous/connectez-vous pour activer les modifications apportées aux groupes.
-
Vous pouvez utiliser
docker run hello-world
pour vérifier si vous pouvez exécuter docker sans sudo.