繁体   English   中英

如何在 docker compose 中将主机目录挂载为卷

[英]How do I mount a host directory as a volume in docker compose

我有一个正在 dockerizing 的开发环境,我希望能够 livereload 我的更改而不必重建 docker 图像。 我正在使用 docker compose 因为 redis 是我的应用程序的依赖项之一,我喜欢能够链接 redis 容器

我在docker-compose.yml中定义了两个容器:

node:
  build: ./node
  links:
    - redis
  ports:
    - "8080"
  env_file:
    - node-app.env

redis:
  image: redis
  ports:
    - "6379"

我已经在我的node应用程序的 dockerfile 中添加了一个卷,但是如何将主机的目录挂载到该卷中,以便我对代码的所有实时编辑都反映在容器中?

这是我当前的 Dockerfile:

# Set the base image to Ubuntu
FROM    node:boron

# File Author / Maintainer
MAINTAINER Amin Shah Gilani <amin@gilani.me>

# Install nodemon
RUN npm install -g nodemon

# Add a /app volume
VOLUME ["/app"]

# TODO: link the current . to /app

# Define working directory
WORKDIR /app

# Run npm install
RUN npm install

# Expose port
EXPOSE  8080

# Run app using nodemon
CMD ["nodemon", "/app/app.js"]

我的项目看起来像这样:

/
- docker-compose.yml
- node-app.env
- node/
  - app.js
  - Dockerfile.js

查看他们的文档

从它的外观来看,您可以在 docker-compose.yml 上执行以下操作

volumes:
    - ./:/app

其中./是主机目录, /app是容器的目标目录。


编辑:
以前的文档源现在会指向版本历史记录,您必须选择您正在使用的 compose 版本并查找参考。

对于懒人 – v3 / v2 / v1

旁注:截至本次编辑,所有版本的语法保持不变

有几个选项

简短的语法

使用host : guest格式,您可以执行以下任何操作:

volumes:
  # Just specify a path and let the Engine create a volume
  - /var/lib/mysql

  # Specify an absolute path mapping
  - /opt/data:/var/lib/mysql

  # Path on the host, relative to the Compose file
  - ./cache:/tmp/cache

  # User-relative path
  - ~/configs:/etc/configs/:ro

  # Named volume
  - datavolume:/var/lib/mysql

长句法

从 docker-compose v3.2 开始,您可以使用长语法来配置可以以简短形式表示的附加字段,例如mount type (volume、bind 或 tmpfs)和read_only

version: "3.2"
services:
  web:
    image: nginx:alpine
    ports:
      - "80:80"
    volumes:
      - type: volume
        source: mydata
        target: /data
        volume:
          nocopy: true
      - type: bind
        source: ./static
        target: /opt/app/static

networks:
  webnet:

volumes:
  mydata:

查看https://docs.docker.com/compose/compose-file/#long-syntax-3了解更多信息。

如果您想在 Docker Compose YAML 文件的volumes部分中将特定主机目录(以下示例中的/disk1/prometheus-data )挂载为volumes ,您可以按如下方式进行,例如:

version: '3'

services:
  prometheus:
    image: prom/prometheus
    volumes:
      - prometheus-data:/prometheus

volumes:
  prometheus-data:
    driver: local
    driver_opts:
      o: bind
      type: none
      device: /disk1/prometheus-data

顺便说一下,在 prometheus 的 Dockerfile 中,您可能会找到如下的VOLUME指令,这将其标记为从本机主机等外部安装的卷(但请注意:尽管将卷安装到容器中,该指令并不是必须的。 ):

文件

...
VOLUME ["/prometheus"]
...

参考:

这是两件事:

我在docker-compose.yml添加了音量:

node:
  volumes:
    - ./node:/app

我将npm install && nodemon app.js部分移到CMD因为RUN将内容添加到联合文件系统,并且我的卷不是 UFS 的一部分。

# Set the base image to Ubuntu
FROM    node:boron

# File Author / Maintainer
MAINTAINER Amin Shah Gilani <amin@gilani.me>

# Install nodemon
RUN npm install -g nodemon

# Add a /app volume
VOLUME ["/app"]

# Define working directory
WORKDIR /app

# Expose port
EXPOSE  8080

# Run npm install
CMD npm install && nodemon app.js

我们要创造主机目录映射自己的码头工人卷之前,我们在泊坞窗,compose.yml外部

1.创建名为share的

docker volume create --driver local \
--opt type=none \
--opt device=/home/mukundhan/share \
--opt o=bind share

2.在你的docker-compose中使用它

version: "3"

volumes:
  share:
    external: true

services:
  workstation:
    container_name: "workstation"
    image: "ubuntu"
    stdin_open: true
    tty: true
    volumes:
      - share:/share:consistent
      - ./source:/source:consistent
    working_dir: /source
    ipc: host
    privileged: true
    shm_size: '2gb'
  db:
    container_name: "db"
    image: "ubuntu"
    stdin_open: true
    tty: true
    volumes:
      - share:/share:consistent
    working_dir: /source
    ipc: host

这样我们就可以与运行在不同容器中的许多服务共享同一个目录

在 docker-compose.yml 中,您可以使用以下格式:

volumes:
    - host directory:container directory

根据他们的文件

分享 redis golang docker-compose.yaml 使用绑定安装我已经实现了。

version: '3.0'
services:
  redisdb:
    image: redis:6.0
    restart: always
    ports:
      - "6379:6379"
    container_name: redisdb-container
    command: ["redis-server", "--bind", "redisdb", "--port", "6379"]

  urlshortnerservice:
    depends_on:
      - redisdb
    ports:
      - "7777:7777"
    restart: always
    container_name: url-shortner-container
    image: url-shortner-service
    volumes:
      - ../pkg/repository/filestorage:/pkg/repository/filestorage #host directory:container directory

这是我的 Node.js 应用程序和 MongoDB 数据库的工作示例:

码头工人-compose.yml

version: '3'
services: 
    my-app:
        container_name: my-app-container
        restart: always
        build: .
        volumes:
            - './storage:/usr/src/app/storage'
        ports: 
            - "3000:3000"
        links:
            - my-app-db
    
    my-app-db:
        container_name: my-app-db-container
        image: mongo
        restart: always
        volumes:
            - './data:/data/db'          
        ports:
            - "27017:27017"

Dockerfile

FROM node:16.13.2
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app
COPY package.json ./
RUN npm install
COPY . /usr/src/app/
EXPOSE 3000
CMD [ "npm", "start"]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM