Aller au contenu

« Docker commandes » : différence entre les versions

De Marmits Wiki
Aucun résumé des modifications
 
Ligne 62 : Ligne 62 :
docker volume rm $(docker volume ls -qf dangling=true)
docker volume rm $(docker volume ls -qf dangling=true)
</syntaxhighlight>
</syntaxhighlight>
== Mettre à jour un container 🔥 ==
{| class="wikitable"
|-
! Besoin
! Commande recommandée
|-
| Rebuild simple
| <code>docker compose up -d --build</code>
|-
| Rebuild sans cache
| <code>docker compose build --no-cache &amp;&amp; docker compose up -d</code>
|-
| Recréer containers proprement
| <code>docker compose up -d --force-recreate</code>
|-
| Tout supprimer puis repartir propre
| <code>docker compose down &amp;&amp; docker compose up -d --build</code>
|-
| Mettre à jour le <code>FROM</code>
| <code>docker compose build --pull</code>
|}


== Pratiques ==
== Pratiques ==
Ligne 171 : Ligne 194 :
<a href="https://discordapp.com/users/284694598888980480"><img src='https://img.shields.io/badge/captnsharky-blue?logo=discord&logoColor=white' /></a>
<a href="https://discordapp.com/users/284694598888980480"><img src='https://img.shields.io/badge/captnsharky-blue?logo=discord&logoColor=white' /></a>
‎</html>
‎</html>


[[Catégorie:Docker]]
[[Catégorie:Docker]]

Dernière version du 8 janvier 2026 à 12:09

Inspect Container

docker inspect NOM_DU_CONTAINER | grep -E '(Image|Volumes|Network|"Path"|Status|tmp|HostPort|HostIp|IPAddress|Type|Source|Destination|com.docker.compose.project.working_dir)'

Liste images

docker images

Taille image

docker image inspect mon-image:latest --format='{{.Size}}' | numfmt --to=iec

statistiques globales

Montre l'espace utilisé par toutes les images, conteneurs et volumes.

docker system df

Processus

- Vérifier les processus détaillés

docker exec -it CONTAINER_NAME ps aux



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

- Désactiver Docker Desktop (si vous ne l’utilisez plus)

systemctl --user stop docker-desktop
systemctl --user disable docker-desktop

Volumes orphelins

Lister les volumes inutilisés

docker volume ls -qf dangling=true

Les supprimer

docker volume rm $(docker volume ls -qf dangling=true)

Mettre à jour un container 🔥

Besoin Commande recommandée
Rebuild simple docker compose up -d --build
Rebuild sans cache docker compose build --no-cache && docker compose up -d
Recréer containers proprement docker compose up -d --force-recreate
Tout supprimer puis repartir propre docker compose down && docker compose up -d --build
Mettre à jour le FROM docker compose build --pull

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 :