我正在使用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
我想知道,我怎样才能使用生成器?我是新学习码头工人。任何帮助表示赞赏。
答案 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'找到。