Docker: Volumes
Comment persister les données de vos conteneurs avec les volumes Docker
👋 Bienvenue sur la documentation de Stackhero !
Stackhero propose une solution Docker cloud CaaS (Containers as a Service) prête à l'emploi offrant de nombreux avantages, notamment :
- Déployez facilement vos containers en production avec un simple
docker-compose up.- Nom de domaine personnalisable sécurisé avec HTTPS (par exemple, https://api.votre-entreprise.com, https://www.votre-entreprise.com, https://backoffice.votre-entreprise.com).
- Performance optimale et sécurité robuste grâce à une VM privée et dédiée.
- Mises à jour simplifiées en un clic.
Gagnez du temps et simplifiez-vous la vie : il suffit de 5 minutes pour essayer la solution d'hébergement cloud Docker CaaS de Stackhero et déployer vos containers en production !
Par conception, les conteneurs Docker sont éphémères. Cela signifie que toutes les données stockées directement à l'intérieur seront perdues lorsque le conteneur sera supprimé ou remplacé par une autre instance. Pour garantir la persistance des données, les volumes Docker sont la méthode recommandée.
N'utilisez pas les bind mounts Docker
N'utilisez pas les bind mounts sur Stackhero. Optez toujours pour les volumes Docker pour éviter toute perte de données.
Les bind mounts impliquent de lier un répertoire de la VM hôte Stackhero à un conteneur. Cependant, si vous vous appuyez sur les bind mounts, la mise à jour de votre instance Stackhero for Docker entraînera la perte de toutes les données stockées de cette manière.
Les bind mounts sont généralement spécifiés dans la commande docker run avec une syntaxe comme -v /monRepertoire:/mnt (notez le / initial). Dans les fichiers Docker Compose, ils apparaissent comme volumes: /monRepertoire:/mnt. Bannissez ces configurations ou vous perdrez vos données.
À la place, utilisez les volumes Docker, qui sont gérés par Docker et ne font pas référence à des chemins absolus.
Pour résumer :
Approche incorrecte :
docker run -it -v /monRepertoire:/mnt alpine
Approche correcte :
docker volume create monVolume
docker run -it -v monVolume:/mnt alpine
Lors de l'utilisation de fichiers Docker Compose :
Configuration incorrecte :
services:
monService:
image: alpine
volumes:
- /monRepertoire:/mnt
Configuration correcte :
services:
monService:
image: alpine
volumes:
- monVolume:/mnt
volumes:
monVolume:
name: monVolume
Commandes pratiques pour les volumes Docker
Voici une référence rapide pour gérer les volumes Docker :
-
Pour créer un nouveau volume nommé
monVolume, exécutez :docker volume create monVolume -
Pour lister tous les volumes existants :
docker volume ls -
Pour supprimer un volume spécifique nommé
monVolume:docker volume rm monVolumeRemarque : La suppression d'un volume supprimera définitivement toutes les données qu'il contient, et il n'y a aucun moyen de les récupérer par la suite.