我的开发团队目前正在为我们正在开发的项目建立更新环境。我要直截了当。
在我们的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与执行此操作的用户一起写入或读取这些文件,因此解决方案是向所有用户授予权限。也许以一种更具约束力的方式?
最佳答案
试试这个dockerfile
USER root
RUN npm install -g yarn
USER [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/