docker 使用dockerfile
dockerfile可以理解成是docker镜像的描述文件,通过它可以定制镜像启动的各个过程。
dockerfile的格式
1. FROM
指定基于哪个基础镜像
格式:
FROM <image>
FROM <image>:<tag>
2. MAINTAINER
指定作者信息
格式:
MAINTAIN <name>
3. RUN
镜像操作指令
格式:
RUN <command>
RUN [“executable”, “param1”, “param2”]
4. CMD
RUN和CMD看起来挺像,但是CMD用来指定容器启动时用到的命令,只能有一条。
格式:
CMD ["executable", "param1", "param2"]
CMD command param1 param2
CMD ["param1", "param2"]
5. EXPOSE
这个用来指定要映射出去的端口,比如容器内部我们启动了sshd和nginx,所以我们需要把22和80端口暴漏出去。这个需要配合-P(大写)来工作,也就是说在启动容器时,需要加上-P,让它自动分配。如果想指定具体的端口,也可以使用-p(小写)来指定。
格式:
EXPOSE <port> [<port>...]
6. ENV
它主要是为后续的RUN指令提供一个环境变量,我们也可以定义一些自定义的变量 ENV MYSQL_version 5.6
格式:
ENV <key> <value>
7.ADD
将本地的一个文件或目录拷贝到容器的某个目录里。 其中src为Dockerfile所在目录的相对路径,它也可以是一个url。
格式:
add <src> <dest>
8. COPY
格式同ADD,使用方法和ADD一样,不同的是,它不支持url
9. ENTRYPOINT
容器启动时要执行的命令,它和CMD很像,也是只有一条生效,如果写多个只有最后一条有效。和CMD不同是: CMD 是可以被 docker run 指令覆盖的,而ENTRYPOINT不能覆盖。
比如,容器名字为test,我们在Dockerfile中指定如下
启动容器的命令是 docker run test
这样会输出 test
假如启动容器的命令是 docker run -it test /bin/bash
什么都不会输出
ENTRYPOINT不会被覆盖,而且会比CMD或者docker run指定的命令要靠前执行
10. VOLUME
创建一个可以从本地主机或其他容器挂载的挂载点
格式:
VOLUME ["/data"]
11. USER
指定运行容器的用户
格式:
USER daemon
12. WORKDIR
为后续的RUN、CMD或者ENTRYPOINT指定工作目录
格式:
WORKDIR /path/to/workdir
使用dockerfile制作nginx镜像
1.编写dockerfile
2.制作docker镜像
3.启动镜像
最后更新于
这有帮助吗?