docker 数据管理 | 数据卷容器 | 容器互联
Docker 数据管理
在 Docker 中,为了方便查看容器内产生的数据或将多个容器中的数据实现共享,就涉及到容器的数据管理操作
数据卷
数据卷是一个供容器使用的特殊目录,位于容器中,对数据卷的修改操作立即可见,并且更新数据不会影响到镜像,从而实现数据在宿主机与容器之间的迁徙
类似于 Linux 中对目录进行的 mount 挂载操作
①创建数据卷
docker run -itd -v /data1 -v /data2 --name centos1 centos:7 /bin/bash
'//-v表示创建数据卷,多个-v可创建多个;--name可给容器自定义名称'
docker exec -it centos1 /bin/bash
'//可以两个数据卷data1和data2已挂载成功'
②挂载宿主机目录作为数据卷
docker run -itd -v /opt/:/data1 --name centos2 centos:7 /bin/bash
'//使用-v可以在创建数据卷的同时,将宿主机的目录挂载至数据卷上使用,实现宿主机与容器之间的数据迁徙'
'//宿主机目录为绝对路径,若没有该目录,则执行完命令后会创建该目录'
echo "hello world" > /opt/test.txt
docker exec -it centos2 /bin/bash
cat /data1/file
'//可以看到响应文件与内容,其验证了宿主机与容器之间的数据迁徙,反之亦然'
数据卷容器
如果需要在容器之间共享数据,我们可以使用数据卷容器
数据卷容器就是一个普通的容器,专门提供数据卷给其他容器挂载使用
docker run -itd -v /data1 -v /data2 --name test1 centos:7 /bin/bash
docker exec -it test1 /bin/bash
echo "123" > /data1/aa
echo "321" > /data2/bb
exit
docker run -itd --volumes-from test1 --name test2 centos:7 /bin/bash
docker exec -it test2 /bin/bash
cat data1/aa
cat data1/bb
echo "123123" >> /data1/aa
echo "321321" >> /data2/bb
exit
'//可以看到,通过数据卷容器机制,实现了容器之间的数据共享,这样可以有效预防单点故障'
Docker 网络通信
Docker 提供了映射容器端口到宿主机和容器互联机制来为容器提供网络服务
端口映射
在启动容器时,如果不指定对应的端口,那么在容器外将无法通过网络来访问容器的内容,Docker 提供端口映射机制来将容器内的服务提供给外部网络访问
其原理就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务
docker images
docker run -itd -p nginx:new
或者
docker run -itd -p 5555:80 nginx:new
docker ps -a
curl 192.168.78.11:5555
容器互联
容器互联就是通过容器的名称在容器之间建立一条专门的网络通信隧道,从而实现容器间的互联
①创建源容器
1.创建源容器
docker run -itd -P --name test3 centos:7 /bin/bash
2.创建接收容器
docker run -itd -P --name test4 --link test3:test3 centos:7 /bin/bash
'//使用link指定连接容器以实现容器互联'
3.测试容器互联
docker exec -it test4 /bin/bash
ping test3
容器互联需要双方全部配置,单方配置,只能单方通信
登陆test3 容器
无法ping通
自定义网络创建容器互联
docker network create --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet
docker run -itd --name nginx1 --net mynet nginx:new
docker run -itd --name nginx2 --net mynet nginx:new