Docker不应将新文件写入原始目录

时间:2018-12-28 01:43:27

标签: linux bash docker docker-compose

我有一个目录结构如下的项目:

docker-compose.yml
project1/
--Dockerfile
--docker-compose-entry.sh
project2/
--Dockerfile
--docker-compose-entry.sh
project3/
--Dockerfile
--docker-compose-entry.sh

我的docker-compose-entry.sh文件在旋转时会在容器中创建和写入一些文件。但这又做了另一件事。当他们在自己的容器中写入文件时,他们还将文件写入我本地的原始目录。

我希望文件在启动时写入容器中,并留在容器中而不触及我的实际目录。容器销毁后,应销毁生成的文件。

有人建议如何做吗?任何想法都会受到高度赞赏。

更新,以下是注释中要求的文件内容:

# docker-compose.yml

version: '2'

services:
  project1:
    restart: always
    build: ./project1
    image: project1
    command: gunicorn project1.wsgi -b 0.0.0.0:8000
    volumes:
      - ./project1:/project1
      - ./common:/project1/common
    expose:
      - "8000"
    depends_on:
      - db
  project2:
    restart: always
    build: ./project2
    image: project2
    command: gunicorn project2.wsgi -b 0.0.0.0:8000
    volumes:
      - ./project2:/project2
      - ./common:/project2/common
    expose:
      - "8000"
    depends_on:
      - db
  project3:
    restart: always
    build: ./project3
    image: project3
    command: gunicorn project3.wsgi -b 0.0.0.0:8000
    volumes:
      - ./project3:/project3
      - ./common:/project3/common
    expose:
      - "8000"
    depends_on:
      - db
  db:
    image: postgres
    restart: always
    ports:
      - "5432:5432"
    volumes:
      - data:/var/lib/postgresql/data
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: postgres
      POSTGRES_DB: sacrina
volumes:
  data:

这是我来自project1的Dockerfile的示例。

#Dockerfile

FROM wildfish/django:node-latest

RUN mkdir /project1
WORKDIR /project1
ADD . /project1

ADD requirements.txt /project1/
ADD ./common/.bowerrc /project1/
ADD ./common/bower.json /project1/
ADD ./common/package.json /project1/
ADD ./common/gulpfile.js /project1/
ADD ./config/ /project1/

RUN pip install -r /project1/requirements.txt
RUN npm install --global bower gulp-cli

COPY ./docker-entrypoint.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/docker-entry-point.sh

ENTRYPOINT ["docker-entry-point.sh"]

这是我的docker-entry-point.sh的示例

# docker-entry-point.sh

#!/bin/sh

npm install
bower install
gulp

python manage.py collectstatic --no-input
gunicorn project1.wsgi -b 0.0.0.0:8000

1 个答案:

答案 0 :(得分:1)

您滥用volumes

首先,您在DockerfileADD . /project1的构建阶段将子文件夹中的所有内容复制到容器中。 完成此操作后,您已经拥有/project1容器中的所有内容,并且可以使用它。

但是,当您使用docker-compose启动容器时,会使用

创建其他binding
volumes:
  - ./project2:/project2

还有你

1)用主机的文件夹覆盖容器中的内容

2)使容器能够修改主机的文件夹,因为绑定是可写的(要创建只读,请指定- ./project2:/project2:ro

您要做的就是简单地从docker-compose中删除此卷声明并享受。

顺便说一句,如果所有通信都在一个docker-compose中的容器之间运行,并且您未指定network模式(默认为bridge),则无需显式公开端口,例如你在

expose:
  - "8000"