Docker之具名挂载和匿名挂载
具名挂载
# 具名挂载
[root@ecss6 /]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
2c9bcaaacf37c50d7bea189453e0105c86a2fa7bf85c390365fa11f319828b64
[root@ecss6 /]# docker volume ls
DRIVER VOLUME NAME
local bc4c7c9a4049dfdbf6105ff9a7bcb2a80d4dc51908b63f9f659780b606beb180
local juming-nginx
# 通过-v 卷名:容器内路径
# 查看一下这个卷
docker volume inspect juming-nginx
所有docker容器内的卷,没有指定目录的情况下默认在/var/lib/docker/volumes/xxx/_data
。
我们通过具名挂载可以方便地找到一个卷,大多数情况使用具名挂载。
匿名挂载
# 匿名挂载
-v 容器内路径
docker run -d -P --name nginx01 -v /etc/nginx nginx
查看所有volume的情况
[root@ecss6 /]# docker volume ls
DRIVER VOLUME NAME
local bc4c7c9a4049dfdbf6105ff9a7bcb2a80d4dc51908b63f9f659780b606beb180
# 这里就是你匿名挂载,我们在-v后纸屑了容器内的路径,没有写容器外的路径!
如何确定是具名还是匿名?
# 如何确定是具名还是匿名,或是指定路径挂载?
-v 容器内路径 # 匿名挂载
-v 卷名:容器内路径 # 具名挂载
-v /宿主机路径::容器内路径 # 指定路径挂载
拓展:
# 通过 -v 容器内路径:ro rw 改变读写权限
ro 只读
rw 可读可写
# 一旦设置了容器权限,容器对我们挂载的内容就有限定了。
初识Dockerfile
dockerfile就是用来构建docker镜像的构建文件!命令脚本!
# 创建一个dockerfile文件
# 文件内容 指令(大写) 参数
[root@ecss6 docker-test-volume]# cat dockerfile1
FROM centos
VOLUME ["vol01","vol02"]
CMD echo "success"
CMD /bin/bash
我们使用docker build命令构建自己的镜像
# docker build -f /home/docker-test-volume/dockerfile1 -t hong/centos:2.0 .
# 后面的.不要漏掉
启动容器
![](https://i-blog.csdnimg.cn/blog_migrate/6880f9a222814ed16dc893737bf2419b.jpeg)
这个卷外部有一个同步的目录。
VOLUME ["vol01","vol02"]
查看一下卷挂载的路径
测试是否可以同步
可以看到文件已经同步成功!
数据卷容器
结论:容器之间配置信息的传递,容器数据卷的生命周期一直持续到没有容器使用为止。
DockerFile
dockerfile是用来构建镜像的文件!
构建步骤
1、编写一个dockerfile文件;
2、docker build 构建一个镜像;
3、docker run 运行镜像;
4、docker push 发布镜像(DockerHub、阿里云镜像仓库)。
官方的文档:
![](https://i-blog.csdnimg.cn/blog_migrate/95dff88643bafa701f46d3bb62848c77.png)
很多官方镜像都是基础包,很多功能没有,我们通常会构建自己的镜像。
DockerFile构建过程
基础知识:
1、每个保留关键字(指令)都是大写字母;
2、执行自上而下顺序执行;
3、#表示注释;
4、每一个指令都会创建提交一个新的镜像层。
dockerfile是面向开发的,我们要发布项目,做镜像,就需要编写dockerfile文件。
DockerFile:构建文件,定义了一切的步骤和源代码;
Docker Images:通过DockerFile构建镜像,最终发布和运行的产品。
DockerFile指令
FROM # 基础镜像,一切从这里开始构建
MAINTAINER #镜像是谁写的,姓名+邮箱
RUN # 镜像构建的时候需要运行的命令
ADD #步骤:tomcat镜像,这个tomcat压缩包!添加内容
WORKDIR #镜像的工作目录
VOLUME #挂载的目录
EXPOSE #暴露端口配置
CMD #指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT #指定这个容器启动的时候要运行的命令,可以追加命令
ONBUILD #当构建一个被继承DockerFile,这个时候就会运行ONBUILD的指令。触发指令。
COPY #类似ADD,将文件拷贝到镜像中
ENV #构建的时候设置环境变量
实战测试
创建一个自己的centos
1、编写DockerFile的文件
[root@ecss6 dockerfile]# cat mydockerfile
FROM centos
MAINTAINER hong<18292442580@163.com>
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo "-----bulid success-----"
CMD /bin/bash
2、通过这个文件构建镜像
docker build -f mydockerfile -t mycentos:1.0 .
构建成功:
Successfully built 8da83edc6395
Successfully tagged mycentos:1.0
3、测试运行
![](https://i-blog.csdnimg.cn/blog_migrate/03628978eb4dfa75da714d20b8f70c86.png)
CMD和ENTRYPOINT区别
CMD #指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT #指定这个容器启动的时候要运行的命令,可以追加命令