Docker系列(四)Dockerfile
2015-10-22 10:46
561 查看
基本语法 使用 #来注释
FROM 指令告诉Docker使用哪个镜像作为基础
接着是维护者信息
RUN 开头的指令会在创建中运行,比如安装软件包
[b]FROM[/b] 格式: FROM<image>或FROM<image>:<tag>
说明:第一条指令必须为FROM指令,如果在同一个Dockerfile文件中创建多个镜像时,可以使用多个FROM指令(每个镜像一次).
[b]MAINTAINER[/b] 格式:
MAINTAINER <name> ##name为指定维护者信息
[b]RUN[/b] 格式:
RUN <command> 或 RUN [“executable”,”param1”,”param2”]
前者将在shell终端中运行命令,即 /binsh –c ;后者则使用exec执行,指定使用其它终端可以通过第二种方式实现.
RUN <cmd>被当作/bin/sh –c “cmd”运行
RUN [“executable”,”param1”,…]:Docker把它当作JSON的序列来解析,因此必须用双引号,而且executable需要完整的路径。
[b]CMD[/b] 功能:
执行Container时的默认行为,指定启动容器时执行的命令,每个Dockerfile只能有一条CMD命令,如果有多条,只有最后一天会被执行。
格式:
CMD [“executable”,”param1”,”param2”]
CMD command param1 param2 在/bin/sh中执行,提供给需要的支付运用.
CMD [“param1”,”param2”]提供给ENTRYPOINT的默认参数.
[b]EXPOSE[/b] 格式:EXPOSE <port> [<port> …]
功能:Docker服务器暴露的端口号,供互联系统使用,在启动容器时需要通过 –P,Docker主机会自动分配一个端口转发到指定的端口.
[b]ENV[/b] 格式:ENV <key><value> ##类型MAP
功能:指定一个环境变量,会被后续RUN指令使用,并在容器运行时保持.
[b]ADD[/b] 功能:
复制指定的 <src>到容器中的<dest>.其中<src>可以是Dockerfile所在的目录的一个相对路径,也可以是一个URL,还可以是一个tar文件(自动解压为目录).
格式:
ADD <src> <dest>
例子:ADD myApp /var/www
[b]COPY[/b] 格式: COPY <src> <dest>
复杂本地机器的<src>到容器中的<dest>,注:src为Dockerfile所在目录的相对路径.
[b]ENTRYPOINT[/b] 格式:
ENTRYPOINT [“executable”,”param1”,”param2”]
ENTRYPOINT command param1 param2 (默认的shell中执行)
功能:
1、 把整个Container变成一个可执行的文件。
2、 镜像的执行入口
3、 配置容器启动后执行的命令,并且不可以被docker run提供的参数覆盖.
4、 每个Dockerfile中只有一个ENTRYPOINT,当指定多个事,只有最后一个生效
5、 当定义了ENTRYPOINT以后,CMD只能够作为参数进行传递.
[b]VOLUME[/b] 格式:
VOLUME[“/data”]
功能:创建一个可以从本地主机或其它容器挂载的挂载点,一般用来存放数据库和需要保持的数据等.注意“/data”是指定的容器中目录
[b]USER[/b] 格式:
USER daemon
功能:
指定运行容器时的用户名或UID,后续的RUM也会使用指定用户.当服务不需要管理员权限时,可以通过该命令指定运行用户.
[b]WORKDIR[/b] 格式:
WORKDIR /path/to/workdir
功能:
为后续的RUN、CMD、ENTRYPOINT指令配置工作目录.可以使用多个WORKDIR指令,后续命令如果参数是相对路径,则会基于之前命令指定的路径.
[b]ONBUILD[/b] 格式:
ONBUILD [INSTRUCTION]
功能:
配置当所创建的镜像作为其它新创建镜像的基础镜像时,所执行的操作指令.
FROM 指令告诉Docker使用哪个镜像作为基础
接着是维护者信息
RUN 开头的指令会在创建中运行,比如安装软件包
[b]FROM[/b] 格式: FROM<image>或FROM<image>:<tag>
说明:第一条指令必须为FROM指令,如果在同一个Dockerfile文件中创建多个镜像时,可以使用多个FROM指令(每个镜像一次).
[b]MAINTAINER[/b] 格式:
MAINTAINER <name> ##name为指定维护者信息
[b]RUN[/b] 格式:
RUN <command> 或 RUN [“executable”,”param1”,”param2”]
前者将在shell终端中运行命令,即 /binsh –c ;后者则使用exec执行,指定使用其它终端可以通过第二种方式实现.
RUN <cmd>被当作/bin/sh –c “cmd”运行
RUN [“executable”,”param1”,…]:Docker把它当作JSON的序列来解析,因此必须用双引号,而且executable需要完整的路径。
[b]CMD[/b] 功能:
执行Container时的默认行为,指定启动容器时执行的命令,每个Dockerfile只能有一条CMD命令,如果有多条,只有最后一天会被执行。
格式:
CMD [“executable”,”param1”,”param2”]
CMD command param1 param2 在/bin/sh中执行,提供给需要的支付运用.
CMD [“param1”,”param2”]提供给ENTRYPOINT的默认参数.
[b]EXPOSE[/b] 格式:EXPOSE <port> [<port> …]
功能:Docker服务器暴露的端口号,供互联系统使用,在启动容器时需要通过 –P,Docker主机会自动分配一个端口转发到指定的端口.
[b]ENV[/b] 格式:ENV <key><value> ##类型MAP
功能:指定一个环境变量,会被后续RUN指令使用,并在容器运行时保持.
[b]ADD[/b] 功能:
复制指定的 <src>到容器中的<dest>.其中<src>可以是Dockerfile所在的目录的一个相对路径,也可以是一个URL,还可以是一个tar文件(自动解压为目录).
格式:
ADD <src> <dest>
例子:ADD myApp /var/www
[b]COPY[/b] 格式: COPY <src> <dest>
复杂本地机器的<src>到容器中的<dest>,注:src为Dockerfile所在目录的相对路径.
[b]ENTRYPOINT[/b] 格式:
ENTRYPOINT [“executable”,”param1”,”param2”]
ENTRYPOINT command param1 param2 (默认的shell中执行)
功能:
1、 把整个Container变成一个可执行的文件。
2、 镜像的执行入口
3、 配置容器启动后执行的命令,并且不可以被docker run提供的参数覆盖.
4、 每个Dockerfile中只有一个ENTRYPOINT,当指定多个事,只有最后一个生效
5、 当定义了ENTRYPOINT以后,CMD只能够作为参数进行传递.
[b]VOLUME[/b] 格式:
VOLUME[“/data”]
功能:创建一个可以从本地主机或其它容器挂载的挂载点,一般用来存放数据库和需要保持的数据等.注意“/data”是指定的容器中目录
[b]USER[/b] 格式:
USER daemon
功能:
指定运行容器时的用户名或UID,后续的RUM也会使用指定用户.当服务不需要管理员权限时,可以通过该命令指定运行用户.
[b]WORKDIR[/b] 格式:
WORKDIR /path/to/workdir
功能:
为后续的RUN、CMD、ENTRYPOINT指令配置工作目录.可以使用多个WORKDIR指令,后续命令如果参数是相对路径,则会基于之前命令指定的路径.
[b]ONBUILD[/b] 格式:
ONBUILD [INSTRUCTION]
功能:
配置当所创建的镜像作为其它新创建镜像的基础镜像时,所执行的操作指令.
相关文章推荐
- Docker系列(三)常用命令
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
- CentOS7 安装最新版的Docker
- windows7下从docker容器启动memcached服务的简单介绍
- Docker(2)-Linux启动过程
- 浅析Docker的网络模式
- Docker学习笔记 — etcd应用场景
- Docker系列(二)组件介绍
- docker安装gitlab
- docker1.9源码分析(五):server分配handler提供服务的流程
- docker1.9源码分析(三):daemon启动过程
- docker1.9源码分析(二):client流程之CmdPull命令
- ubuntu 安装docker + seagull实现图形化管理
- docker1.9目录结构及各目录实现的功能
- docker里下的centos是一个只读文件系统?我修改/etc/hosts都修改不了,怎么破
- docker1.9源码分析(一):执行主函数以及命令行解析
- Docker在windows下无法开启伪终端解决方法
- Docker学习笔记 — Coreos/Flannel