docker的数据管理

目录

一.如何管理docker容器中的数据

二.数据卷

2.1数据卷原理

 2.2数据卷作用

 2.3数据卷案例

 三.数据卷容器

3.1数据卷容器的作用

 3.2端口映射

一.如何管理docker容器中的数据

docker的数据管理_第1张图片

  管理Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器( DataVolumes Containers)

二.数据卷

2.1数据卷原理

  • 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于​​​Linux下对目录进行的mount操作​​​。
docker pull centos:7
  • 宿主机目录/var/www挂载到容器中的/data1。​​
  • 注意:宿主机本地目录的路径必须是使用绝对路径​​​。如果路径不存在,Docker会自动创建相应的路径。

 2.2数据卷作用

  • 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的 mount操作。

 2.3数据卷案例

docker run -v /var/www:/data1 --name web1 -it centos:7     #-v选项可以在容器内创建数据卷
ls
echo "this is hehe" > /data1/abc.txt
exit
 
#返回宿主机进行查看
cat /var/www/1.txt

docker的数据管理_第2张图片

 三.数据卷容器

3.1数据卷容器的作用

  • 让两个容器实现数据共享
  • 如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
  • php ---->mysql之间想要通讯,通过socket
#创建一个容器作为数据卷容器
docker run -it --name niuma3 -v /data1 -v /data2 centos:7 bash #创建并进入容器
echo "this is niuma" > /data1/1.txt #容器内创建测试文件1
echo "THIS IS niuma2" > /data2/2.txt #容器内创建测试文件1
 
#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name niuma4 --volumes-from niuma3 centos:7 bash #创建并进入容器
cat data1/1.txt #查看测试数据是否同步
cat data2/2.txt

docker的数据管理_第3张图片

 3.2端口映射

  • 在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是​​​将宿主机的端口映射到容器中​​​,使得外部网络访问宿主机的端口便可访问容器内的服务。
docker run -d --name test1 -P nginx    #随机映射端口(从32768开始)
docker run -d --name test2 -p 43000:80 nginx  #指定映射端口
[root@localhost containers]# docker ps -a
CONTAINER ID   IMAGE          COMMAND                   CREATED          STATUS                          PORTS                                     NAMES
ad869aa1016a   nginx          "/docker-entrypoint.…"   19 seconds ago   Up 18 seconds                   0.0.0.0:43000->80/tcp, :::43000->80/tcp   test2
0afa76acdc9b   nginx          "/docker-entrypoint.…"   34 seconds ago   Up 33 seconds                   0.0.0.0:32768->80/tcp, :::32768->80/tcp   test1


浏览器访问: http://192.168.40.23:43000. http://192.168.40.23:32768

docker的数据管理_第4张图片

docker的数据管理_第5张图片

 

你可能感兴趣的:(docker,容器,运维)