Maison  >  Article  >  Opération et maintenance  >  Docker résume et partage la technologie du volume de données

Docker résume et partage la technologie du volume de données

WBOY
WBOYavant
2022-01-14 18:44:581703parcourir

Cet article vous apporte les connaissances pertinentes sur la technologie du volume de données résumées et partagées par Docker. J'espère qu'il sera utile à tout le monde. La technologie de volume de données Docker

sera Emballez-le avec l'environnement dans un miroir !

Docker résume et partage la technologie du volume de donnéesDes données ? Si les données sont dans le conteneur, alors si nous supprimons le conteneur, les données seront perdues ! Condition : les données peuvent être conservées

MySQL, si le conteneur est supprimé, la base de données sera supprimée et s'enfuira ---> Condition : les données MySQL peuvent être stockées localement ! Il peut y avoir une technologie de partage de données entre conteneurs ! Les données générées dans le conteneur Docker sont synchronisées avec le local ! C'est la technique du roulage ! Montage de répertoire, montez le répertoire dans notre conteneur sous Linux !

Docker résume et partage la technologie du volume de donnéesRésumé : opérations de persistance et de synchronisation des conteneurs ! Le partage de données peut également être réalisé entre conteneurs !

Using Volumes Data Volumes

docker run -it -v 宿主机目录: 容器目录 -p 主机端口:容器端口 容器id
Procédure à pas pratiques pour afficher les détails de la synchronisation

Créez un fichier dans le conteneur pour voir s'il est synchronisé avec le dossier local

quand le conteneur est fermé Ensuite, modifiez le fichier local pour voir si la modification sera synchronisée avec le fichier dans le conteneur

Docker résume et partage la technologie du volume de données

Mysql combat réel

command

docker run -d -p 3310:3306 -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
paramètre

-d opération en arrière-plan

- p mappage de port

-v Montage du volume de données : synchroniser les données Docker résume et partage la technologie du volume de données

-e Définir les variables d'environnement : le mot de passe de connexion MySQL est défini ici

--name Nommer le conteneur

Docker résume et partage la technologie du volume de données

Résultat du test : Connexion réussie

Docker résume et partage la technologie du volume de données

Problèmes rencontrésLa dernière version de mysql utilisée en premier : 8.0----Lors de l'utilisation de navicat pour se connecter, des erreurs inexplicables sont toujours signalées

Solution : Passer à la version 5.7, il n'y a pas de problème

Lorsque nous exécutons le miroir mysql, nous n'ajoutons pas -e MYSQL_ROOT_PASSWORD=123456 pour définir le mot de passe. Le conteneur sera toujours fermé et ne sera pas ouvert même s'il est redémarré

Ajoutez -e MYSQL_ROOT_PASSWORD=123456 pour l'activer parfaitement

Même si nous supprimons le conteneur. , et le volume de données que nous avons monté sur le local n'est toujours pas perdu. Cela réalise la fonction de persistance des données du conteneur

montage nommé et montage anonyme

Docker résume et partage la technologie du volume de donnéesmontage anonyme

-v chemin dans le. récipient! Docker résume et partage la technologie du volume de données

docker run -d --name nginx01 -v /etc/nginx nginx

Ici, nous avons constaté qu'il s'agit d'un montage anonyme. Après -v, nous avons uniquement écrit le chemin à l'intérieur du conteneur, pas le chemin à l'extérieur du conteneur

Afficher l'état de tous les volumes

docker volume ls

Montage nommé.

-v Le nom du volume monté : le chemin dans le conteneur

docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx nginx
Ici, nous constatons qu'il s'agit d'un montage anonyme. Nous écrivons le chemin dans le conteneur après -v, et il n'y a pas de conteneur Un chemin externe. , mais avec un nom

Répertoire de contenu de Docker : /var/lib/docker Tous les volumes du conteneur docker, sans spécifier de répertoire, se trouvent dans : /var/lib/docker /volume/xx/_data

Nous pouvons facilement trouver l'un de nos volumes grâce au montage nommé, et la méthode la plus couramment utilisée lors de l'utilisation de volumes est le montage nommé

Connaissances supplémentairesDocker résume et partage la technologie du volume de données

Comment faire la distinction entre le montage nommé et le montage anonyme, précisez le chemin à monter -v chemin à l'intérieur du conteneur #Montage anonyme

-v nom du volume : chemin à l'intérieur du conteneur #Montage nommé

-v /chemin à l'extérieur du conteneur : à l'intérieur du conteneur Chemin #Spécifiez le chemin à monter

Extension

Docker résume et partage la technologie du volume de données-v Chemin du conteneur : ro rw Modifier les autorisations de lecture et d'écriture

ro lecture seule Lecture seule

rw readwrite Lisible et inscriptible

一旦设置了这个容器权限,容器对我们挂载出来的内容就有限定了

docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx:ro nginx
docker run -d --name nginx01 -v 具名挂在名称:/etc/nginx:rw nginx

Ro 只要看到ro就说明这个路径只能通过宿主机来进行操作,容器内是无法操作的!

初识Dockerfile

dockerfile

dockerfile就是用来构建docker镜像文件的!命令脚本!先体验一下

通过这个脚本可以生成镜像,镜像是一层一层的,脚本是一个个的命令,每个命令都是一层!

写一个dockerfile

# 创立一个dockerfile文件,名字可以随便的取,最好叫做dockerfile
# 文件中的内容 指令(大写) 参数
FROM centos
VOLUME ["volme01","volume02"]
CMD echo "--------end----------"
CMD /bin/bash
#这里每个指令就是镜像的一层

使用dockerfile生成镜像

docker build -f dockerfile文件位置 -t 镜像名称和版本 镜像生成的位置

Docker résume et partage la technologie du volume de données

进入镜像查看详情

Docker résume et partage la technologie du volume de données

查看卷的同步目录

docker ps -a

docker inspect 容器id

Docker résume et partage la technologie du volume de données

最后测试两个文件夹中是不是同步

同步成功

总结

使用dockerfile构建镜像的方式在我们未来的使用中非常的多,因为我们通常会构建自己的镜像

假设构建镜像时候没有挂载卷,要手动镜像挂载-v

数据卷容器

实际上即使保证的容器之间的数据共享的问题

Docker résume et partage la technologie du volume de données

数据卷容器实际上就是被拷贝数据的容器(A- volumes-from ->B,B是数据卷容器)

测试两个镜像之间同步

首先先开三个容器

创建docker01

Docker résume et partage la technologie du volume de données

创建docker02  --volumes-from docekr01

Docker résume et partage la technologie du volume de données

创建docker03  --volumes-from docekr02

Docker résume et partage la technologie du volume de données

查看docker01和docker03之间的数据共享

Docker résume et partage la technologie du volume de données

接着我们将docker02删除,查看docker01和docker03之间的数据共享

Docker résume et partage la technologie du volume de données

总结:

Docker résume et partage la technologie du volume de données

实现多个mysql之间的数据共享

  docker run -d -p 3310:3306 -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
  docker run -d -p 3310:3306 --volumes-from mysql01 -e MYSQL_ROOT_PASSWORD=123456 --name 
  mysql02 mysql:5.7

总结:

容器之间配置信息的传递。数据卷容器的声明周期一直持续到没有容器使用位置

理解:容器之间只要是共享就会数据copy,即使有的容器被删除,数据依然存在,直到所有共享 的容器都删除,数据才会被彻底删除

但是一旦你持久化到了本地,这个时候,本地的数据是不会删除的。

推荐学习:《docker视频教程

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer