Dockerfile镜像的创建方法和容器通信

Docker镜像的创建方法:

  1. 基于已有镜像创建

其实质就是把一个容器里运动的程序以及该程序的运行环境打包生成新的镜像。

命令格式: docker   commit【选项】 容器ID/名称    仓库名称:标签

选项:-m:说明信息        -a:作者信息  -p:生成过程中停止容器的运行。

1)启动一个镜像,在容器里做修改,然后将修改后的容器提交称为新的镜像,需记住该容器的ID号。

Dockerfile镜像的创建方法和容器通信

2)使用docker commit命令创建一个新的镜像,如下:

[[email protected] ~]# docker commit -m 'zheshiyige web' -a 'linfan'   de07a3fb37ab  httpd:centos

sha256:679c6bfeff20d9fa17151a7d6574a4f9ee7a65cd7bf15f816416443aee1ed465

3)创建完成后,会返回创建镜像的ID信息。查看本地镜像列表可以看到新镜像信息。

[[email protected] ~]# docker images  | grep  httpd

httpd               centos              679c6bfeff20        29 minutes ago      357 MB

 

基于本地模板创建

导出

导入

 

  1. 基于dockerfile创建       重点知识

案例 使用dockerfile创建镜像并在容器中运行

  首先建立目录,作为生成镜像的工作目录,然后分别创建编写dockerfile文件 ,需要运行的脚本文件及要复制到容器的文件,执行步骤如下:

[[email protected] ~]# docker load < /mnt/centos       //导入centos镜像

  1. 创建工作目录

[[email protected] ~]# mkdir apache

[[email protected] ~]# cd apache/

  1. 创建并编写dockerfile文件

[[email protected] apache]# vim Dockerfile

#基于的基础镜像centos

FROM centos

#维护该镜像的用户信息

MAINTAINER  The Centos project <[email protected]>

#镜像操作指令安装apache软件包

RUN yum -y update

RUN yum -y install httpd

#开启80端口

EXPOSE  80

#复制网址首页文件

ADD     index.html   /var/www/html/index.html

#将执行脚本复制到镜像中

ADD     run.sh  /run.sh

RUN        chmod   775    /run.sh

#设置apache服务不自行启动

RUN     systemctl disable httpd

#启动容器时执行脚本

CMD   ["/run.sh"]                                                                             Dockerfile镜像的创建方法和容器通信

此dockerfile文件使用的基础镜像是centos,所有要保证首先获取此基础镜像,使用docker  pull  docker.io/centos获取镜像,之后的容器允许时才会生效。

  1. 编写执行脚本内容

[[email protected] apache]# vim run.sh

#!/bin/bash

rm -rf  /run/httpd/*                                  #清理httpd的缓存

exec  /usr/sbin/apachectl   -D   FOREGROUND    #启动apache服务

  1. 创建测试页面

[[email protected] apache]# echo "dockerfile" > index.html

Dockerfile镜像的创建方法和容器通信 5)使用Dockerifle生成镜像

[[email protected] apache]# docker build  -t  linux:centos   .    

-t:指定镜像的标签信息                 “.”:当前目录              

Dockerfile镜像的创建方法和容器通信

  1. 将新的镜像允许容器

[[email protected] apache]# docker run -d -p  80:80 linux:centos

dfb0a2833a03f47226dc73214ae3af5dcfd69560fef9f61fc50e3e7512930762    

-p选项实现从本地端口80到容器中80端口的映射。

Dockerfile镜像的创建方法和容器通信

 

测试页面:       

Dockerfile镜像的创建方法和容器通信

 

Docker的数据管理      

  在Docker中,方便查看容器内产生的数据或者将多个容器之间的数据实现共享,会涉及容器的数据管理操作。

  管理Docker容器中的数据主要有两种方式:数据卷和数据卷容器。

  1. 数据卷

  数据卷是一个供容器使用的特殊目录,位于容器当中,可将宿主机的目录挂着到数据卷上,对数据卷的修改操作立刻课件,更新操作不影响镜像,从而实现宿主机与容器之间的迁移,类似于mount操作。

案例:通过linux:centos镜像创建一个为web的容器并挂着/data1和/data2

-v:可创建多个数据卷  --name给容器创建一个友好的自定义名称。

[[email protected] /]# docker run -d -v /data1 -v /data2  --name web linux:centos

7aa3e831461eb3267c5f4af63e35c43d7ace8d23d7c09629dc50badd274e6e25

进入web容器

[[email protected] /]# docker exec -it web /bin/bash

[[email protected] /]# ls

anaconda-post.log  boot   data2  etc   lib    media  opt   root  run.sh  srv  tmp  var

bin                data1  dev    home  lib64  mnt    proc  run   sbin    sys  usr

 

  1. 挂载主机目录作为数据卷

[[email protected] /]# docker run -d -v /share:/data1 --name web1 linux:centos

3e61581c618ae24424f54e4c0b61dc3c41fcc8e19c73ad59728e5fafa672b07e

[[email protected] /]# docker exec -it web1 /bin/bash       //进入容器

[[email protected] /]# cd data1/

[[email protected] data1]# touch  1

[[email protected] data1]# exit

Exit

[[email protected] /]# cd /share/                        //宿主机

[[email protected] share]# ls

\1  

 

 

 

 

  1. 数据卷容器

  容器之间共享一些数据,最简单的办法就是通过数据卷容器。

  使用预先创建好的数据卷挂着/data1,使用volumes-from来挂着web1容器中的数据卷到新的容器,新的容器名为nginx,如下:

[[email protected] /]# docker run -it --volumes-from  web1 --name nginx linux:centos  /bin/bash

[[email protected] /]# ls

anaconda-post.log  boot   dev  home  lib64  mnt  proc  run     sbin  sys  usr

bin                data1  etc  lib   media  opt  root  run.sh  srv   tmp  var

[[email protected] /]# cd data1/

[[email protected] data1]# ls

1

 

 

  1. 端口映射

[[email protected] /]# docker run -d -P  linux:centos

76d6e84428a57112281743842969d33d6e21739e613afb5adc3bb634c423cb52

Dockerfile镜像的创建方法和容器通信

通过ps -a可以看到32768端口被映射到容器的80端口

-P:(大写)选项实现随机映射,docker会随机映射一个端口范围在49000-49900的端口内部开放的网络端口。

-p:(小写)实现指定的端口映射

[[email protected] /]# docker run -d -p   4444:80 linux:centos

a75e684258546531d8faff02bb4a9b159bc1ef2be931f63b20d78e548b511711

Dockerfile镜像的创建方法和容器通信

 

 

 

  1. 容器互联

  容器互联通过容器的名称在容器见建立一条专门的网络通信隧道从而实现的互联。

1)源容器

[[email protected] /]# docker run -d -P  --name  host1 linux:centos

8536ffe57dca8e4efd13e59a1d37e44683e197abbe73184448b7f28fc3e29e32

2)接收容器

[[email protected] /]# docker run -d -P  --name host2  --link host1:host linux:centos

01ac94598f2c5b6b8db8ee026ab52224137eb3f584dcbc4b450f0bc0d5c73d38

--link host1:host            --link 源容器:源容器的别名

3)测试容器互联

[email protected] /]# docker exec -it host2 /bin/bash

[[email protected] /]# ping host1

PING host (172.17.0.7) 56(84) bytes of data.

64 bytes from host (172.17.0.7): icmp_seq=1 ttl=64 time=0.152 ms

^C

[[email protected] /]# ping host

PING host (172.17.0.7) 56(84) bytes of data.

64 bytes from host (172.17.0.7): icmp_seq=1 ttl=64 time=0.075 ms

^C

--- host ping statistics ---