昨天寫項(xiàng)目時(shí)需要用到Mysql的衍生版本percona, 就想用Doker來(lái)安裝.結(jié)果踩了一晚上坑, 今早終于解決. 現(xiàn)記錄在此.
這個(gè)坑原因是我對(duì)linux的目錄權(quán)限問題不敏感導(dǎo)致的. 我的系統(tǒng)是ubuntu16.04, 運(yùn)行 docker pull percona 拉取鏡像時(shí)一切正常.
![](/d/20211016/d29946d473fab2ccf283b761e070573b.gif)
拉取完后,輸入 docker images查看所有鏡像, 顯示正常:
![](/d/20211016/a49bf171fefe746fc5b40be4774608d0.gif)
然后我創(chuàng)建容器,命令為(執(zhí)行時(shí)不要有換行):
docker create --name percona -v /data/mysql-data:/var/lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root percona:lates
這個(gè)命令的意思是我創(chuàng)建一個(gè)名為percona的容器, 然后把我本地的/data/mysql-data目錄映射到docker容器中的/var/lib/mysql目錄 并指定3306端口,然后設(shè)數(shù)據(jù)庫(kù)root用戶密碼也為root,最后的percona:latest是指定我上面拉取的版本.
因?yàn)閐ocker容器中的數(shù)據(jù)庫(kù)只是一個(gè)鏡像,可以理解為并不是真實(shí)存在的,映射到我本地目錄的作用就是docker往/var/lib/mysql目錄存儲(chǔ)的數(shù)據(jù)都可以同步存儲(chǔ)到我的本地/data/mysql-data目錄. 這樣保證了數(shù)據(jù)不丟失,而且方便我本地操作.
命令的參數(shù)不了解的可以看下官方文檔或者隨便搜個(gè)docker視頻教程, 都有解釋. 然后我開啟此容器, docker start percona. 開啟完后查詢所有運(yùn)行中的容器docker ps, 這時(shí)候出問題了:
![](/d/20211016/684c0312141adb4eb743c17d10ab69c7.gif)
為空,即沒有查到運(yùn)行中的容器... 然后我查了下所有的容器,包括運(yùn)行的和沒運(yùn)行的的. docker ps -a, 顯示如下:
![](/d/20211016/595373a7c052a59bbb67d8a6303be3e1.gif)
原來(lái)是端口沒有綁定成功, 所以沒有運(yùn)行!, 每次運(yùn)行就自動(dòng)exited
這時(shí)我查看了一下docker日志, 輸入命令 docker logs 容器id, 顯示如下:
![](/d/20211016/c67aa61a6bccff4316ce40a73ac115ae.gif)
注: 這里的71是我此容器的container_id的開頭前兩個(gè)數(shù)字, docker支持這種簡(jiǎn)化寫法.
日志報(bào)錯(cuò)說我沒有對(duì)容器中/var/lib/mysql目錄下的創(chuàng)建和寫權(quán)限.
現(xiàn)在找到這個(gè)問題原因了, 可是搜了一晚上都沒有解決, 不得不說網(wǎng)上的一些不負(fù)責(zé)任的水貼是真的坑!
終于在早上找了解決辦法:
即檢查我本地目錄的所有者和docker容器中的/var/lib/mysql目錄的所有者是否為同一個(gè)用戶.
docker run -ti --rm --entrypoint="/bin/bash" percona -c "whoami && id"
此命令的作用是查看容器的所有者, 顯示為:
![](/d/20211016/81cace8091e70be2f20ecf9ff013e639.gif)
然后輸入(不能換行):
docker run -ti --rm -v /data/mysql-data:/var/lib/mysql --entrypoint="/bin/bash" percona -c "ls -la /var/lib/mysql"
此命令的作用是查看映射本地?cái)?shù)據(jù)卷時(shí), 此目錄的擁有者
![](/d/20211016/309d068ef88b1d3e9b1a7fbd5f617d30.gif)
原因就出在這里, 這就是為什么mysql用戶訪問docker中的目錄時(shí), 會(huì)報(bào)權(quán)限錯(cuò)誤! 因?yàn)?本地映射目錄的主人是root用戶, 而docker容器中/var/lib/mysql目錄的主人是mysql用戶,uid為999!
然后解決方法就是, 把當(dāng)前目錄的擁有者賦值給uid 999即mysql用戶, 再重新啟動(dòng)容器
![](/d/20211016/fc5d9086310309c12e3160c477d94a2a.gif)
問題解決了! 浪費(fèi)了一晚上時(shí)間, 不得不說, linux的權(quán)限控制知識(shí)還要加深!
到此這篇關(guān)于Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑的文章就介紹到這了,更多相關(guān)Docker創(chuàng)建容器目錄權(quán)限內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!