網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
Docker實(shí)現(xiàn)掛載的方式
在介紹VOLUME指令之前,我們來(lái)看下如下場(chǎng)景需求:
1.容器是基于鏡像創(chuàng)建的,最后的容器文件系統(tǒng)包括鏡像的只讀層+可寫層,容器中的進(jìn)程操作的數(shù)據(jù)持久化都是保存在容器的可寫層上。一旦容器刪除后,這些數(shù)據(jù)就沒(méi)了,除非我們?nèi)斯浞菹聛?lái)(或者基于容器創(chuàng)建新的鏡像)。能否可以讓容器進(jìn)程持久化的數(shù)據(jù)保存在主機(jī)上呢?這樣即使容器刪除了,數(shù)據(jù)還在。
2. 當(dāng)我們?cè)陂_(kāi)發(fā)一個(gè)web應(yīng)用時(shí),開(kāi)發(fā)環(huán)境是在主機(jī)本地,但運(yùn)行測(cè)試環(huán)境是放在docker容器上。這樣的話,我在主機(jī)上修改文件(如html,js等)后,需要再同步到容器中。這顯然比較麻煩。
3. 多個(gè)容器運(yùn)行一組相關(guān)聯(lián)的服務(wù),如果他們要共享一些數(shù)據(jù)怎么辦?
對(duì)于這些問(wèn)題,我們當(dāng)然能想到各種解決方案。而docker本身提供了一種機(jī)制,可以將主機(jī)上的某個(gè)目錄與容器的某個(gè)目錄(稱為掛載點(diǎn)、或者叫卷)關(guān)聯(lián)起來(lái),容器上的掛載點(diǎn)下的內(nèi)容就是主機(jī)的這個(gè)目錄下的內(nèi)容,這類似linux系統(tǒng)下mount的機(jī)制。 這樣的話,我們修改主機(jī)上該目錄的內(nèi)容時(shí),不需要同步容器,對(duì)容器來(lái)說(shuō)是立即生效的。 掛載點(diǎn)可以讓多個(gè)容器共享。
下面我們來(lái)介紹具體的實(shí)現(xiàn)機(jī)制。
一、通過(guò)docker run命令
1.運(yùn)行命令:docker run --name test -it -v /home/xqh/myimage:/data ubuntu /bin/bash
其中的 -v 標(biāo)記 在容器中設(shè)置了一個(gè)掛載點(diǎn) /data(就是容器中的一個(gè)目錄),并將主機(jī)上的 /home/xqh/myimage 目錄中的內(nèi)容關(guān)聯(lián)到 /data下。
這樣在容器中對(duì)/data目錄下的操作,還是在主機(jī)上對(duì)/home/xqh/myimage的操作,都是完全實(shí)時(shí)同步的,因?yàn)檫@兩個(gè)目錄實(shí)際都是指向主機(jī)目錄。
2.運(yùn)行命令:docker run --name test1 -it -v /data ubuntu /bin/bash
上面-v的標(biāo)記只設(shè)置了容器的掛載點(diǎn),并沒(méi)有指定關(guān)聯(lián)的主機(jī)目錄。這時(shí)docker會(huì)自動(dòng)綁定主機(jī)上的一個(gè)目錄。通過(guò)docker inspect 命令可以查看到。
xqh@ubuntu:~/myimage$ docker inspect test1
[
{
? ? "Id": "1fd6c2c4bc545163d8c5c5b02d60052ea41900a781a82c20a8f02059cb82c30c",
.............................
? ? "Mounts": [
? ? ? ? {
? ? ? ? ? ? "Name": "0ab0aaf0d6ef391cb68b72bd8c43216a8f8ae9205f0ae941ef16ebe32dc9fc01",
? ? ? ? ? ? "Source": "/var/lib/docker/volumes/0ab0aaf0d6ef391cb68b72bd8c43216a8f8ae9205f0ae941ef16ebe32dc9fc01/_data",
? ? ? ? ? ? "Destination": "/data",
? ? ? ? ? ? "Driver": "local",
? ? ? ? ? ? "Mode": "",
? ? ? ? ? ? "RW": true
? ? ? ? }
? ? ],
上面 Mounts下的每條信息記錄了容器上一個(gè)掛載點(diǎn)的信息,“Destination” 值是容器的掛載點(diǎn),"Source"值是對(duì)應(yīng)的主機(jī)目錄。可以看出這種方式對(duì)應(yīng)的主機(jī)目錄是自動(dòng)創(chuàng)建的,其目的不是讓在主機(jī)上修改,而是讓多個(gè)容器共享。
二、通過(guò)dockerfile創(chuàng)建掛載點(diǎn)
上面介紹的通過(guò)docker run命令的-v標(biāo)識(shí)創(chuàng)建的掛載點(diǎn)只能對(duì)創(chuàng)建的容器有效。通過(guò)dockerfile的 VOLUME 指令可以在鏡像中創(chuàng)建掛載點(diǎn),這樣只要通過(guò)該鏡像創(chuàng)建的容器都有了掛載點(diǎn)。
還有一個(gè)區(qū)別是,通過(guò) VOLUME 指令創(chuàng)建的掛載點(diǎn),無(wú)法指定主機(jī)上對(duì)應(yīng)的目錄,是自動(dòng)生成的。
#test
FROM ubuntu
MAINTAINER hello1
VOLUME ["/data1","/data2"]
上面的dockfile文件通過(guò)VOLUME指令指定了兩個(gè)掛載點(diǎn) /data1 和 /data2.
我們通過(guò)docker inspect 查看通過(guò)該dockerfile創(chuàng)建的鏡像生成的容器,可以看到如下信息
"Mounts": [
? ? {
? ? ? ? "Name": "d411f6b8f17f4418629d4e5a1ab69679dee369b39e13bb68bed77aa4a0d12d21",
? ? ? ? "Source": "/var/lib/docker/volumes/d411f6b8f17f4418629d4e5a1ab69679dee369b39e13bb68bed77aa4a0d12d21/_data",
? ? ? ? "Destination": "/data1",
? ? ? ? "Driver": "local",
? ? ? ? "Mode": "",
? ? ? ? "RW": true
? ? },
? ? {
? ? ? ? "Name": "6d3badcf47c4ac5955deda6f6ae56f4aaf1037a871275f46220c14ebd762fc36",
? ? ? ? "Source": "/var/lib/docker/volumes/6d3badcf47c4ac5955deda6f6ae56f4aaf1037a871275f46220c14ebd762fc36/_data",
? ? ? ? "Destination": "/data2",
? ? ? ? "Driver": "local",
? ? ? ? "Mode": "",
? ? ? ? "RW": true
? ? }
],
可以看到兩個(gè)掛載點(diǎn)的信息。
三、容器共享卷(掛載點(diǎn))
下面我們創(chuàng)建另一個(gè)容器可以和test1(已經(jīng)創(chuàng)建好的容器)共享 /data1 和 /data2卷,這是在 docker run中使用 --volumes-from標(biāo)記,如:
可以是來(lái)源不同鏡像,如:
docker run --name test2 -it --volumes-from test1 ubuntu /bin/bash
也可以是同一鏡像,如:
docker run --name test3 -it --volumes-from test1 myimage /bin/bash
上面的三個(gè)容器 test1 , test2 , test3 均有 /data1 和 /data2 兩個(gè)目錄,且目錄中內(nèi)容是共享的,任何一個(gè)容器修改了內(nèi)容,別的容器都能獲取到。
四、最佳實(shí)踐:數(shù)據(jù)容器
如果多個(gè)容器需要共享數(shù)據(jù)(如持久化數(shù)據(jù)庫(kù)、配置文件或者數(shù)據(jù)文件等),可以考慮創(chuàng)建一個(gè)特定的數(shù)據(jù)容器,該容器有1個(gè)或多個(gè)卷。
其它容器通過(guò)–volumes-from 來(lái)共享這個(gè)數(shù)據(jù)容器的卷。
因?yàn)槿萜鞯木肀举|(zhì)上對(duì)應(yīng)主機(jī)上的目錄,所以這個(gè)數(shù)據(jù)容器也不需要啟動(dòng)。
如: docker run --name dbdata myimage echo “data container”
說(shuō)明:有個(gè)卷,容器之間的數(shù)據(jù)共享比較方便,但也有很多問(wèn)題需要解決,如權(quán)限控制、數(shù)據(jù)的備份、卷的刪除等。以后在介紹。
關(guān)于Docker中掛載的解釋
現(xiàn)在有這么一個(gè)命令:
docker run -p 33061:3306 --name mysql ?--restart=always -e MYSQL_ROOT_PASSWORD=pisen ?-v /etc/localtime:/etc/localtime:ro ?-v /etc/timezone:/etc/timezone:ro ?-d mysql:5.7
因?yàn)橹匾f(shuō)掛載的問(wèn)題,就單獨(dú)揪出來(lái)參數(shù)來(lái)說(shuō)
-v /etc/localtime:/etc/localtime:ro
就是將 ?宿主機(jī)的/etc/localtime文件掛載到容器的/etc/localtime 文件,并且容器內(nèi)的/etc/localtime文件設(shè)置為只讀(:ro)
實(shí)際的效果就是mysql容器啟動(dòng)后,時(shí)間時(shí)區(qū)的設(shè)置,使用的就是宿主機(jī)的 /etc/localtime 文件內(nèi)設(shè)置的內(nèi)容起作用。
如果沒(méi)有設(shè)置只讀的情況下,該掛載實(shí)現(xiàn)的效果是:
情況1:使用echo命令去修改
echo 'lq' > timezone
無(wú)論更改宿主機(jī)上的/etc/localtime文件內(nèi)容還是修改容器內(nèi)的/etc/localtime文件內(nèi)容,都會(huì)影響到對(duì)方。
情況2:使用vi命令去修改
vi timezone
則無(wú)論修改哪邊都不會(huì)影響到另外一方的文件內(nèi)容。
總結(jié)
原文鏈接:https://blog.csdn.net/qq_39007083/article/details/104569982
- 上一篇:沒(méi)有了
- 下一篇:沒(méi)有了
相關(guān)推薦
- 2023-01-13 分布式緩存Redis與Memcached的優(yōu)缺點(diǎn)區(qū)別比較_數(shù)據(jù)庫(kù)其它
- 2024-03-23 spring boot 使用AOP實(shí)現(xiàn)是否已登錄檢測(cè)
- 2022-08-27 asp.net中MVC的處理流程詳解_基礎(chǔ)應(yīng)用
- 2022-09-03 C#設(shè)計(jì)模式之建造者模式_C#教程
- 2022-09-02 Qt為exe添加ico圖片的簡(jiǎn)單實(shí)現(xiàn)步驟_C 語(yǔ)言
- 2022-03-05 Linux下Apache服務(wù)的部署和配置_Linux
- 2022-05-03 python讀寫xml文件實(shí)例詳解嘛_python
- 2021-12-02 Oracle數(shù)據(jù)庫(kù)產(chǎn)重啟服務(wù)和監(jiān)聽(tīng)程序命令介紹_oracle
- 欄目分類
-
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支