Docker掛載主機目錄,訪問相應的文件出現Premission denied的權限訪問問題,
[root@localhost soft]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/centos 7.2.1511 686672a1d0cc 5 weeks ago
//將主機上的/soft目錄掛載到docker的/soft目錄,前面的是主機目錄,后面的是docker的目錄。
docker run -i -t -v /soft:/soft 686672a1d0cc /bin/bash
掛載后,查看相應的文件出現如下的提示:
[root@ba471da26d07 soft]# ls
ls: cannot access jdk-8u102-linux-x64.tar.gz: Permission denied
hadoop-2.7.2.tar.gz jdk-8u102-linux-x64.tar.gz
問題原因及解決辦法
原因是CentOS7中的安全模塊selinux把權限禁掉了,至少有以下三種方式解決掛載的目錄沒有權限的問題:
1.在運行容器的時候,給容器加特權,及加上 --privileged=true 參數:
docker run -i -t -v /soft:/soft --privileged=true 686672a1d0cc /bin/bash
2.臨時關閉selinux:
setenforce 0
3.添加selinux規則,改變要掛載的目錄的安全性文本
原文:https://blog.csdn.net/rznice/article/details/52170085