解決docker掛載的目錄無法讀寫問題
使用下面的命令可以創建一個容器並且把本地的/home/dock/Downloads目錄掛載到容器中的/usr/Downloads中
[root@docker ~]# docker run -it -v /home/dock/Downloads:/usr/Downloads ubuntu /bin/bash
在Centos上創建完後,會出現如下問題
root@637fe9ea94f0:/usr/Downloads# ls ls: cannot open directory '.': Permission denied
解決辦法:
原因是CentOS7中的安全模塊selinux把權限禁掉瞭,
有以下幾種方式解決掛載的目錄沒有權限的問題:
1.在運行容器的時候,給容器加特權,及加上 –privileged=true 參數:
docker run -i -t -v /soft:/soft --privileged=true 637fe9ea94f0 /bin/bash
2.臨時關閉selinux:
setenforce 0
3.添加selinux規則,改變要掛載的目錄的安全性文本
補充:docker掛載文件夾後不能訪問,沒有權限
輸入docker run 後掛載的文件夾不能訪問,沒有權限
例如:
sudo nvidia-docker run -p 8090:8888 -p 8091:80 -p 8092:6666 --name=pytorch0.4 -v ~/workspace:/root/workspace -i --shm-size 31G -t dsksd/pytorch:0.4.1 /bin/bash
將主機的workspace文件夾與容器的/root/workspace文件夾相掛載,但是在主機上不能向workspace文件夾中寫入數據。因為此時文件夾的擁有者為root。
可以執行命令:
sudo chown -R $USER 文件夾位置(/workspace)
文件夾就可以進行讀寫瞭。但是重啟後需要重新執行上述命令。
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- docker 命令報異常permission denied的解決方案
- docker<容器數據卷-v>對容器內數據持久化詳解(備份)
- docker 環境搭建、docker 與容器常用指令大全(推薦)
- docker部署蝸牛影院系統詳細流程分析
- docker+gitlab+jenkins從零搭建自動化部署