Docker容器-------数据卷和数据卷容器

目录

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

二、数据卷

1、数据卷原理

2、数据卷作用

3、数据卷案例

3.1 创建两个容器,指定挂载点,并在宿主目录写入数据

3.2 另外开两个终端,分别登陆c1 c2容器,并查看挂载点目录里的文件

三、数据卷容器

1、数据卷容器作用

2、数据卷容器案例

四、容器互联(使用centos镜像)

五、总结


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

二、数据卷

1、数据卷原理

将容器内部的配置文件目录,挂载到宿主机指定目录下

1.数据卷默认会一直存在,即使容器被删除

2.宿主机和容器是两个不同的名称空间,如果想进行连接需要用ssh,exec和attch也类似于ssh这种方式登录

3.在企业中ssh这种登陆方式会比较危险,安全漏洞很大,尽量减少ssh这种,杜绝了频繁使用exec

4.因此使用数据卷的方式把容器内部的文件目录挂载到宿主机指定目录下进行修改,当容器里的文件频繁需要修改时不需要登陆进去,直接使用数据卷方式在宿主机指定的目录下进行修改即可。方便又安全
 

2、数据卷作用

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

3、数据卷案例

实例:将宿主机目录 /var/www 分别挂载到c1 c2容器中的 /data1,/data2

3.1 创建两个容器,指定挂载点,并在宿主目录写入数据

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 "aaaaa" > bbb.txt

 

3.2 另外开两个终端,分别登陆c1 c2容器,并查看挂载点目录里的文件

 

 

 

三、数据卷容器

1、数据卷容器作用

让两个容器实现数据共享

如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。

php ---->mysql之间想要通讯,通过socket

2、数据卷容器案例

需求:创建数据卷容器

#创建一个容器作为数据卷容器
docker run -it --name test1 -v /data1 -v /data2 centos:7 bash	#创建并进入容器
echo "this is test02 file" > /data1/test.txt		  	#容器内创建测试文件1
echo "THIS IS TEST2 FILE" > /data2/TEST.txt					#容器内创建测试文件2

#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name test2 --volumes-from test1 centos:7 bash	#创建并进入容器
cat data1/test.txt											#查看测试数据是否同步
cat data2/TEST.txt

四、容器互联(使用centos镜像)

容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。

[root@localhost ~]# docker ps -a
CONTAINER ID   IMAGE          COMMAND                  CREATED          STATUS        
c8ae4e12e72e   centos:7       "/bin/bash"              2 minutes ago    Exited (0) 32 
615ca8cff410   centos:7       "/bin/bash"              3 minutes ago    Exited (0) 2 m
6386c804a6a8   centos:7       "/bin/bash"              36 minutes ago   Up 36 minutes 
8f5dc29c808b   centos:7       "/bin/bash"              36 minutes ago   Up 36 minutes 
32d73116e070   nginx:latest   "/docker-entrypoint.…"   3 days ago       Exited (255) 2
b58ea50c4ce1   nginx:latest   "/docker-entrypoint.…"   3 days ago       Exited (255) 2
bb523ec8743d   centos:7       "/bin/bash"              3 days ago       Exited (255) 2
6fee13e6605e   mysql          "docker-entrypoint.s…"   4 days ago       Exited (255) 4
6c8cec97ab3b   nginx          "/docker-entrypoint.…"   5 days ago       Exited (137) 3
d2ad35a3fba8   hello-world    "/hello"                 5 days ago       Exited (0) 5 d
[root@localhost ~]# docker exec -it c1 /bin/bash
[root@8f5dc29c808b /]# ping c2
ping: c2: Name or service not known
[root@8f5dc29c808b /]# exit
[root@localhost ~]# docker run -itd -P --name c3 --link c2:c2 centos:7 /bin/bash
fc1e901a2ce024022bf098a651bd3bec39e0c845b4c01f5665142f060e9dde91
[root@localhost ~]# docker exec -it c3 /bin/bash
[root@fc1e901a2ce0 /]# ping c2
PING c2 (172.17.0.3) 56(84) bytes of data.
64 bytes from c2 (172.17.0.3): icmp_seq=1 ttl=64 time=0.453 ms
64 bytes from c2 (172.17.0.3): icmp_seq=2 ttl=64 time=0.050 ms
64 bytes from c2 (172.17.0.3): icmp_seq=3 ttl=64 time=0.066 ms
64 bytes from c2 (172.17.0.3): icmp_seq=4 ttl=64 time=0.063 ms
64 bytes from c2 (172.17.0.3): icmp_seq=5 ttl=64 time=0.054 ms
^C
--- c2 ping statistics ---
5 packets transmitted, 5 received, 0% packet loss, time 4000ms
rtt min/avg/max/mdev = 0.050/0.137/0.453/0.158 ms
[root@fc1e901a2ce0 /]# 
[root@fc1e901a2ce0 /]# yum install -y net-tools
[root@fc1e901a2ce0 /]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 172.17.0.4  netmask 255.255.0.0  broadcast 172.17.255.255
        ether 02:42:ac:11:00:04  txqueuelen 0  (Ethernet)
        RX packets 3269  bytes 24474682 (23.3 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 3090  bytes 170648 (166.6 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


 

 

五、总结

本文介绍了通过数据卷和数据卷容器对容器内数据进行共享、备份和恢复等操作,通过这些机制,即使容器在运行中出现故障,用户也不必担心数据发生丢失,只需要快速地重新创建容器即可。在生成容器的同时,加上-v选项,指定把当前服务器的目录映射到容器中。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值