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

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

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

redis:
  image: redis
  ports:
    - "6379"

我已经在我的节点应用程序的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是容器的目标目录。


EDIT:
Previous documentation source now leads to version history, you'll have to select the version of compose you're using and look for the reference.

对于lazy - v3 / v2 / v1

旁注:在此编辑之前,语法对所有版本保持相同

其他回答

在docker-compose。Yml你可以使用这样的格式:

volumes:
    - host directory:container directory

根据他们的文件

有两件事:

我在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

有几个选择

短的语法

使用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类型(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之前,我们必须创建自己的与主机目录映射的docker卷。Yml作为外部

1.创建名为share的卷

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

2.在你的码头写作中使用它

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:
    - ./:/app

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


EDIT:
Previous documentation source now leads to version history, you'll have to select the version of compose you're using and look for the reference.

对于lazy - v3 / v2 / v1

旁注:在此编辑之前,语法对所有版本保持相同