大家好,18一19docker相信很多的网友都不是很明白,包括18一19docker4K也是一样,不过没有关系,接下来就来为大家分享关于18一19docker和18一19docker4K的一些知识点,大家可以关注收藏,免得下次来找不到哦,下面我们开始吧!
文章大纲:
能够基于已有镜像、本地镜像和docker创建镜像能够管理docker的数据卷和数据卷容器能够通过端口映射和容器互联实现docker容器的网络互通Docker镜像的创建方法:·基于已有镜像创建
其实质就是把一个容器里运动的程序以及该程序的运行环境打包生成新的镜像。
命令格式:dockercommit【选项】容器ID/名称仓库名称:标签
选项:-m:说明信息-a:作者信息-p:生成过程中停止容器的运行。
1)启动一个镜像,在容器里做修改,然后将修改后的容器提交称为新的镜像,需记住该容器的ID号。
2)使用dockercommit命令创建一个新的镜像,如下:
[root@localhost~]#dockercommit-m'zheshiyigeweb'-a'linfan'de07a3fb37abhttpd:centos
sha256:679c6bfeff20d9fa17151a7d6574a4f9ee7a65cd7bf15f816416443aee1ed465
3)创建完成后,会返回创建镜像的ID信息。查看本地镜像列表可以看到新镜像信息。
[root@localhost~]#dockerimages|grephttpd
httpdcentos679c6bfeff2029minutesago357MB
基于本地模板创建
导出
导入
·基于dockerfile创建
案例使用dockerfile创建镜像并在容器中运行
首先建立目录,作为生成镜像的工作目录,然后分别创建编写dockerfile文件,需要运行的脚本文件及要复制到容器的文件,执行步骤如下:
[root@localhost~]#dockerload</mnt/centos//导入centos镜像
1)创建工作目录
[root@localhost~]#mkdirapache
[root@localhost~]#cdapache/
2)创建并编写dockerfile文件
[root@localhostapache]#vimdockerfile
#基于的基础镜像centos
FROMcentos
#维护该镜像的用户信息
MAINTAINERTheCentosproject<Cloud-ops@centos.org>
#镜像操作指令安装apache软件包
RUNyum-yupdate
RUNyum-yinstallhttpd
#开启80端口
EXPOSE80
#复制网址首页文件
ADDindex.html/var/www/html/index.html
#将执行脚本复制到镜像中
ADDrun.sh/run.sh
RUNchmod775/run.sh
#设置apache服务不自行启动
RUNsystemctldisablehttpd
#启动容器时执行脚本
CMD["/run.sh"]
此dockerfile文件使用的基础镜像是centos,所以要保证首先获取此基础镜像,使用dockerpulldocker.io/centos获取镜像,之后的容器允许时才会生效。
3)编写执行脚本内容
[root@localhostapache]#vimrun.sh
#!/bin/bash
rm-rf/run/httpd/*#清理httpd的缓存
exec/usr/sbin/apachectl-DFOREGROUND#启动apache服务
4)创建测试页面
[root@localhostapache]#echo"dockerfile">index.html
5)使用Dockerifle生成镜像
[root@localhostapache]#dockerbuild-tlinux:centos.
-t:指定镜像的标签信息".":当前目录
6)将新的镜像允许容器
[root@localhostapache]#dockerrun-d-p80:80linux:centos
dfb0a2833a03f47226dc73214ae3af5dcfd69560fef9f61fc50e3e7512930762
-p选项实现从本地端口80到容器中80端口的映射。
测试页面:
Docker的数据管理
在Docker中,方便查看容器内产生的数据或者将多个容器之间的数据实现共享,会涉及容器的数据管理操作。
管理Docker容器中的数据主要有两种方式:数据卷和数据卷容器。
·数据卷
数据卷是一个供容器使用的特殊目录,位于容器当中,可将宿主机的目录挂着到数据卷上,对数据卷的修改操作立刻可见,更新操作不影响镜像,从而实现宿主机与容器之间的迁移,类似于mount操作。
案例:通过linux:centos镜像创建一个为web的容器并挂着/data1和/data2
-v:可创建多个数据库--name给容器创建一个友好的自定义名称。
[root@localhost/]#dockerrun-d-v/data1-v/data2--nameweblinux:centos
7aa3e831461eb3267c5f4af63e35c43d7ace8d23d7c09629dc50badd274e6e25
进入web容器
[root@localhost/]#dockerexec-itweb/bin/bash
[root@7aa3e831461e/]#ls
anaconda-post.logbootdata2etclibmediaoptrootrun.shsrvtmpvar
bindata1devhomelib64mntprocrunsbinsysusr
·挂载主机目录作为数据卷
[root@localhost/]#dockerrun-d-v/share:/data1--nameweb1linux:centos
3e61581c618ae24424f54e4c0b61dc3c41fcc8e19c73ad59728e5fafa672b07e
[root@localhost/]#dockerexec-itweb1/bin/bash//进入容器
[root@3e61581c618a/]#cddata1/
[root@3e61581c618adata1]#touch1
[root@3e61581c618adata1]#exit
Exit
[root@localhost/]#cd/share///宿主机
[root@localhostshare]#ls
\1
·数据卷容器
容器之间共享一些数据,最简单的办法就是通过数据卷容器。
使用预先创建好的数据卷挂着/data1,使用volumes-from来挂着web1容器中的数据卷到新的容器,新的容器名为nginx,如下:
[root@localhost/]#dockerrun-it--volumes-fromweb1--namenginxlinux:centos/bin/bash
[root@eacc9825ec7e/]#ls
anaconda-post.logbootdevhomelib64mntprocrunsbinsysusr
bindata1etclibmediaoptrootrun.shsrvtmpvar
[root@eacc9825ec7e/]#cddata1/
[root@eacc9825ec7edata1]#ls
1
·端口映射
[root@localhost/]#dockerrun-d-Plinux:centos
76d6e84428a57112281743842969d33d6e21739e613afb5adc3bb634c423cb52
通过ps-a可以看到32768端口被映射到容器的80端口
-P:(大写)选项实现随机映射,docker会随机映射一个端口范围在49000-49900的端口内部开放的网络端口。
-p:(小写)实现指定的端口映射
[root@localhost/]#dockerrun-d-p4444:80linux:centos
a75e684258546531d8faff02bb4a9b159bc1ef2be931f63b20d78e548b511711
·容器互联
容器互联通过容器的名称在容器间建立一条专门的网络通信隧道从而实现的互联。
1)源容器
[root@localhost/]#dockerrun-d-P--namehost1linux:centos
8536ffe57dca8e4efd13e59a1d37e44683e197abbe73184448b7f28fc3e29e32
2)接收容器
[root@localhost/]#dockerrun-d-P--namehost2--linkhost1:hostlinux:centos
01ac94598f2c5b6b8db8ee026ab52224137eb3f584dcbc4b450f0bc0d5c73d38
--linkhost1:host--link源容器:源容器的别名
3)测试容器互联
root@localhost/]#dockerexec-ithost2/bin/bash
[root@01ac94598f2c/]#pinghost1
PINGhost(172.17.0.7)56(84)bytesofdata.
64bytesfromhost(172.17.0.7):icmp_seq=1ttl=64time=0.152ms
^C
[root@01ac94598f2c/]#pinghost
PINGhost(172.17.0.7)56(84)bytesofdata.
64bytesfromhost(172.17.0.7):icmp_seq=1ttl=64time=0.075ms
^C
---hostpingstatistics---
好了,关于18一19docker和18一19docker4K的问题到这里结束啦,希望可以解决您的问题哈!