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

1.问题

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

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

而后一直报错:redis

Fatal error, can't open config file '/usr/redis/redis.conf'

2.排查过程

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

docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 -p 6378:6379 redis

而后进入容器centos

docker exec -it redis2 /bin/bash

而后进入挂载的文件夹下tomcat

cd /usr/local/etc/redis

发现报错:安全

cannot open directory '.': Permission denied

也就是没有权限bash

3.缘由以及解决方案

3.1 缘由

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

3.2解决方案

有三种方法解决:日志

  1. 在运行时加 --privileged=true
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而后再打开code

[root@localhost tomcat]# setenforce 0
[root@localhost tomcat]# setenforce 1

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

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

chcon [-R] [-t type] [-u user] [-r role] 文件或者目录

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

执行:

chcon -Rt svirt_sandbox_file_t /home/redis/redis.conf

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

4.1 容器目录不能够为相对路径

4.2 宿主机目录若是不存在,则会自动生成

4.3 宿主机的目录若是为相对路径呢

能够经过docker inspect命令,查看容器“Mounts”那一部分,咱们能够获得这个问题的答案。

相关文章
相关标签/搜索