Aller au contenu

« Docker commandes » : différence entre les versions

De Marmits Wiki
Aucun résumé des modifications
Aucun résumé des modifications
Ligne 1 : Ligne 1 :
== Docker natif ==
Pour lancer un conteneur Docker sans démarrer Docker Desktop sur Ubuntu, vous devez utiliser le démon Docker directement via la ligne de commande.
- Démarrez le service Docker natif
<syntaxhighlight lang="bash" line copy>
sudo systemctl start docker
</syntaxhighlight>
- Vérifiez que le démon Docker fonctionne
<syntaxhighlight lang="bash" line copy>
sudo systemctl status docker
</syntaxhighlight>
- Désactivez Docker Desktop au démarrage
<syntaxhighlight lang="bash" line copy>
systemctl --user disable docker-desktop
</syntaxhighlight>
- Forcer Docker CLI à utiliser le socket natif<br />
Modifiez la variable d’environnement DOCKER_HOST pour pointer vers le socket système : <br />
(Pour que cela persiste après un redémarrage, ajoutez cette ligne dans ~/.bashrc ou ~/.zshrc.)
<syntaxhighlight lang="bash" line copy>
export DOCKER_HOST=unix:///var/run/docker.sock
</syntaxhighlight>
== Pratiques ==
== Pratiques ==
=== Images ===
=== Images ===

Version du 31 mai 2025 à 22:31

Docker natif

Pour lancer un conteneur Docker sans démarrer Docker Desktop sur Ubuntu, vous devez utiliser le démon Docker directement via la ligne de commande. - Démarrez le service Docker natif

sudo systemctl start docker

- Vérifiez que le démon Docker fonctionne

sudo systemctl status docker

- Désactivez Docker Desktop au démarrage

systemctl --user disable docker-desktop

- Forcer Docker CLI à utiliser le socket natif
Modifiez la variable d’environnement DOCKER_HOST pour pointer vers le socket système :
(Pour que cela persiste après un redémarrage, ajoutez cette ligne dans ~/.bashrc ou ~/.zshrc.)

export DOCKER_HOST=unix:///var/run/docker.sock

Pratiques

Images

Afficher ID + nom + tag

docker images --format "{{.Repository}}:{{.Tag}} {{.ID}}"
Trier uniquement les images uniques (comme -q) mais avec noms
docker images --format "{{.ID}} {{.Repository}}:{{.Tag}}" | sort -u

Scripts

Docker stop

Stop et supprime tous les conteneurs

#!/bin/bash

# Arrêter tous les conteneurs en cours d'exécution
docker stop $(docker ps -q)

# Supprimer tous les conteneurs
docker rm $(docker ps -a -q)

docker system prune -f
echo "Tous les conteneurs ont été supprimés."

Docker clean

Stop tous les containers, supprime les images, supprime les volumes

#!/bin/bash

# Arrêter tous les conteneurs en cours d'exécution
docker stop $(docker ps -q)

# Supprimer tous les conteneurs
docker rm $(docker ps -a -q)

# Supprimer toutes les images
docker rmi $(docker images -q)

# Supprimer tous les volumes
docker volume rm $(docker volume ls -q)

echo "Tous les conteneurs, images et volumes Docker ont été supprimés."

docker system prune -f

Divers

Commandes de base

#liste les conteneurs actifs. Aussi accessible par la commande docker ps [-a]. L'option -a liste aussi l'ensemble des conteneurs inactifs
docker container ls [-a]

#démarre une nouvelle instance d'un conteneur à partir d'une image donnée
docker container run ...image_de_base...

#crée un conteneur basé sur une image donnée sans le démarrer
docker container create ...image_de_base...

#stoppe un conteneur actif
docker container stop nom_conteneur

#démarre un conteneur inactif
docker container start nom_conteneur

#attache les entrées et sorties standards locales à un conteneur actif
docker container attach nom_conteneur

#exécute une commande dans un conteneur actif
docker container exec nom_conteneur commande

#supprime un conteneur inactif
docker container rm nom_conteneur

#supprime tous les conteneurs inactifs
docker container prune

#affiche les logs d'un conteneur actif
docker container logs [-f] nom_conteneur

#affiche les statistiques d'un conteneur actif
docker container stats nom_conteneur

#affiche les informations détaillées d'un conteneur actif
docker container inspect nom_conteneur

Commandes avec paramètres

#la commande pour my-mariadb va créer un répertoire par défaut (on ne peut pas le spécifier nous même)
docker run --name my-mariadb --detach --env MYSQL_ROOT_PASSWORD=root --network db-network -v /var/lib/mysql mariadb
docker run --network db-network --detach --publish 7080:8080 adminer

#permet de créer l'image de contacts_nginx_prod
docker build --target contacts_nginx_prod -t $USER/demo-contacts-web:1.0.0 .

source :