47-Dockerfile-VOLUME/EXPOSE指令

本文介绍了Dockerfile中VOLUME指令用于创建匿名数据卷挂载点,以及EXPOSE指令用于声明容器运行时监听的端口。VOLUME声明的卷内容修改会被丢弃,而EXPOSE不实际发布端口,但提供了容器打算发布的端口信息。示例中展示了如何在Dockerfile中使用这两个指令,以及如何通过docker命令运行容器并查看相关信息。


前言

  • 本篇来学习下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

在这里插入图片描述

version: "3.8" volumes: eft-q2x-mysql: driver: local driver_opts: type: none o: bind device: ${EFT_Q2X_VOLUME_MYSQL_DATA:-/mnt/data/EFT-Q2X/mysql} eft-q2x-storage: driver: local driver_opts: type: none o: bind device: ${EFT_Q2X_VOLUME_STORAGE:-/mnt/data/EFT-Q2X/storage} services: eft-q2x-mysql: container_name: eft-q2x-mysql build: context: ./docker-build/mysql dockerfile: docker-image-mysql5.7.v${EFT_IMAGE_MYSQL5_7_VERSION:-1.0.0}.dockerfile image: eft-image-mysql5:${EFT_IMAGE_MYSQL5_7_VERSION:-1.0.0} volumes: - eft-q2x-mysql:/var/lib/mysql - ./support/EFT-Q2X/mysql/init-scripts/:/docker-entrypoint-initdb.d - ./support/EFT-Q2X/mysql/conf/my.cnf:/etc/mysql/my.cnf - ./support/EFT-Q2X/mysql/log/:/var/log/mysql network_mode: host environment: MYSQL_ROOT_PASSWORD: ${EFT_Q2X_MYSQL_ROOT_PASSWORD:-hC123456} MYSQL_USER: ${EFT_Q2X_MYSQL_USER:-hcare} MYSQL_PASSWORD: ${EFT_Q2X_MYSQL_PASSWORD:-hC123456} healthcheck: test: [ "CMD", "mysqladmin", "ping", "-h", "localhost" ] interval: 10s timeout: 5s retries: 5 restart: unless-stopped eft-q2x-redis: container_name: eft-q2x-redis image: redis:${REDIS_VERSION:-7.4.2} volumes: - ./support/EFT-Q2X/redis/:/etc/redis/ network_mode: host restart: unless-stopped command: [ "redis-server", "/etc/redis/redis.cnf" ] healthcheck: test: [ "CMD", "redis-cli", "-a", "hC123456", "ping" ] interval: 10s timeout: 5s retries: 5 eft-q2x-auth: container_name: eft-q2x-auth build: context: ./application/EFT-Q2X/backend/auth/image-build dockerfile: docker-image-eft-q2x-auth.dockerfile args: EFT_IMAGE_JDK8_VERSION: ${EFT_IMAGE_JDK8_VERSION:-1.0.0} DEPLOY_JAR_NAME: ${EFT_Q2X_AUTH_JAR_NAME:-EFT-Q20-AUTHENTICATION-R-huancare-20250724-exec.jar} image: eft-image-q2x-auth:${EFT_Q2X_AUTH_IMAGE_VERSION:-1.0.0} volumes: - ./application/EFT-Q2X/backend/auth/logs:/app/logs # - ./application/EFT-Q2X/backend/auth/config:/app/config - eft-q2x-storage:/mnt/storage network_mode: host depends_on: eft-q2x-mysql: condition: service_healthy eft-q2x-redis: condition: service_healthy restart: unless-stopped eft-q2x-operator: container_name: eft-q2x-operator build: context: ./application/EFT-Q2X/backend/operator/image-build dockerfile: docker-image-eft-q2x-operator.dockerfile args: EFT_IMAGE_JDK8_VERSION: ${EFT_IMAGE_JDK8_VERSION:-1.0.0} DEPLOY_JAR_NAME: ${EFT_Q2X_OPERATOR_JAR_NAME:-EFT-Q20-OPERATOR-R-huancare-20250724-exec.jar} image: eft-image-q2x-operator:${EFT_Q2X_OPERATOR_IMAGE_VERSION:-1.0.0} volumes: - ./application/EFT-Q2X/backend/operator/logs:/app/logs # - ./application/EFT-Q2X/backend/operator/config:/app/config - eft-q2x-storage:/mnt/storage network_mode: host depends_on: eft-q2x-mysql: condition: service_healthy eft-q2x-redis: condition: service_healthy restart: unless-stopped eft-q2x-service: container_name: eft-q2x-service build: context: ./application/EFT-Q2X/backend/service/image-build dockerfile: docker-image-eft-q2x-service.dockerfile args: EFT_IMAGE_JDK8_VERSION: ${EFT_IMAGE_JDK8_VERSION:-1.0.0} DEPLOY_JAR_NAME: ${EFT_Q2X_SERVICE_JAR_NAME:-EFT-Q20-SERVICE-R-huancare-20250724-exec.jar} image: eft-image-q2x-service:${EFT_Q2X_SERVICE_IMAGE_VERSION:-1.0.0} volumes: - ./application/EFT-Q2X/backend/service/logs:/app/logs # - ./application/EFT-Q2X/backend/service/config:/app/config - eft-q2x-storage:/mnt/storage network_mode: host depends_on: eft-q2x-mysql: condition: service_healthy eft-q2x-redis: condition: service_healthy restart: unless-stopped eft-q2x-q6: container_name: eft-q2x-q6 build: context: ./application/EFT-Q2X/backend/q6/image-build dockerfile: docker-image-eft-q2x-q6.dockerfile args: EFT_IMAGE_JDK8_VERSION: ${EFT_IMAGE_JDK8_VERSION:-1.0.0} DEPLOY_JAR_NAME: ${EFT_Q2X_Q6_JAR_NAME:-EFT-Q20-SERVICE-R-huancare-20250724-exec.jar} image: eft-image-q2x-q6:${EFT_Q2X_Q6_IMAGE_VERSION:-1.0.0} volumes: - ./application/EFT-Q2X/backend/q6/logs:/app/logs # - ./application/EFT-Q2X/backend/q6/config:/app/config - eft-q2x-storage:/mnt/storage network_mode: host depends_on: eft-q2x-mysql: condition: service_healthy eft-q2x-redis: condition: service_healthy restart: unless-stopped 根据此内容给出在服务器上如何部署
最新发布
08-31
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱学习de测试小白

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值