docker run -v 用户目录的权限配置

本文介绍了在使用Docker运行容器时遇到的挂载目录权限问题,详细分析了如何解决因挂载目录权限不足导致容器无法正常运行的案例,如Jenkins和Verdaccio。解决方法包括检查并设置挂载目录的用户ID和权限,确保与容器内的用户匹配,从而保证容器能正确写入日志和数据。
摘要由CSDN通过智能技术生成

docker run -v 用户目录的权限

挂载目录的权限
docker run -v 或者 docker-compose -v 挂载目录的权限是跟挂在目录的权限相关的

概述

在挂在目录前发现容器可运行,挂在容器后容器却无法运行

jekins
直接启动镜像, 一切正常

docker run -d -p 8080:8080 -p 50000:50000 --name jenkins-base jenkins
docker logs jenkins

但直接将文件存储在容器中,不利于日志的持久化, 一旦容器坏掉无法访问时,则永久性丢失日志
为了持久化日志将 _/var/jenkins_home_挂在至主机目录/data/jenkins时,出现异常

# 挂载目录启动 jenkins; 发现容器没有运行起来
docker run -d -p 8080:8080 -p 50000:50000 -v /data/jenkins:/var/jenkins_home --name jenkins jenkins

查看日志

docker logs 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?

verdaccio
挂载目录 /verdaccio/storage 出现错误

-- warn Permission denied

解决方案

在docker run 或者 docker-compose up 之前先赋予挂在目录对应的权限, 然后在挂载目录

查看用户id

# 使用id命令查看jenkins的用户id
docker exec -it --user jenkins  jenkins-base bash
# 通过id命令获取用户id
id
uid=1000(root) gid=0(root) groups=0(root)

添加目录权限

chown 1000:1000 /data/jenkins -R

参考

Docker 容器权限管理
Docker Volume 之权限管理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值