Docker File

概述

Docker File是一个由一系列命令组成的脚本文件,该脚本文件用来构建镜像文件,比如官方的tomcat、ngnix都是通过dockerfile构建的镜像

流程:开发应用=>DockerFile=>打包为镜像=>上传到仓库(私有仓库,公有仓库)=> 下载镜像 => 启动 运行。

步骤

1、基础语法

  • 每条保留字指令都必须为大写字母且后面要跟随至少一个参数
  • 指令按照从上到下,顺序执行
  • # 表示注释
  • 每条指令都会创建一个新的镜像层,并对镜像进行提交
  • 编写DockerFile文件 建议文件名dockerfile

2、流程

  • docker从基础镜像运行一个容器
  • 执行一条指令并对容器做出修改
  • 执行类似 docker commit 的操作提交一个新的镜像层
  • Docker再基于刚提交的镜像运行一个新容器
  • 执行dockerfile中的下一条指令直到所有指令都执行完成!

3、说明

从应用软件的角度来看,DockerFile,docker镜像与docker容器分别代表软件的三个不同阶段。 DockerFile 是软件的原材料 (代码) Docker 镜像则是软件的交付品 (.apk)

Docker 容器则是软件的运行状态 (客户下载安装执行)

DockerFile 面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可

DockerFile:需要定义一个DockerFile,DockerFile定义了进程需要的一切东西。DockerFile涉及的内容 包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进 程和内核进程(当引用进行需要和系统服务和内核进程打交道,这时需要考虑如何设计 namespace的权 限控制)等等。

Docker镜像:在DockerFile 定义了一个文件之后,Docker build 时会产生一个Docker镜像,当运行 Docker 镜像时,会真正开始提供服务;

Docker容器:容器是直接提供服务的。

4、关键字

FROM # 基础镜像,当前新镜像是基于哪个镜像的
MAINTAINER # 镜像维护者的姓名混合邮箱地址
RUN # 容器构建时需要运行的命令
EXPOSE # 当前容器对外保留出的端口
WORKDIR # 指定在创建容器后,终端默认登录的进来工作目录,一个落脚点
ENV # 用来在构建镜像过程中设置环境变量
ADD # 将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包
COPY # 类似ADD,拷贝文件和目录到镜像中!
VOLUME # 容器数据卷,用于数据保存和持久化工作
CMD # 指定一个容器启动时要运行的命令,dockerFile中可以有多个CMD指令,但只有最
后一个生效!
ENTRYPOINT # 指定一个容器启动时要运行的命令!和CMD一样
ONBUILD # 当构建一个被继承的DockerFile时运行命令,父镜像在被子镜像继承后,父镜像的
ONBUILD被触发

实战

Docker Hub 中99% 的镜像都是通过在base镜像(Scratch)中安装和配置需要的软件构建出来的

制作centos镜像

查看官方的centos

[root@izj6c22bffydfp7tlrbx7fz ~]# docker run  -it centos
[root@f9bb0cbe11d1 /]# pwd
/
[root@f9bb0cbe11d1 /]# vim test.txt
bash: vim: command not found
[root@f9bb0cbe11d1 /]# ifconfig
bash: ifconfig: command not found
[root@f9bb0cbe11d1 /]# 

不支持vim 、ifconfig等,自己制作一个支持vim和ifconfig的centos

编写dockerfile文件

mkdir docker_centos
vim dockerfile_centos

FROM centos
MAINTAINER lph<123@qq.com>
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo "----------end--------"
CMD /bin/bash

构建

#docker build -f dockerfile地址 -t 新镜像名字:TAG .
# . 表示当前目录
docker build -f dockerfile_centos -t mycentos:1.0 .

运行

docker run -it 新镜像名字:TAG

测试vim 和ifconfig

列出镜像地的变更历史

docker history 镜像名

CMD 和 ENTRYPOINT 的区别
两个命令都是指定一个容器启动时要运行的命令
CMD:Dockerfile 中可以有多个CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数
替换!
ENTRYPOINT: docker run 之后的参数会被当做参数传递给 ENTRYPOINT,之后形成新的命令组合!


测试CMD :
# 1、构建dockerfil
vim dockerfile-cmd-test

FROM centos
CMD [ "ls", "-a" ]

2、build 镜像
docker build -f dockerfile-cmd-test -t cmdtest .

3、执行
docker run 554bc6952657

会列出目录
etc
home
lib
lib64

如果我们希望用 -l 列表展示信息,我们就需要加上 -l参数
docker run cmdtest -l
但是运行报错,就是因为 -l 替换了原来的 CMD,而不是添加在原来的 ls -a 后面。而 -l 根本不是命令,所
以自然找不到。


测试ENTRYPOINT命令
vim dockerfile-entrypoint-test

FROM centos
ENTRYPOINT [ "ls", "-a" ]
    
docker build -f dockerfile-entrypoint-test -t entrypointtest .
docker run ae07199f9144
bin
dev
etc
home
lib
lib64

测试-l参数,发现可以直接使用,这里就是一种追加,我们可以明显的知道 CMD 和ENTRYPOINT 的区别了
docker run entrypointtest -l

自定义tomcat镜像

编写dockerfile

# vim Dockerfile
FROM centos
MAINTAINER lph<123@qq.com>
#把宿主机当前上下文的read.txt拷贝到容器/usr/local/路径下
COPY read.txt /usr/local/cincontainer.txt
#把java与tomcat添加到容器中
ADD jdk-8u11-linux-x64.tar.gz /usr/local/
ADD apache-tomcat-9.0.22.tar.gz /usr/local/
#安装vim编辑器
RUN yum -y install vim
#设置工作访问时候的WORKDIR路径,登录落脚点
ENV MYPATH /usr/local
WORKDIR $MYPATH
#配置java与tomcat环境变量
ENV JAVA_HOME /usr/local/jdk1.8.0_11
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.22
ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.22
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
#容器运行时监听的端口
EXPOSE 8080
#启动时运行tomcat
# ENTRYPOINT ["/usr/local/apache-tomcat-9.0.22/bin/startup.sh" ]
# CMD ["/usr/local/apache-tomcat-9.0.22/bin/catalina.sh","run"]
CMD /usr/local/apache-tomcat-9.0.22/bin/startup.sh && tail -F
/usr/local/apache-tomcat-9.0.22/bin/logs/catalina.out

构建镜像

#文件名是Dockerfile 不用写-f
docker build -t diytomcat .

备注:Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied 解决办法:在挂载目录后多加一个--privileged=true参数即可

启动

docker run -d -p 9090:8080 --name mydiytomcat -v
/home/kuangshen/build/tomcat/test:/usr/local/apache-tomcat9.0.22/webapps/test -v
/home/kuangshen/build/tomcat/tomcat9logs/:/usr/local/apache-tomcat9.0.22/logs --privileged=true diytomcat

验证测试访问! curl localhost:9090

结合前面学习的容器卷将测试的web服务test发布

发布镜像

注册dockerhub Docker Hub,需要有一个账号

# 1、查看登录命令
[root@lph tomcat]# docker login --help
Usage: docker login [OPTIONS] [SERVER]
# 2、登录
[root@lph tomcat]# docker login -u lph
Password:
WARNING! Your password will be stored unencrypted in
/root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentialsstore
Login Succeeded
# 3、将镜像发布出去
[root@lph tomcat]# docker push lph/diytomcat:1.0
The push refers to repository [docker.io/library/diytomcat]
0f02399c6fdf: Preparing
e79ea0c3a34e: Preparing
09281fa8fe38: Preparing
b56a902b0aef: Preparing
0683de282177: Preparing
# 拒绝:请求的资源访问被拒绝
denied: requested access to the resource is denied
# 问题:本地镜像名无帐号信息,解决加 tag即可
docker tag 251ca4419332 lph/diytomcat:1.0
# 再次 push, ok
[root@lph tomcat]# docker push lph/diytomcat:1.0
The push refers to repository [docker.io/lph/diytomcat]
0f02399c6fdf: Pushing [========> ]
9.729MB/59.76MB
e79ea0c3a34e: Pushing [==========> ]
3.188MB/15.41MB
09281fa8fe38: Pushing [> ]
3.823MB/324MB
b56a902b0aef: Pushed
0683de282177: Pushing [=> ]
5.997MB/237.1MB

阿里云镜像服务

1、登录阿里云 2、找到容器镜像服务

3、创建命名空间

4、创建镜像仓库

5、点击进入这个镜像仓库,可以看到所有的信息

6、测试推送发布

# 1、登录阿里云
[root@lph tomcat]# docker login --username=18225148644 registry.cnbeijing.aliyuncs.com
Password:
WARNING! Your password will be stored unencrypted in
/root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentialsstore
Login Succeeded
# 2、设置 tag
docker tag [ImageId] registry.cn-beijing.aliyuncs.com/bilibilikuangshen/lph-test:[镜像版本号]
[root@lph tomcat]# docker tag 251ca4419332 registry.cnbeijing.aliyuncs.com/bilibili-kuangshen/lph-test:v1.0
# 3、推送命令
docker push registry.cn-beijing.aliyuncs.com/bilibili-lph/lphtest:[镜像版本号]
[root@lph tomcat]# docker push registry.cnbeijing.aliyuncs.com/bilibili-lph/lph-test:v1.0

在阿里云镜像仓库查看效果!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序三两行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值