Maison >Opération et maintenance >Docker >Comment faire une mise en miroir de bases de données avec Docker
Docker est actuellement la technologie de conteneurisation la plus populaire, qui peut regrouper des applications et leurs dépendances dans un conteneur indépendant et s'exécuter dans différents environnements. Les bases de données sont un composant essentiel des applications, et leur exécution dans Docker est un scénario très courant car il fournit un moyen pratique, sûr et reproductible de tester, déployer et mettre à l'échelle des applications de bases de données.
Alors, comment créer une image de base de données dans Docker ? Les étapes pour créer un miroir de base de données MySQL sont décrites en détail ci-dessous.
1. Téléchargez l'image MySQL officielle
Vous pouvez télécharger l'image MySQL officielle sur Docker Hub Nous pouvons utiliser la commande suivante pour télécharger l'image MySQL depuis Docker Hub :
docker pull mysql/mysql-server
2 Créez une image MySQL personnalisée
Bien. Nous pouvons utiliser directement l'image MySQL officielle, mais elle peut ne pas répondre à nos besoins, tels que les fichiers de configuration, les scripts d'initialisation, la sauvegarde des données, etc. Par conséquent, nous devons créer une image personnalisée basée sur l’image officielle pour répondre à nos besoins.
1. Créer un Dockerfile
Dockerfile est un fichier texte qui contient une série d'instructions pour créer une image Docker. Nous utilisons l'image officielle MySQL comme base, puis créons une image personnalisée en ajoutant des fichiers de configuration, des scripts d'initialisation, une sauvegarde des données, etc.
Dans cet exemple, nous créons un fichier Dockerfile avec le contenu suivant :
FROM mysql/mysql-server # 安装telnet和net-tools RUN yum update && yum install -y telnet net-tools # 添加自定义配置文件 ADD my.cnf /etc/mysql/my.cnf # 添加初始化脚本 ADD init.sql /docker-entrypoint-initdb.d/ # 添加数据备份 ADD backup.sql /tmp/backup.sql
L'explication du fichier Dockerfile ci-dessus est la suivante :
2. Construire l'image
Dans cet exemple, nous avons préparé des fichiers Dockerfile, des fichiers de configuration personnalisés, des scripts d'initialisation, une sauvegarde de données et d'autres ressources. Ensuite, vous devez exécuter la commande suivante dans le répertoire où se trouve le fichier Dockerfile pour construire l'image :
docker build -t my-mysql:latest .
Parmi elles, -t est utilisé pour nommer l'image, et :latest signifie utiliser la dernière version.
3. Exécutez le conteneur MySQL
Maintenant que nous avons créé avec succès une image MySQL personnalisée, nous allons exécuter l'image dans le conteneur et attribuer un nom au conteneur :
docker run -d -p 3306:3306 --name my-mysql -v /data/mysql:/var/lib/mysql my-mysql
Parmi eux, -d signifie exécuter le conteneur dans en arrière-plan, -p mappe le port 3306 du conteneur au port 3306 de l'hôte, -v mappe le répertoire /data/mysql de l'hôte au répertoire /var/lib/mysql du conteneur et my-mysql représente le nom du conteneur.
Nous pouvons désormais utiliser l'outil client MySQL pour nous connecter au conteneur MySQL et tester qu'il fonctionne correctement.
mysql -h 127.0.0.1 -P 3306 -u root -p
4. Conclusion
Grâce à ce processus, nous avons appris à créer une image MySQL personnalisée dans Docker et à exécuter l'image. Cela facilite le test, le déploiement et la mise à l'échelle des applications de base de données. Dans les projets réels, nous pouvons ajouter davantage de configurations personnalisées et de scripts d'initialisation selon les besoins, ainsi que des données de sauvegarde et de récupération et d'autres fonctions.
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!