gpt4 book ai didi

Docker EACCES 权限被拒绝 mkdir

转载 作者:行者123 更新时间:2023-12-02 18:18:43 31 4
gpt4 key购买 nike

我的 friend 给了我一个带有 dockerfile 的项目,这似乎对他来说工作得很好,但我得到了一个权限错误。

FROM node:alpine

RUN mkdir -p /usr/src/node-app && chown -R node:node /usr/src/node-app

WORKDIR /usr/src/node-app

COPY package.json yarn.lock ./
COPY ./api/package.json ./api/
COPY ./iso/package.json ./iso/

USER node
RUN yarn install --pure-lockfile

COPY --chown=node:node . .

EXPOSE 3000

error An unexpected error occurred: "EACCES: permission denied, mkdir '/usr/src/node-app/node_modules/<project_name>/api/node_modules'".

会不会是docker版本错误?

enter image description here

最佳答案

COPY 通常将内容复制到 root 拥有的镜像中,如果目录不存在,它将在镜像中创建目录。特别是,当您 COPY ./api/package.json ./api/ 时,它会创建 root 拥有的 api 子目录,当您稍后尝试运行 yarn install,它无法创建 node_modules 子目录,因为您已经切换了用户。

我建议将文件复制到容器中并以 root 身份运行构建过程。不要chown任何东西;将所有这些文件保留为 root 所有。仅在 Dockerfile 的末尾切换到备用 USER,您在其中声明 CMD。这意味着运行容器的非根用户将无法有意或无意地修改容器中的代码或库,这通常是一种良好的安全做法。

FROM node:alpine

# Don't RUN mkdir; WORKDIR creates the directory if it doesn't exist

WORKDIR /usr/src/node-app

# All of these files and directories are owned by root
COPY package.json yarn.lock ./
COPY ./api/package.json ./api/
COPY ./iso/package.json ./iso/
# Run this installation command still as root
RUN yarn install --pure-lockfile

# Copy in the rest of the application, still as root
COPY . .
# RUN yarn build

# Declare how to run the container -- _now_ switch to a non-root user
EXPOSE 3000
USER node
CMD yarn start

关于Docker EACCES 权限被拒绝 mkdir,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71163315/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com