前言
- 本篇来学习下Dockerfile中的VOLUME/EXPOSE指令
VOLUME
作用
- 创建一个匿名数据卷挂载点
说明
- 用 VOLUME 声明了卷,那么以后对于卷内容的修改会被丢弃,所以,一定要在 volume 声明之前修改内容
格式
# JSON数组 必须使用双引号,不能使用单引号 VOLUME ["/var/log/"] 或 # 直接写 VOLUME /var/log 或 # 空格分割 VOLUME /var/log /var/db
使用示例
- 新建dockerfile
FROM ubuntu # 挂载 容器指定的文件夹,如果不存在,会自动创建。 # 指定了 VOLUME 指令后,即使启动容器的时候没有指定 -v 参数,也会自动进行匿名卷挂载。 VOLUME [ "/demo","/app" ]
- 制作镜像并运行容器
# 制作镜像 docker build -t test --force-rm --no-cache . # 运行容器 docker run -it -d test
- 查看挂载卷
# 查看运行容器 docker ps # 查看容器信息 docker inspect 容器id
EXPOSE
作用
格式
EXPOSE <port> [<port>/<protocol>...]
说明:
- Docker 容器在运行的时候在指定的网络端口上进行侦听,可以指定端口是侦听 TCP 还是 UDP ,如果没有指定,默认就是 TCP
- 指令实际上不会发布端口,它充当了构建镜像人员和运行容器人员之间的一种文档,即打算发布那些端口的信息,要在运行容器时映射端口,需要使用 docker run -p xxx:xxx 或 docker run -P 的命令
- 如果 docker run,指定了 --net=host 宿主机网络模式,容器中 EXPOSE 指令暴露的端口会直接使用宿主机对应的端口,不存在映射关系
使用示例
- 新建dockerfile
FROM nginx EXPOSE 80
- 制作镜像并运行
docker build -t test --force-rm --no-cache . docker run -it -d -network=host test
- 查看容器信息
docker ps docker inspect 容器id
- 访问nginx
curl 127.0.0.1:80