您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Docker如何創建容器時設置目錄權限,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
昨天寫項目時需要用到Mysql的衍生版本percona, 就想用Doker來安裝.結果踩了一晚上坑, 今早終于解決. 現記錄在此.
這個坑原因是我對linux的目錄權限問題不敏感導致的. 我的系統是ubuntu16.04, 運行 docker pull percona 拉取鏡像時一切正常.
拉取完后,輸入 docker images查看所有鏡像, 顯示正常:
然后我創建容器,命令為(執行時不要有換行):
docker create --name percona -v /data/mysql-data:/var/lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root percona:lates
這個命令的意思是我創建一個名為percona的容器, 然后把我本地的/data/mysql-data目錄映射到docker容器中的/var/lib/mysql目錄 并指定3306端口,然后設數據庫root用戶密碼也為root,最后的percona:latest是指定我上面拉取的版本.
因為docker容器中的數據庫只是一個鏡像,可以理解為并不是真實存在的,映射到我本地目錄的作用就是docker往/var/lib/mysql目錄存儲的數據都可以同步存儲到我的本地/data/mysql-data目錄. 這樣保證了數據不丟失,而且方便我本地操作.
命令的參數不了解的可以看下官方文檔或者隨便搜個docker視頻教程, 都有解釋. 然后我開啟此容器, docker start percona. 開啟完后查詢所有運行中的容器docker ps, 這時候出問題了:
為空,即沒有查到運行中的容器... 然后我查了下所有的容器,包括運行的和沒運行的的. docker ps -a, 顯示如下:
原來是端口沒有綁定成功, 所以沒有運行!, 每次運行就自動exited
這時我查看了一下docker日志, 輸入命令 docker logs 容器id, 顯示如下:
注: 這里的71是我此容器的container_id的開頭前兩個數字, docker支持這種簡化寫法.
日志報錯說我沒有對容器中/var/lib/mysql目錄下的創建和寫權限.
現在找到這個問題原因了, 可是搜了一晚上都沒有解決, 不得不說網上的一些不負責任的水貼是真的坑!
終于在早上找了解決辦法:
即檢查我本地目錄的所有者和docker容器中的/var/lib/mysql目錄的所有者是否為同一個用戶.
docker run -ti --rm --entrypoint="/bin/bash" percona -c "whoami && id"
此命令的作用是查看容器的所有者, 顯示為:
然后輸入(不能換行):
docker run -ti --rm -v /data/mysql-data:/var/lib/mysql --entrypoint="/bin/bash" percona -c "ls -la /var/lib/mysql"
此命令的作用是查看映射本地數據卷時, 此目錄的擁有者
原因就出在這里, 這就是為什么mysql用戶訪問docker中的目錄時, 會報權限錯誤! 因為 本地映射目錄的主人是root用戶, 而docker容器中/var/lib/mysql目錄的主人是mysql用戶,uid為999!
然后解決方法就是, 把當前目錄的擁有者賦值給uid 999即mysql用戶, 再重新啟動容器
關于“Docker如何創建容器時設置目錄權限”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。