国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

瀏覽:13日期:2024-11-21 18:19:42

昨天寫項(xiàng)目時(shí)需要用到Mysql的衍生版本percona, 就想用Doker來安裝.結(jié)果踩了一晚上坑, 今早終于解決. 現(xiàn)記錄在此.這個(gè)坑原因是我對(duì)linux的目錄權(quán)限問題不敏感導(dǎo)致的. 我的系統(tǒng)是ubuntu16.04, 運(yùn)行 docker pull percona 拉取鏡像時(shí)一切正常.

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

拉取完后,輸入 docker images查看所有鏡像, 顯示正常:

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

然后我創(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ù)庫root用戶密碼也為root,最后的percona:latest是指定我上面拉取的版本.

因?yàn)閐ocker容器中的數(shù)據(jù)庫只是一個(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í)候出問題了:

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

為空,即沒有查到運(yùn)行中的容器... 然后我查了下所有的容器,包括運(yùn)行的和沒運(yùn)行的的. docker ps -a, 顯示如下:

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

原來是端口沒有綁定成功, 所以沒有運(yùn)行!, 每次運(yùn)行就自動(dòng)exited

這時(shí)我查看了一下docker日志, 輸入命令 docker logs 容器id, 顯示如下:

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

注: 這里的71是我此容器的container_id的開頭前兩個(gè)數(shù)字, docker支持這種簡化寫法.

日志報(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'

此命令的作用是查看容器的所有者, 顯示為:

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

然后輸入(不能換行):

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í), 此目錄的擁有者

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

原因就出在這里, 這就是為什么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)容器

Docker創(chuàng)建容器時(shí)目錄權(quán)限踩坑

問題解決了! 浪費(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Docker
相關(guān)文章:
主站蜘蛛池模板: 安阳县| 百色市| 观塘区| 肃宁县| 鄯善县| 阿拉善右旗| 古丈县| 浮山县| 澄迈县| 临高县| 钟山县| 分宜县| 新营市| 桃园县| 阜新| 南昌市| 石棉县| 酒泉市| 高碑店市| 托里县| 三原县| 凌源市| 鄂温| 大同县| 福贡县| 三门县| 合作市| 南靖县| 马山县| 凭祥市| 开鲁县| 日喀则市| 麻城市| 滨海县| 桐庐县| 台中市| 五河县| 建宁县| 白玉县| 克山县| 施甸县|