docker数据管理和网络通信+docker实例+dockerfile镜像实战

一、Docker 的数据管理

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

1.数据卷(主机和容器间的挂载)

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

docker pull centos:7

#宿主机目录/opt/www 挂载到容器中的/data1。
注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。

[root@localhost ~]# docker run -v /opt/www:/data01 --name test01 -it centos:7 /bin/bash
 #-v 选项可以在容器内创建数据卷       #创建容器test01并进入    #/var/www:/data1 左边是主机的路径,右边是容器1路径


[root@38e468fcd989 /]# ls
   data01
[root@38e468fcd989 /]# echo "this is web1" > /data01/test.txt
[root@38e468fcd989 /]# cat /data01/test.txt

   this is web1
[root@38e468fcd989 /]# exit
 

#返回宿主机进行查看

[root@localhost ~]# cd /opt/www
[root@localhost www]# ls
test.txt
[root@localhost www]# cat test.txt 
this is web1

2.数据卷容器(容器和容器间的挂载)

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

#创建一个容器作为数据卷容器
[root@localhost ]# docker run --name test02 -v /data01 -v /data02 -it centos:7 /bin/bash                #创建并运行容器test02    #挂载目录为test01的 /data01 和 /data02
[root@5e6c2a984919 /]# echo "this is data01" > /data01/yss.txt

[root@5e6c2a984919 data02]# echo "this is data02" > /data02/yss02.txt

[root@5e6c2a984919 data02]# exit

#使用 --volumes-from 来挂载 web2 容器中的数据卷到新的容器
[root@localhost ]# docker run -it --volumes-from test02 --name test03 centos:7 /bin/bash
   #创建容器test03,挂载test02的目录到test03上

[root@1f4657b34fca /]# ls data01
yss.txt
[root@1f4657b34fca /]# ls data02
yss02.txt
 


二、端口映射

在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。

docker run -itd --name nginx01 -P nginx:latest               #随机映射端口(从32768开始)

docker run -itd --name nginx01 -p 8001:80 nginx:latest /bin/bash      #指定映射端口(映射主机的8000到docker的80上)

docker ps -a
CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS                   NAMESeba897edbb71   nginx:latest   "/docker-entrypoint.…"   29 seconds ago       Up 28 seconds               0.0.0.0:8001->80/tcp, :::8001->80/tcp     nginx02
ef93bc0cfbb0   nginx:latest   "/docker-entrypoint.…"   About a minute ago   Up About a minute           0.0.0.0:32768->80/tcp, :::32768->80/tcp   nginx01

浏览器访问:http://192.168.190.10:8001    、http://192.168.190.10:32768


三、容器互联(接收容器能ping通源容器)(使用centos镜像)

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

只有接收容器能ping通源容器

#创建并运行源容器取名test04
docker run -itd -P --name test04 centos:7 /bin/bash    
    
#创建并运行接收容器取名test05,使用--link选项指定连接容器以实现容器互联
docker run -itd -P --name test05 --link test04:test04 centos:7 /bin/bash            #--link 容器名:连接的别名

#进test05 容器, ping test04

docker exec -it test05 /bin/bash
[root@e4288a5d0006 /]# ping test04


四、Docker 镜像的创建

创建镜像有三种方法,分别为基于已有镜像创建、基于本地模板创建以及基于Dockerfile创建。

1.基于现有镜像创建

(1)首先启动一个镜像,在容器里做

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值