在docker中创建的文件在主机上被写保护

时间:2016-07-06 05:58:35

标签: ember.js docker docker-compose

我正在使用docker容器进行rails和ember。我正在将源从本地安装到容器中。我在本地所做的所有更改都会反映在容器中。

现在我想使用generators来创建文件。文件已创建,但它们在我的机器上被写保护。

当我尝试docker-compose run frontend bash时,我会在容器内部获得root@061e4159d4ef:/frontend#超级用户提示访问权限。我在这种模式下可以创建文件。这些文件在我的主机中受到写保护。

我还尝试了docker-compose run --user "$(id -u):$(id -g)" frontend bash,我得到了I have no name!@31bea5ae977c:/frontend$,我无法在此模式下创建任何文件。以下是我收到的错误消息。

I have no name!@31bea5ae977c:/frontend$ ember g template about
/frontend/node_modules/ember-cli/node_modules/configstore/node_modules/mkdirp/index.js:90
                    throw err0;
                    ^

Error: EACCES: permission denied, mkdir '/.config'
    at Error (native)
    at Object.fs.mkdirSync (fs.js:916:18)
    at sync (/frontend/node_modules/ember-cli/node_modules/configstore/node_modules/mkdirp/index.js:71:13)
    at Function.sync (/frontend/node_modules/ember-cli/node_modules/configstore/node_modules/mkdirp/index.js:77:24)
    at Object.create.all.get (/frontend/node_modules/ember-cli/node_modules/configstore/index.js:39:13)
    at Object.Configstore (/frontend/node_modules/ember-cli/node_modules/configstore/index.js:28:44)
    at clientId (/frontend/node_modules/ember-cli/lib/cli/index.js:22:21)
    at module.exports (/frontend/node_modules/ember-cli/lib/cli/index.js:65:19)
    at /usr/local/lib/node_modules/ember-cli/bin/ember:26:3
    at /usr/local/lib/node_modules/ember-cli/node_modules/resolve/lib/async.js:44:21

这是我的Dockerfile

FROM node:6.2

ENV INSTALL_PATH /frontend
RUN mkdir -p $INSTALL_PATH

WORKDIR $INSTALL_PATH

# Copy package.json separately so it's recreated when package.json
# changes.
COPY package.json ./package.json
RUN npm install
COPY . $INSTALL_PATH
RUN npm  install -g phantomjs bower ember-cli ;\
    bower --allow-root install

EXPOSE 4200
EXPOSE 49152

CMD [ "ember", "server" ]

这是我的docker-compose.yml文件,请注意它不在当前目录中,而是在父目录中。

frontend:
   build: "frontend/"
   dockerfile: "Dockerfile"
   environment:
      - EMBER_ENV=development
   ports:
      - "4200:4200"
      - "49152:49152"
   volumes:
      - ./frontend:/frontend

我想知道,我怎样才能使用生成器?我是新学习码头工人。任何帮助表示赞赏。

1 个答案:

答案 0 :(得分:3)

你得到I have no name!因为:$(id -u):$(id -g) 主机中的用户ID和组未链接到容器中的任何用户。

解决方案:

如果容器已经在运行,请在容器内执行chown UID:GID -R /frontend ,并且由于某种原因无法阻止它。否则,您可以在主机中执行chown命令,然后再次运行容器。 UID和GID 必须的节点属于容器内的用户

示例:chown 101:101 -R /frontend,其中101是UID:www-data的GID。

如果您的容器中没有其他用户执行root,则必须创建一个新用户。为此,您必须创建一个Dockerfile并放置如下内容:

FROM your_image_name
RUN useradd -ms /bin/bash newuser

有关Dockerfiles的更多信息可以在here找到,或者只能通过googlin'找到。