杨梅冲
每天在想什么呢?

一、什么是dockerfile

Dockerfile是一个包含用于组合映像的命令的文本文档。可以使用在命令行中调用任何命令。 Docker通过读取Dockerfile中的指令自动生成映像。
docker build命令用于从Dockerfile构建映像。可以在docker build命令中使用-f标志指向文件系统中任何位置的Dockerfile。
# 例如:
docker build -f /path/to/a/Dockerfile

Dcokerfile的基本结构

Dockerfile 一般分为四部分:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行指令,'#' 为 Dockerfile 中的注释。

二、dockerfile文件说明

Docker以从上到下的顺序运行Dockerfile的指令。为了指定基本映像,第一条指令必须是FROM。一个声明以字符开头则被视为注释。可以在Docker文件中使用RUNCMDFROMEXPOSEENV等指令。

# 基础镜像:centos后可加版本:centos:7
FROM centos:7
#维护者信息注释(选写)
MAINTAINER xx xx@xx.com

# 安装基础软件:尽可能少RUN,可以使用&& 链接
RUN rpm -ivh https://mirrors.aliyun.com/epel/epel-release-latest-7.noarch.rpm && yum  install nginx -y

# add 将本地文件扔到容器里
ADD index1.html /usr/share/nginx/html/index.html

# 开放端口
EXPOSE 80
# ADD run.sh /run.sh
# RUN chmod 755 /run.sh
# 启动执行
CMD ["nginx"]
# 创建新镜像 : .为Dockerfile所在目录,在创建镜像的目录执行下面命令,ADD里的东西也放在同一个目录
docker build -t nginx:centos .

# 启动镜像,去访问index.html
docker run -d -P nginx:centos
[root@ ~]# docker images
REPOSITORY          TAG       IMAGE ID       CREATED         SIZE
nginx               centos    578353538643   5 minutes ago   420MB

# 登录
docker run -it -P  nginx:centos bash

[root@ ~]# docker ps
CONTAINER ID   IMAGE          COMMAND   CREATED          STATUS          PORTS                                                                                NAMES
8de513a57286   nginx:centos   "bash"    17 seconds ago   Up 16 seconds   0.0.0.0:49174->80/tcp, :::49174->80/tcp, 0.0.0.0:49173->443/tcp, :::49173->443/tcp   sharp_sammet

常用参数:FROM: 指定基础镜像,必须为第一个命令


MAINTAINER: 维护者信息

ADD
#构建镜像时执行的命令,将本地文件添加到容器中,tar类型文件会自动解压(网络压缩资源不会被解压),可以访问网络资源
格式:ADD <src>... <dest>

COPY:功能类似ADD,但是是不会自动解压文件,也不能访问网络资源,拷贝文件或目录至容器中,单纯复制文件推荐使用

EXPOSE 指定容器与宿主机交互端口

RUN
# 构建镜像时执行的命令,重复执行这个dockerfile时不会再执行
# linux
RUN shell命令
# windows
RUN ["executable", "param1", "param2"]
""" 注1:   RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定--no-cache参数,如:docker build --no-cache 注2:多行命令不要写多个RUN,原因是Dockerfile中每一个指令都会建立一层. 多少个RUN就构建了多少层镜像,会造成镜像的臃肿、多层,不仅仅增加了构件部署的时间,还容易出错。 """ CMD 构建容器后调用,也就是在容器启动时才进行调用 格式: CMD ["executable","param1","param2"] (执行可执行文件,优先) CMD ["param1","param2"] (设置了ENTRYPOINT,则直接调用ENTRYPOINT添加参数) CMD command param1 param2 (执行shell内部命令) 示例: CMD echo "This is a test." | wc - CMD ["/usr/bin/wc","--help"]
注:CMD不同于RUN,CMD用于指定在容器启动时所要执行的命令,而RUN用于指定镜像构建时所要执行的命令。 ENTRYPOINT:配置容器,使其可执行化。配合CMD可省去
"application",只使用参数。
ENTRYPOINT ["executable","param1","param2"]
示例:ENTRYPOINT ["/usr/local/nginx/sbin/nginx","-c","/usr/local/nginx/conf/nginx.conf"]
示例2:搭配CMD使用:一般变参才会使用CMD,这里的CMD等于在给ENTRYPOINT传参
    ENTRYPOINT ["nginx","-c"] #定参
    CMD ["/etc/nginx/nginx.conf"] #变参
不传参,容器内默认运行:nginx -c /etc/nginx/nginx.conf
传参,覆盖掉CMD里的指定文件: # docker run nginx:centos -c /etc/nginx/new.conf

ENV 设置环境变量,以便之后引用
# 语法有两种 1. ENV <key> <value> 2. ENV <key>=<value> ... # 两者的区别就是第一种是一次设置一个,第二种是一次设置多个
例如: ENV VERSION 6.6.6
    RUN curl -SLO "https://xxx/$VERSION/XX.tar.gz" VOLUME 可实现挂载功能,可以将本地文件夹或者其他容器中的文件夹挂在到这个容器种
用途:避免重要数据因容器重启而丢失,避免容器不断变大
# 语法为,可以时多个值: VOLUME ["/data"] VOLUME ["/var/log/"] VOLUME /var/log VOLUME /var/log /var/db# docker容器的数据管理
from centos
VOLUME ["/datavolume3","/datavolume6"]
CMD /bin/bash

# 构建命令
docker build -t="volume" .
# 启动容器后会发现2个目录
/datavolume3和/datavolume6


# docker的数据卷容器
数据卷容器:命名的容器挂载数据卷,其它容器通过挂载这个容器实现数据共享,挂载数据卷的容器就叫做数据卷容器
挂载方法:
docker run --volumes-from [container name]
示例:
(1) 创建第一个容器
    docker run --name data-volume -dit volume 在/datavolume3中创建一个文件xc.txt
(2)创建第二个容器
    docker run --name data-volume2 --volumes-from data-volume -itd centos /bin/bash
    登录到data-volume2中就会发现对应目录也有/datavolume3和/datavolume6,并且/datavolume3目录中有xc.txt文件

# docker数据卷的备份和还原,容器与容器之间的数据备份还原
数据备份方法:
docker run --volumes-from [container name] -v $(pwd):/backup centos tar czvf /backup/backup.tar [container data volume]

示例:将容器data-volume2中/datavolume卷进行备份到/root/backup/目录中
备份:docker run --volumes-from data-volume2 -v /root/backup:/backup --name datavolume-copy centos tar czvf /backup/datavolume.tar.gz /datavolume
还原:docker run --volumes-from data-volume2 -v /root/backup:/backup centos tar czvf /backup/datavolume.tar.gz -C /

USER 设置启动容器的用户和用户组
USER daemo
注意:如果设置了容器以daemon用户去运行,那么RUN, CMD 和 ENTRYPOINT 都会以这个用户去运行
格式:USER user:group WORKDIR
# 语法,类似cd功能: WORKDIR /path/to/workdir # 设置工作目录,对RUN,CMD,ENTRYPOINT,COPY,ADD生效。如果不存在则会创建,也可以设置多次。 ARG:用于指定传递给构建运行时的变量 格式: ARG <name>[=<default value>]

ONBUILD 用于延迟构建命令的执行,Dockerfile里使用ONBUILD指定的命令,在本次构建镜像过程中不执行,当有新的dockerfile使用了之前构建的镜像作为基础镜像,这是执行新镜像的dockerfile构建时候,会执行ONBUILD指定的命令
例如:自己制作了一个centos基础镜像,制作的时候有一条ONBUILD命令,当使用这个镜像作为nginx镜像时就会执行onbuild命令

LABLE 指令给镜像添加元数据

HEALTHCHECK 用于指定某个程序或指令来监控docker容器服务的运行状态
格式:HEALTHCHECK [选项] CMD <命令>:设置检查容器健康状况的命令
   HEALTHCHECK NONE:如果基础镜像有健康检查指令,使用这行可以屏蔽其监控检查指令

ARG 构建参数与ENV作用一致,但作用域不同,ARG设置的环境变量仅对dockerfile内有效,只在docker build过程中有效,构建好的镜像内不存在此环境变量
格式: ARG 参数名=默认值

 

# tomcat 安装
# cat tomcat.yaml
FROM centos:8
MAINTAINER xiong
RUN yum install wget
ADD jdk-8u281-linux-x64.rpm /usr/local/
ADD apache-tomcat-8.5.50.tar.gz /usr/local/
RUN cd /usr/local && rpm -ivh jdk-8u281-linux-x64.rpm
RUN mv /usr/local/apache-tomcat-8.5.50.tar.gz /usr/local/tomcat8
EXPOSE 8080
ENTRYPOINT /usr/local/tomcat8/bin/startup.sh && tail -F /usr/local/tomcat8/logs/catalina.out


#构建tomcat
docker build -t="tomcat8:v1" tomcat.yaml

 

posted on 2021-10-24 10:32  杨梅冲  阅读(2470)  评论(0编辑  收藏  举报