1.宿主机根目录下:
mkdir /mydocker 进入该目录
2.新建Dockerfile
vim Dockerfile
# volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,-------success1"
CMD /bin/bash
3.构建镜像
docker build -f /mydocker/Dockerfile -t shuidi/centos .
-f file的缩写 标记Dockerfile 在 /mydocker/Dockerfile 这个位置
4. 构建容器 docker run --name dc01 -it shuidi/centos
容器数据卷继承
docker run -it --name dc02 --volumes-from dc01 shuidi/centos
继承的容器与父容器的 容器卷 会相互共享传递
Dockerfile内容基础知识:
1.每条保留字指令都必须为大写字母且后面要跟随至少一个参数
2.指令按照从上到下,顺序执行
3.#表示注释
4.每条命令都会创建一个新的镜像层,并对镜像进行提交
Docker执行Dockerfile的大致流程
1.docker从基础镜像运行一个容器
2.执行一条指令并对容器作出修改
3.执行类似docker commit 的操作提交一个新的镜像层
4.docker再基础于刚提交的镜像运行一个新容器
5.执行dockerfile中的下一条指令直到所有指令都执行完成
保留字指令:
FROM | 基础镜像,当前新镜像是基于哪个镜像的 | |
MAINTAINER | 镜像维护者的姓名和邮箱地址 | |
RUN | 容器构建时需要运行的命令 | |
EXPOSE | 当前容器对外暴露的端口 | |
WORKDIR | 指定在创建容器后,终端默认登陆进来的工作目录,一个落脚点 | |
ENV | 用来在构建镜像过程中设置环境变量
ENV MY_PATH /usr/mytest 这个环境变量可以在后续的任何RUN指令中使用,这就如同在命令前面指定了环境变量前缀一样;也可以在其它指令中直接使用这些环境变量, 比如: WORKDIR $MY_PATH | |
ADD | 将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包 | |
COPY | 类似ADD,拷贝文件和目录到镜像中。 将从构建上下文目录中<原路径>的文件/目录复制到新一层的镜像内的<目标路径>位置 | COPY src dest COPY ["src","dest"] |
VOLUME | 容器数据卷,用于数据保存和持久化工作 | |
CMD | 指定一个容器启动时要运行的命令 Dockerfile中可以有多个CMD指令,但只有最后一个生效,CMD会被docker run之后的参数替换 | CMD 指令的格式和RUN相似,也是两种格式: shell 格式: CMD<命令> exec 格式:CMD ["可执行文件","参数1","参数2"] 参数列表格式: CMD["参数1","参数2"...] 在指定了 ENTRYPOINT指令后,用 CMD 指定具体的参数 |
ENTRYPOINT | 指定一个容器启动时要运行的命令 ENTRYPOINT的目的和CMD一样,都是在指定容器启动程序及参数 | |
ONBUILD | 当构建一个被继承的Dockerfile时运行命令,父镜像在被子继承后父镜像的onbuild被触发 |