欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Docker 數(shù)據(jù)卷管理

 更新時(shí)間:2017年07月06日 11:17:22   作者:東邪西毒  
本篇文章主要介紹了Docker 數(shù)據(jù)卷管理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

Docker中的數(shù)據(jù)可以存儲(chǔ)在類似于虛擬機(jī)磁盤的介質(zhì)中,在Docker中稱為數(shù)據(jù)卷(Data Volume)。數(shù)據(jù)卷可以用來(lái)存儲(chǔ)Docker應(yīng)用的數(shù)據(jù),也可以用來(lái)在Docker容器間進(jìn)行數(shù)據(jù)共享。

數(shù)據(jù)卷呈現(xiàn)給Docker容器的形式就是一個(gè)目錄,支持多個(gè)容器間共享,修改也不會(huì)影響鏡像。使用Docker的數(shù)據(jù)卷,類似在系統(tǒng)中使用 mount 掛載一個(gè)文件系統(tǒng)。

本節(jié)中,我們需要依次完成下面幾項(xiàng)任務(wù):

1.創(chuàng)建數(shù)據(jù)卷
2.管理數(shù)據(jù)卷權(quán)限
3.掛載宿主機(jī)文件
4.使用數(shù)據(jù)卷容器共享數(shù)據(jù)
5.數(shù)據(jù)卷備份

一、創(chuàng)建數(shù)據(jù)卷

容器管理實(shí)驗(yàn)中我們學(xué)習(xí)的命令docker run用來(lái)創(chuàng)建容器,可以在使用改命令時(shí)添加-v參數(shù),就可以創(chuàng)建并掛載一個(gè)到多個(gè)數(shù)據(jù)卷到當(dāng)前運(yùn)行的容器中,-v的作用是將宿主機(jī)的一個(gè)目錄作為容器的數(shù)據(jù)卷掛載到容器中,使宿主機(jī)和容器之間可以共享一個(gè)目錄,如果本地路徑不存在,Docker也會(huì)自動(dòng)創(chuàng)建。

本節(jié)實(shí)驗(yàn)中,我們掛載2個(gè)數(shù)據(jù)卷到新創(chuàng)建的容器上:

 # 創(chuàng)建兩個(gè)目錄

  mkdir /tmp/data1 /tmp/data2

  # 分別將兩個(gè)目錄掛載到新創(chuàng)建的容器上

  docker run -t -i --name shiyanlou -v /tmp/data1:/data1 -v /tmp/data2:/data2 ubuntu /bin/bash

上述命令中-v參數(shù)可以使用多次,并掛在多個(gè)數(shù)據(jù)卷到容器中。后面的參數(shù)信息中冒號(hào)前面是宿主機(jī)的本地目錄,冒號(hào)后面是容器中的掛載目錄。

使用docker inspect shiyanlou查看shiyanlou容器中的數(shù)據(jù)卷信息:

#docker inspect shiyanlou

進(jìn)入容器后我們可以查看和使用容器卷,嘗試向這個(gè)容器卷中寫入數(shù)據(jù),然后在宿主機(jī)中查看是否存在:

可以看到容器中掛載的數(shù)據(jù)卷具備可寫權(quán)限,那么如何對(duì)數(shù)據(jù)卷的權(quán)限進(jìn)行管理呢?比如如何創(chuàng)建一個(gè)只讀的數(shù)據(jù)卷呢?

二、數(shù)據(jù)卷權(quán)限

掛載的數(shù)據(jù)卷默認(rèn)為可讀寫權(quán)限,除非外部文件系統(tǒng)做了特殊限制,在docker run的時(shí)候也可以執(zhí)行為只讀權(quán)限:

# 創(chuàng)建一個(gè)數(shù)據(jù)卷目錄
mkdir /tmp/readonlydata

# 以只讀的方式掛載到shiyanlouro容器上
docker run -t -i --name shiyanlouro -v /tmp/readonlydata:/rodata:ro ubuntu /bin/bash

上面的命令中參數(shù)很簡(jiǎn)單,ro表示readonly,掛載后的數(shù)據(jù)卷就是只讀權(quán)限了,這時(shí)候我們?cè)俅螄L試向數(shù)據(jù)卷中寫入:

除了可以掛載目錄之外,文件也可以作為數(shù)據(jù)卷掛載到容器中。

三、掛載宿主機(jī)上的文件

在本實(shí)驗(yàn)中,我們想讓所有的容器都可以共享宿主機(jī)的/etc/apt/sources.list,從而只需要改變宿主機(jī)的apt源就能夠影響到所有的容器。

復(fù)制代碼 代碼如下:
docker run -t -i --name shiyanloufile -v /etc/apt/sources.list:/etc/apt/sources.list:ro ubuntu /bin/bash

如果我們想共享一個(gè)數(shù)據(jù)卷給多個(gè)容器怎么辦,比如設(shè)想一個(gè)場(chǎng)景,我們有兩個(gè)處理上傳數(shù)據(jù)的應(yīng)用運(yùn)行在不同的容器中,但需要同時(shí)讀取同一個(gè)文件夾下的文件,此時(shí),最好的方式是使用數(shù)據(jù)卷容器。

四、數(shù)據(jù)卷容器

如果需要在多個(gè)容器間共享數(shù)據(jù),并希望永久保存這些數(shù)據(jù),最好的方式是使用數(shù)據(jù)卷容器,類似于一個(gè)提供網(wǎng)絡(luò)文件共享服務(wù)的NFS服務(wù)器。

數(shù)據(jù)卷容器創(chuàng)建方法跟普通容器一樣,只需要指定宿主機(jī)的一個(gè)文件夾作為數(shù)據(jù)卷即可,使用docker create命令創(chuàng)建但不啟動(dòng)數(shù)據(jù)卷容器:

docker create -v /shiyanloudata --name shiyanloudb ubuntu /bin/true

其他使用該數(shù)據(jù)卷容器的容器創(chuàng)建時(shí)候需要使用--volumes-from參數(shù),指定該容器名稱或ID:

docker run --volumes-from shiyanloudb ...

創(chuàng)建site1和site2兩個(gè)容器掛載數(shù)據(jù)卷容器shiyanloudb:

可以連接到這兩個(gè)容器中對(duì)數(shù)據(jù)卷進(jìn)行操作,并查看彼此之間是否已經(jīng)有了共享文件:

五、備份數(shù)據(jù)卷

繼續(xù)使用實(shí)驗(yàn)四的環(huán)境,我們對(duì)數(shù)據(jù)卷容器中的數(shù)據(jù)進(jìn)行備份,備份方法:

1.創(chuàng)建一個(gè)新的容器
2.掛載數(shù)據(jù)卷容器
3.掛載宿主機(jī)本地目錄作為數(shù)據(jù)卷
4.將數(shù)據(jù)卷容器的內(nèi)容備份到宿主機(jī)本地目錄掛載的數(shù)據(jù)卷中
5.完成備份操作后容器銷毀

請(qǐng)按照上述步驟對(duì)數(shù)據(jù)卷容器shiyanloudb中的數(shù)據(jù)進(jìn)行備份:

# 創(chuàng)建備份目錄
mkdir /tmp/backup

# 創(chuàng)建備份容器
docker run --rm --volumes-from shiyanloudb -v /tmp/backup:/backup ubuntu tar cvf /backup/shiyanloudb.tar /shiyanloudata

總結(jié)

1.創(chuàng)建數(shù)據(jù)卷
2.管理數(shù)據(jù)卷權(quán)限
3.掛載宿主機(jī)文件
4.使用數(shù)據(jù)卷容器共享數(shù)據(jù)
5.數(shù)據(jù)卷備份

請(qǐng)務(wù)必保證自己能夠動(dòng)手完成整個(gè)實(shí)驗(yàn),只看文字很簡(jiǎn)單,真正操作的時(shí)候會(huì)遇到各種各樣的問題,解決問題的過(guò)程才是收獲的過(guò)程。

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

相關(guān)文章

  • 利用 Docker 構(gòu)建簡(jiǎn)單的 java 開發(fā)編譯環(huán)境的方法詳解

    利用 Docker 構(gòu)建簡(jiǎn)單的 java 開發(fā)編譯環(huán)境的方法詳解

    這篇文章主要介紹了利用 Docker 構(gòu)建簡(jiǎn)單的 java 開發(fā)編譯環(huán)境的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • docker?images的常用方式

    docker?images的常用方式

    這篇文章主要介紹了docker?images的常用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • docker容器動(dòng)態(tài)添加端口號(hào)的方法

    docker容器動(dòng)態(tài)添加端口號(hào)的方法

    這篇文章主要介紹了docker容器動(dòng)態(tài)添加端口號(hào)的方法,本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • Linux安裝Docker詳細(xì)教程

    Linux安裝Docker詳細(xì)教程

    這篇文章介紹了Linux安裝Docker的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • Docker執(zhí)行DockerFile構(gòu)建過(guò)程指令解析

    Docker執(zhí)行DockerFile構(gòu)建過(guò)程指令解析

    這篇文章主要為大家介紹了Docker執(zhí)行DockerFile構(gòu)建過(guò)程及DockerFile的指令解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪<BR>
    2022-04-04
  • .NETCore Docker實(shí)現(xiàn)容器化與私有鏡像倉(cāng)庫(kù)管理

    .NETCore Docker實(shí)現(xiàn)容器化與私有鏡像倉(cāng)庫(kù)管理

    Docker是用Go語(yǔ)言編寫基于Linux操作系統(tǒng)的一些特性開發(fā)的,其提供了操作系統(tǒng)級(jí)別的抽象,是一種容器管理技術(shù),它隔離了應(yīng)用程序?qū)A(chǔ)架構(gòu)(操作系統(tǒng)等)的依賴。這篇文章主要介紹了.NETCore Docker實(shí)現(xiàn)容器化與私有鏡像倉(cāng)庫(kù)管理,需要的朋友可以參考下
    2019-08-08
  • 使用Docker快速搭建Airflow+MySQL詳細(xì)步驟

    使用Docker快速搭建Airflow+MySQL詳細(xì)步驟

    本文詳細(xì)介紹了如何使用Docker和Docker Compose安裝并配置Apache Airflow 2.9.3,步驟包括創(chuàng)建項(xiàng)目目錄、編寫docker-compose.yml文件、創(chuàng)建所需目錄結(jié)構(gòu)、啟動(dòng)和管理Docker容器,以及如何訪問和配置Airflow Web UI,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • docker中使用flink記錄一些組合命令示例

    docker中使用flink記錄一些組合命令示例

    當(dāng)使用Docker運(yùn)行Flink時(shí),可以通過(guò)編寫腳本或者直接在命令行中輸入一系列的組合命令來(lái)完成特定任務(wù),本文給大家分享docker中使用flink記錄一些組合命令示例,感興趣的朋友一起看看吧
    2024-03-03
  • Docker容器配置Nginx實(shí)例分享

    Docker容器配置Nginx實(shí)例分享

    這篇文章主要介紹了Docker容器配置Nginx實(shí)例分享的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • SpringBoot 整合 Docker的詳細(xì)過(guò)程

    SpringBoot 整合 Docker的詳細(xì)過(guò)程

    這篇文章主要介紹了SpringBoot 整合 Docker的詳細(xì)過(guò)程,本文通過(guò)一個(gè)簡(jiǎn)單的項(xiàng)目來(lái)給大家介紹整合的詳細(xì)過(guò)程,需要的朋友可以參考下
    2021-11-11

最新評(píng)論