目录
一、数据卷
数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的mount操作。
1.1 数据卷原理
将容器内部的配置文件目录,挂载到宿主机指定目录下
- 数据卷默认会一直存在,即使容器被删除
- 宿主机和容器是两个不同的名称空间,如果想进行连接需要使用ssh,exec和attch也类似于ssh这种方式登录
- 在企业中ssh这种登录方式会比较危险,安全漏洞很大,尽量减少ssh这种,杜绝了频繁使用exec
- 因此使用数据卷的凡是把容器内部的文件挂载到宿主机指定目录下进行修改,当容器里的文件频繁需要更改时不需要登录进行,直接使用数据卷方式在宿主机指定的目录下进行修改即可。方便又安全
1.2 数据卷作用
数据卷是一个共容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行地mount操作
1.3 数据卷案例
如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
实例:将宿主机目录/var/www分别挂载到c1、c2容器中地/data1,/data2
创建两个容器,指定挂载点,并在宿主目录写入数据
docker run -itd -v /var/www:/data1 --name c1 centos:7 bash
docker run -itd -v /var/www:/data2 --name c2 centos:7 bash
#在宿主机目录写入数据
echo "123456" >1.txt
另外开两个终端,分别登录c1、c2容器,并查看挂载点目录里地文件
数据同步到c1容器
数据同步到c2容器
在c2容器上创建一个文件,宿主机和c1上也能看到
二、数据卷容器
3.1 数据卷容器作用
让两个容器实现数据共享
如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
php ---->mysql之间想要通讯,通过socket
3.2 数据卷容器案例
需求:创建数据卷容器
#创建一个容器作为数据卷容器
docker run -it --name test1 -v /data1 -v/data2 centos:7 bash #创建并进入容器
echo "this is test1 file" > /data1/test.txt #容器内创建测试文件1
echo "this is test2 file" > /data2/test2.txt #容器内创建测试文件2
#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name test2 --volumes-from test1 centos:7 bash
cat /data1/test.txt
cat /data2/test2.txt
创建一个容器作为数据卷容器并创建文件
使用–volumes-from来挂载test1容器中的数据卷到新的容器
三、容器互联(使用centos镜像)
容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息
#查看容器
[root@docker ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
93dbfd32177c centos:7 "bash" 6 minutes ago Up 6 minutes test2
48ba88d84379 centos:7 "bash" 7 minutes ago Exited (127) 46 seconds ago test1
f9a292476cef centos:7 "bash" 23 minutes ago Up 23 minutes c2
793e30ace52c centos:7 "bash" 24 minutes ago Up 24 minutes c1
#进入c1,ping c2发现ping不通
[root@docker ~]# docker exec -it c1 bash
[root@793e30ace52c /]# ping c2
ping: c2: Name or service not known
[root@793e30ace52c /]# exit
exit
#创建并运行接收容器取名c3,使用--1ink选项指定连接容器以实现容器互联
#--1ink容器名:连接的别名
[root@docker ~]# docker run -itd -P --name c3 --link c2:cw centos:7 /bin/bash
0c61b45abc90bdfef69f35e3a532648843b1d81616f7661feeb99f104f6b29c6
#进入c3,ping c2 可以ping通
[root@docker ~]# docker exec -it c3 bash
[root@0c61b45abc90 /]# ping c2
PING cw (172.17.0.3) 56(84) bytes of data.
64 bytes from cw (172.17.0.3): icmp_seq=1 ttl=64 time=0.068 ms
64 bytes from cw (172.17.0.3): icmp_seq=2 ttl=64 time=0.065 ms
64 bytes from cw (172.17.0.3): icmp_seq=3 ttl=64 time=0.061 ms
^C
--- cw ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2003ms
rtt min/avg/max/mdev = 0.061/0.064/0.068/0.009 ms
#也可以通过IP互联
[root@0c61b45abc90 /]# ping 172.17.0.3
PING 172.17.0.3 (172.17.0.3) 56(84) bytes of data.
64 bytes from 172.17.0.3: icmp_seq=1 ttl=64 time=0.052 ms
64 bytes from 172.17.0.3: icmp_seq=2 ttl=64 time=0.104 ms
64 bytes from 172.17.0.3: icmp_seq=3 ttl=64 time=0.075 ms
^C
--- 172.17.0.3 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2003ms
rtt min/avg/max/mdev = 0.052/0.077/0.104/0.021 ms
[root@0c61b45abc90 /]# exit
exit
#进入c2,下载网络工具,查看ip
[root@docker ~]# docker exec -it c2 bash
[root@f9a292476cef /]# yum -y install net-tools
[root@f9a292476cef /]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.17.0.3 netmask 255.255.0.0 broadcast 172.17.255.255
ether 02:42:ac:11:00:03 txqueuelen 0 (Ethernet)
RX packets 16447 bytes 26061021 (24.8 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 10262 bytes 557531 (544.4 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
loop txqueuelen 1000 (Local Loopback)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0