前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker -v 对挂载的目录没有权限 Permission denied

Docker -v 对挂载的目录没有权限 Permission denied

作者头像
hbbliyong
发布2019-05-25 18:47:08
14.5K0
发布2019-05-25 18:47:08
举报
文章被收录于专栏:hbbliyonghbbliyong

1.问题

今天在使用docker挂载redis的时候老是报错

代码语言:javascript
复制
docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 -p 6378:6379 redis redis-server /usr/local/etc/redis/redis.conf

然后一直报错:

代码语言:javascript
复制
Fatal error, can't open config file '/usr/redis/redis.conf'

2.排查过程

查看日志也是这样 然后我把使用配置文件的地方去掉

代码语言:javascript
复制
docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 -p 6378:6379 redis

然后进入容器

代码语言:javascript
复制
docker exec -it redis2 /bin/bash

然后进入挂载的文件夹下

代码语言:javascript
复制
cd /usr/local/etc/redis

发现报错:

代码语言:javascript
复制
cannot open directory '.': Permission denied

也就是没有权限

3.原因以及解决方案

3.1 原因

centos7中安全模块selinux把权限禁掉了

3.2解决方案

有三种方法解决:

  1. 在运行时加 --privileged=true
代码语言:javascript
复制
docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 --privileged=true redis  redis-server /usr/local/etc/redis/redis.conf

2.临时关闭selinux然后再打开

代码语言:javascript
复制
[root@localhost tomcat]# setenforce 0
[root@localhost tomcat]# setenforce 1

3.添加linux规则,把要挂载的目录添加到selinux白名单

更改安全性文本的格式如下

代码语言:javascript
复制
chcon [-R] [-t type] [-u user] [-r role] 文件或者目录

选顷不参数: 
-R  :该目录下的所有目录也同时修改; 
-t  :后面接安全性本文的类型字段,例如 httpd_sys_content_t ; 
-u  :后面接身份识别,例如 system_u; 
-r  :后面街觇色,例如 system_r

执行:

代码语言:javascript
复制
chcon -Rt svirt_sandbox_file_t /home/redis/redis.conf

4.关于docker挂载的一些经验

4.1 容器目录不可以为相对路径
4.2 宿主机目录如果不存在,则会自动生成
4.3 宿主机的目录如果为相对路径呢

可以通过docker inspect命令,查看容器“Mounts”那一部分,我们可以得到这个问题的答案。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-01-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.问题
  • 2.排查过程
  • 3.原因以及解决方案
  • 更改安全性文本的格式如下
    • 4.关于docker挂载的一些经验
    相关产品与服务
    容器镜像服务
    容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档