我的开发团队目前正在为我们正在开发的项目建立更新环境。我要直截了当。

在我们的DockerFile中,我们使用RUN npm install -g yarn安装yarn
但是,当执行一个清空缓存文件的.sh文件时,我们得到了错误:

yarn error “EACCESS: permission denied, scandir '/root/.config/yarn/link'”

我一直在寻找可能的修复程序,但我们仅找到一种解决方法,该方法是赋予该目录完全权限:
RUN chmode -R 777 '/root/

我们知道强烈不建议这样做。
有谁知道更好的答案?我已经看到了很多类似的问题,例如yarn和docker。

yarn 版本为1.9.4

编辑1:
问题在于,yarn与执行此操作的用户一起写入或读取这些文件,因此解决方案是向所有用户授予权限。也许以一种更具约束力的方式?

最佳答案

试试这个dockerfileUSER rootRUN npm install -g yarnUSER [user name]RUN chown -R [user name] ~/.config && chown -R [user name] ~/.cache
https://docs.npmjs.com/getting-started/fixing-npm-permissions

关于docker - 在docker镜像中安装yarn时出现权限问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51708552/

10-16 06:18