我创建了一个 React 应用程序,并尝试在带有卷的 docker 容器上运行它(将容器内的内容与外部文件映射),之前一切都工作正常,但现在面临共享问题。 有人能帮我吗?这是一个权限问题,但不知道如何解决。 root 用户有权访问 node_modules 文件夹。如何授予节点用户访问权限?
我的 docker 文件
FROM node:alpine
USER node
WORKDIR '/home/node'
COPY package.json .
RUN npm install
COPY . .
CMD ["npm", "run", "start"]
使用的命令:
docker build -t frontend -f Dockerfile.dev .
docker run -p 3000:3000 -v /home/node/node_modules -v $(pwd):/home/node frontend:latest
容器内访问:
~ $ ls -l
total 1488
-rw-rw-r-- 1 node node 124 Jun 20 08:37 Dockerfile.dev
-rw-rw-r-- 1 node node 3369 Jun 17 18:25 README.md
drwxr-xr-x 3 node node 4096 Jun 17 18:45 build
-rw-rw-r-- 1 node node 230 Jun 20 06:56 docker-compose.yml
drwxrwxr-x 1041 root root 36864 Jun 20 19:15 node_modules
-rw-rw-r-- 1 node node 1457680 Jun 18 18:28 package-lock.json
-rw-rw-r-- 1 node node 811 Jun 17 18:26 package.json
drwxrwxr-x 2 node node 4096 Jun 17 18:25 public
drwxrwxr-x 2 node node 4096 Jun 17 18:25 src
很明显,容器中的node_modules文件夹是由root用户在npm install步骤中构建的,因此具有root用户。 这就是我们在设置节点用户时无法访问该文件夹的原因。 为了解决这个问题,我们首先需要使用root用户,在将文件从本地目录复制到图像时,我们必须向节点用户授予权限,然后将节点设置为用户,如下所示:
COPY --chown=node:node package.json .
RUN npm install
COPY --chown=node:node . .
USER node
此文件不是一个非常重要的文件,如果删除可能会导致重大应用程序故障。它只是一个由外部依赖项使用 eslinter 创建的缓存文件。您可以通过运行来安全删除
sudo rm /home/$USER/path-to-your-project/node_modules/.cache/.eslintcache
创建一个
.eslintignore
文件并将 *
放入其中。
如果你正在运行 docker-compose,经过大量调查后,在 npm 安装对我有用时更改 Dockerfile
RUN cd /usr/src/app && npm install
我有同样的问题,但这里提出的解决方案都不适合我,所以我搜索了“Linux 上的 Docker 卷权限被拒绝”,我发现了这篇文章:Docker 卷权限被拒绝,其中解释了您需要启用
permissive
SELinux 上的选项
只需在 Dockerfile 中插入以下行:
RUN chmod 777 /app/node_modules
行前:
CMD ["npm", "run", "start"]
重建它。不需要碰其他任何东西。
当我开发一个 React Web 应用程序时,这个错误一直困扰着我,所以这里
eslint
要求很少的权限,我无法找到需要什么样的权限,所以我决定授予所有可用的权限,并且为我工作。
sudo chmod -R 777 /yourProjectDirectoryName
这里的项目目录是你从home到当前文件夹的目录。
如果这不起作用,请尝试执行此操作,https://idqna.madreview.net/
我在命令中使用“sudo”轻松解决了这个问题:
sudo npm start