项目场景:
通过docker启动Jenkins容器
问题描述
Jenkins容器启动失败,通过sudo docker logs -f jenkins命令 查看日志如下:
touch: cannot touch ‘/var/jenkins_home/copy_reference_file.log’: Permission denied Can not write to /var/jenkins_home/copy_reference_file.log. Wrong volume permissions?
原因分析:
访问copy_reference_file.log文件没有权限。
由于启动用户,和docker容器内部的用不一致导致的。
因为当映射本地数据卷时,/opt/jenkins目录的拥有者为root用户,而容器中jenkins user的uid为1000
解决方案:
修改docker宿主机文件的权限。
我的目录映射关系为:
/opt/jenkins:/var/jenkins_home
所以我需要修改/opt/jenkins目录下的文件的所属用户及用户组。
chown -R 1000:1000 /opt/jenkins