亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Docker Volume 之權(quán)限管理

 更新時間:2018年10月24日 10:34:35   作者:jackluo  
這篇文章主要介紹了詳解Docker Volume 之權(quán)限管理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

Volume數(shù)據(jù)卷是Docker的一個重要概念。數(shù)據(jù)卷是可供一個或多個容器使用的特殊目錄,可以為容器應(yīng)用存儲提供有價值的特性:

  • 持久化數(shù)據(jù)與容器的生命周期解耦:在容器刪除之后數(shù)據(jù)卷中的內(nèi)容可以保持。Docker 1.9之后引進(jìn)的named volume(命名文件卷)可以更加方便地管理數(shù)據(jù)卷的生命周期;數(shù)據(jù)卷可以被獨立地創(chuàng)建和刪除。
  • 數(shù)據(jù)卷可以用于實現(xiàn)容器之間的數(shù)據(jù)共享
  • 可以支持不同類型的數(shù)據(jù)存儲實現(xiàn)

Docker缺省提供了對宿主機本地文件卷的支持,可以將宿主機的目錄掛載到容器之中。由于沒有容器分層文件系統(tǒng)帶來的性能損失,本地文件卷非常適合一些需要高性能數(shù)據(jù)訪問的場景,比如MySQL的數(shù)據(jù)庫文件的存儲。同時Docker支持通過volume plugin實現(xiàn)不同類型的數(shù)據(jù)卷,可以更加靈活解決不同應(yīng)用負(fù)載的存儲需求。比如在阿里云容器服務(wù)中可以為容器提供基于云盤的塊存儲、基于OSSFS和NAS/NFS的共享文件存儲。

然而Docker數(shù)據(jù)卷的權(quán)限管理經(jīng)常是非常令人困惑的。本文將結(jié)合實例給大家介紹Docker數(shù)據(jù)卷權(quán)限管理中的常見問題和解決方法。

從Jenkins掛載本地數(shù)據(jù)卷錯誤談起

最近的一個同事在利用容器運行Jenkins時遇到一個問題,其復(fù)現(xiàn)步驟如下:

注:如果是Windows/Mac需要登錄到Boot2docker虛擬機之上,而Linux無需如此。

docker-machine ssh default

啟動Jenkins官方鏡像,并檢查日志

docker run -d -p 8080:8080 -p 50000:50000 --name jenkins jenkins
docker logs jenkins

我們可以發(fā)現(xiàn)"jenkins"容器日志顯示結(jié)果一切正常

然而為了持久化Jenkins配置數(shù)據(jù),當(dāng)我們把宿主機當(dāng)前目錄下的data文件夾掛載到容器中的目錄"/var/jenkins_home"的時候,問題出現(xiàn)了:

docker rm -f jenkins
docker run -d -p 8080:8080 -p 50000:50000 -v $(pwd)/data:/var/jenkins_home --name jenkins jenkins
docker logs jenkins

錯誤日志如下

touch: cannot touch ‘/var/jenkins_home/copy_reference_file.log': Permission denied
Can not write to /var/jenkins_home/copy_reference_file.log. Wrong volume permissions?

這是神馬情況?

我們檢查一下之前啟動方式的"/var/jenkins_home"目錄權(quán)限,查看Jenkins容器的當(dāng)前用戶: 當(dāng)前用戶是"jenkins"而且"/var/jenkins_home"目錄是屬于jenkins用戶擁有的

docker@default:~$ docker run -ti --rm --entrypoint="/bin/bash" jenkins -c "whoami && id"
jenkins
uid=1000(jenkins) gid=1000(jenkins) groups=1000(jenkins)

docker@default:~$ docker run -ti --rm --entrypoint="/bin/bash" jenkins -c "ls -la /var/jenkins_home"
total 20
drwxr-xr-x 2 jenkins jenkins 4096 Jun 5 08:39 .
drwxr-xr-x 28 root  root  4096 May 24 16:43 ..
-rw-r--r-- 1 jenkins jenkins 220 Nov 12 2014 .bash_logout
-rw-r--r-- 1 jenkins jenkins 3515 Nov 12 2014 .bashrc
-rw-r--r-- 1 jenkins jenkins 675 Nov 12 2014 .profile

而當(dāng)映射本地數(shù)據(jù)卷時,/var/jenkins_home目錄的擁有者變成了root用戶

docker run -ti --rm -v $(pwd)/data:/var/jenkins_home --entrypoint="/bin/bash" jenkins -c "ls -la /var/jenkins_home"
total 4
drwxr-sr-x 2 root staff  40 Jun 5 08:32 .
drwxr-xr-x 28 root root 4096 May 24 16:43 ..

這就解釋了為什么當(dāng)"jenkins"用戶的進(jìn)程訪問"/var/jenkins_home"目錄時,會出現(xiàn) Permission denied 的問題

我們再檢查一下宿主機上的數(shù)據(jù)卷目錄,當(dāng)前路徑下"data"目錄的擁有者是"root",這是因為這個目錄是Docker進(jìn)程缺省創(chuàng)建出來的。

docker@default:~$ ls -la data
total 0
drwxr-sr-x  2 root   staff      40 Jun 5 08:32 ./
drwxr-sr-x  5 docker  staff     160 Jun 5 08:32 ../

發(fā)現(xiàn)問題之后,相應(yīng)的解決方法也很簡單:把當(dāng)前目錄的擁有者賦值給uid 1000,再啟動"jenkins"容器就一切正常了。

sudo chown -R 1000 data
docker start jenkins

這時利用瀏覽器訪問 "http://192.168.99.100:8080/" 就可以看到Jenkins的Web界面了。注:如無法訪問,可能需要通過docker-machine ip命令獲得當(dāng)前Docker宿主機的IP地址。

當(dāng)我們再進(jìn)入容器內(nèi)部查看"/var/jenkins_home"目錄的權(quán)限,其擁有者已經(jīng)變成 "jenkins"

docker@default:~$ docker exec jenkins ls -la /var/jenkins_home
total 24
drwxr-sr-x 11 jenkins staff 340 Jun 5 09:00 .
drwxr-xr-x 28 root  root 4096 May 24 16:43 ..
drwxr-sr-x 3 jenkins staff  60 Jun 5 08:59 .java
-rw-r--r-- 1 jenkins staff 289 Jun 5 08:59 copy_reference_file.log
...

而有趣的是在宿主機上我們看到的 "data"目錄的擁有者是"docker",這是因為"docker"用戶在"boot2docker"宿主機上的uid也是"1000"。

docker@default:~$ ls -la data
total 20
drwxr-sr-x  2 docker  staff      40 Jun 5 11:55 ./
drwxr-sr-x  6 docker  staff     180 Jun 5 11:55 ../
...

這時我們已經(jīng)可以知道:容器的本地數(shù)據(jù)卷中文件/目錄的權(quán)限是和宿主機上一致的,只是uid/gid在Docker容器和宿主機中可能映射為不同的用戶/組名稱。

在上文,我們使用了一個常見的技巧,即在宿主機上執(zhí)行chown命令時采用了uid而不是具體的用戶名,這樣就可以保證設(shè)置正確的擁有者。

問題雖然解決了,但思考并沒有結(jié)束。因為當(dāng)使用本地數(shù)據(jù)卷時,Jenkins容器會依賴宿主機目錄權(quán)限的正確性,這會給自動化部署帶來額外的工作。有沒有方法讓Jenkins容器為數(shù)據(jù)卷自動地設(shè)置正確的權(quán)限呢?這個問題對很多以non-root方式運行的應(yīng)用也都有借鑒意義。

為non-root應(yīng)用正確地掛載本地數(shù)據(jù)卷

我們可以從萬能的stackoverflow.com找到很多相關(guān)的討論,其中一個非常有借鑒意義問答如下

http://stackoverflow.com/questions/23544282/what-is-the-best-way-to-manage-permissions-for-docker-shared-volumes

其中的基本思路有兩個:

一個是利用Data Container的方法在容器間共享數(shù)據(jù)卷。這樣就規(guī)避了解決宿主機上數(shù)據(jù)卷的權(quán)限問題。由于在1.9版本之后,Docker提供了named volume來取代純數(shù)據(jù)容器,我們還需要真正地解決這個問題。

另外一個思路就是讓容器中以root用戶啟動,在容器啟動腳本中利用"chown"命令來修正數(shù)據(jù)卷文件權(quán)限,之后切換到non-root用戶來執(zhí)行程序

我們來參照第二個思路來解決這個問題

下面是一個基于Jenkins鏡像的Dockerfile:它會切換到"root"用戶并在鏡像中添加"gosu"命令,和新的入口點"/entrypoint.sh"

FROM jenkins:latest
USER root
RUN GOSU_SHA=5ec5d23079e94aea5f7ed92ee8a1a34bbf64c2d4053dadf383992908a2f9dc8a \
 && curl -sSL -o /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/1.9/gosu-$(dpkg --print-architecture)" \
 && chmod +x /usr/local/bin/gosu \
 && echo "$GOSU_SHA /usr/local/bin/gosu" | sha256sum -c - 
COPY entrypoint.sh /entrypoint.sh
ENTRYPOINT ["/entrypoint.sh"]

注釋:gosu 是經(jīng)常出現(xiàn)在官方Docker鏡像中的一個小工具。它是"su"和"sudo"命令的輕量級替代品,并解決了它們在tty和信號傳遞中的一些問題。

新入口點的"entrypoint.sh"的內(nèi)容如下:它會為"JENKINS_HOME"目錄設(shè)置"jenkins"的擁有權(quán)限,并且再利用"gosu"命令切換到"jenkins"用戶來執(zhí)行"jenkins"應(yīng)用。

#! /bin/bash
set -e
chown -R 1000 "$JENKINS_HOME"
exec gosu jenkins /bin/tini -- /usr/local/bin/jenkins.sh

您可以直接從 https://github.com/denverdino/docker-jenkins 獲得相關(guān)代碼,并構(gòu)建自己的Jenkins鏡像。執(zhí)行命令如下:

git clone https://github.com/AliyunContainerService/docker-jenkins
cd docker-jenkins/jenkins
docker build -t denverdino/jenkins .

然后基于新鏡像啟動Jenkins容器

docker rm -f jenkins
docker run -d -p 8080:8080 -p 50000:50000 -v $(pwd)/data:/var/jenkins_home --name jenkins denverdino/jenkins

總結(jié)

本文介紹了Docker數(shù)據(jù)卷的基本概念。針對non-root進(jìn)程訪問本地數(shù)據(jù)卷出現(xiàn)的權(quán)限問題,我們給出了一個解決方案。我們計劃在未來為大家繼續(xù)總結(jié)在Docker數(shù)據(jù)卷上遇到的一些其他問題,

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Docker的安裝方法及運行Docker Swarm模式的使用

    Docker的安裝方法及運行Docker Swarm模式的使用

    本文給大家簡單介紹docker的安裝以及1.12版本的swarm模式的使用,包括docker的安裝和配置,對docker swarm簡單使用感興趣的朋友一起看看吧
    2016-11-11
  • Dockerfile多鏡像構(gòu)建方式

    Dockerfile多鏡像構(gòu)建方式

    這篇文章主要介紹了Dockerfile多鏡像構(gòu)建方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Docker自動部署Apache Tomcat的方法

    Docker自動部署Apache Tomcat的方法

    這篇文章主要介紹了Docker自動部署Apache Tomcat的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • 解決docker容器啟動后馬上退出的問題

    解決docker容器啟動后馬上退出的問題

    這篇文章主要介紹了解決docker容器啟動后馬上退出的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Docker鏡像瘦身大小從1.43 GB減少到22.4MB

    Docker鏡像瘦身大小從1.43 GB減少到22.4MB

    本文主要介紹了 Docker鏡像瘦身大小從1.43 GB減少到22.4MB,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 解決Docker x509 insecure registry的問題

    解決Docker x509 insecure registry的問題

    這篇文章主要介紹了解決Docker x509 insecure registry的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Docker如何多步構(gòu)建生成dubbo-admin鏡像詳解

    Docker如何多步構(gòu)建生成dubbo-admin鏡像詳解

    dubbo-admin是dubbo框架的管理平臺,下面這篇文章主要給大家介紹了關(guān)于Docker如何多步構(gòu)建生成dubbo-admin鏡像的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2018-04-04
  • IDEA使用Docker插件遠(yuǎn)程部署項目到云服務(wù)器的方法步驟

    IDEA使用Docker插件遠(yuǎn)程部署項目到云服務(wù)器的方法步驟

    這篇文章主要介紹了IDEA使用Docker插件遠(yuǎn)程部署項目到云服務(wù)器的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Docker堆棧的管理操作詳解

    Docker堆棧的管理操作詳解

    這篇文章主要介紹了Docker堆棧的管理操作,結(jié)合實例形式分析了Docker堆棧管理相關(guān)的新服務(wù)添加、部署、數(shù)據(jù)持久化等操作技巧與注意事項,需要的朋友可以參考下
    2018-06-06
  • Docker Machine深入詳解

    Docker Machine深入詳解

    這篇文章主要介紹了Docker Machine深入詳解,文章總結(jié)的很詳細(xì),有感興趣的同學(xué)可以研究下
    2021-03-03

最新評論