Dockerfile


Dockerfile介绍

Dockerfile就是用来构建docker镜像的构建文件!命令脚本!通过这个脚本可以生成镜像,镜像是一层一层的,脚本一个个的命令,每个命令都是一层!

构建步骤:

  1. 编写一个dockerfile文件
  2. docker build 构建成为一个镜像
  3. docker run 通过镜像生成并运行容器
  4. docker push 发布镜像(DockerHub、阿里云镜像仓库!)

查看一下官方是怎么做的?

https://hub.docker.com/上搜索centos,点击版本链接,就会跳转到github官网

image-20221012224953547_20230303145624075572.png

这就是官方制作的centos的Dockerfile,很多功能都没有,比如clear

image-20221012225112331_20230303145639532934.png

Dockerfile构建过程

基础知识:

  1. 每个保留关键字(指令)都必须是大写字母
  2. 执行从上到下顺序执行
  3. 表示注释

  4. 每一个指令都会创建提交一个新的镜像层,并提交!

dockerfile是面向开发的,我们以后要发布项目,做镜像,就需要编写dockerfile文件,这个文件十分简单!

docker镜像逐渐称为企业交付的标准,必须要掌握!

步骤:开发,部署,运维

DockerFile:构建文件,定义了一切的步骤,源代码

DockerImages:通过DockerFile构建生成的镜像,最终发布和运行的产品!

Docker容器:容器就是镜像运行起来提供服务的

Dockerfile指令

FROM # 基础镜像,一切从这里开始构建
MAINTAINER # 镜像是谁写的,姓名+邮箱
RUN # 镜像构建的时候需要运行的命令
ADD # 步骤:tomcat镜像,这个tomcat压缩包!添加内容
WORKDIR # 镜像的工作目录
VOLUME # 挂载的目录
EXPOSE # 保留端口配置
CMD # 指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT # 指定这个容器启动的时候要运行的命令,可以追加命令
ONBUILD # 当构建一个被继承DockerFile 这个时候就会运行ONBUILD的指令,触发指令
COPY # 类似ADD,将我们文件拷贝到镜像中
ENV # 构建的时候设置环境变量

DockerFile_20230303145703578655.png

ADD与COPY的区别

ADD拷贝文件会将压缩文件自动解压,COPY不支持

CMD与ENTRYPOINT区别

CMD只有最后一个会生效,不能追加。ENTRYPOINT可以追加

# 编写dockerfile文件
[root@localhost ~]# viM dockerfile_cmd
FROM centos
CMD ["ls","-a"]
# 构建镜像
[root@localhost ~]# docker build -f dockerfile_cmd -t centos_cmd .
Sending build context to Docker daemon  4.316MB
Step 1/2 : FROM centos
 ---> 5d0da3dc9764
Step 2/2 : CMD ["ls","-a"]
 ---> Running in bf2a6a015c98
Removing intermediate container bf2a6a015c98
 ---> b7dbd20733ee
Successfully built b7dbd20733ee
Successfully tagged ceshi2:latest
# run运行,发现我们的ls -a命令生效
[root@localhost ~]# docker run b7dbd20733ee
.
..
.dockerenv
bin
dev
etc
home
lib
lib64
lost+found
media
mnt
opt
proc
root
run
sbin
srv
sys
tmp
usr
var
# run的时候想追加一个命令-l(我们期望的实际执行是ls -al) 报错了!原因是cmd的情况下,-l替换了CMD ["ls","-a"]命令,而-l不是命令所以报错
[root@localhost ~]# docker run b7dbd20733ee -l
docker: Error response from daemon: failed to create shim task: OCI runtime create failed: runc create failed: unable to start container process: exec: "-l": executable file not found in $PATH: unknown.
# 只能重新写ls -al
[root@localhost ~]# docker run b7dbd20733ee ls -al
total 0
drwxr-xr-x.   1 root root   6 Oct 17 13:56 .
drwxr-xr-x.   1 root root   6 Oct 17 13:56 ..
-rwxr-xr-x.   1 root root   0 Oct 17 13:56 .dockerenv
lrwxrwxrwx.   1 root root   7 Nov  3  2020 bin -> usr/bin
drwxr-xr-x.   5 root root 340 Oct 17 13:56 dev
drwxr-xr-x.   1 root root  66 Oct 17 13:56 etc
drwxr-xr-x.   2 root root   6 Nov  3  2020 home
lrwxrwxrwx.   1 root root   7 Nov  3  2020 lib -> usr/lib
lrwxrwxrwx.   1 root root   9 Nov  3  2020 lib64 -> usr/lib64
drwx------.   2 root root   6 Sep 15  2021 lost+found
drwxr-xr-x.   2 root root   6 Nov  3  2020 media
drwxr-xr-x.   2 root root   6 Nov  3  2020 mnt
drwxr-xr-x.   2 root root   6 Nov  3  2020 opt
dr-xr-xr-x. 183 root root   0 Oct 17 13:56 proc
dr-xr-x---.   2 root root 162 Sep 15  2021 root
drwxr-xr-x.  11 root root 163 Sep 15  2021 run
lrwxrwxrwx.   1 root root   8 Nov  3  2020 sbin -> usr/sbin
drwxr-xr-x.   2 root root   6 Nov  3  2020 srv
dr-xr-xr-x.  13 root root   0 Oct 17 12:58 sys
drwxrwxrwt.   7 root root 171 Sep 15  2021 tmp
drwxr-xr-x.  12 root root 144 Sep 15  2021 usr
drwxr-xr-x.  20 root root 262 Sep 15  2021 var

# 如果是ENTRYPOINT就可以通过追加实现,docker run c3ffd3632fa0 -l
# 这里就不展示过程了,只需要把上面的dockerfile中的CMD改为ENTRYPOINT就行,如下
FROM centos
ENTRYPOINT ["ls","-a"]

打包示例

# 1.先运行python镜像来作为基础镜像
docker run -it python:3.8-bullseye

# 2.进入到jenkins拉取的代码目录
cd /mydata/jenkins_home/workspace

# 3.复制代码到docker容器中
docker cp jenkins_test 容器id:/usr/local/lib/python3.8/site-packages

# 4.同上,复制python的库site-packages到docker容器中

# 5.打包镜像
docker commit dbee5e9ce45f fanzheng/my_image:0.1


FROM python:3.8-bullseye

WORKDIR /mydata/jenkins_home/workspace

COPY ./fanzheng.txt /mydata/jenkins_home/workspace

CMD ['python','run.py']