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

Docker 數(shù)據(jù)卷及數(shù)據(jù)容器詳細(xì)介紹及示例

 更新時間:2016年11月22日 09:55:48   投稿:lqh  
這篇文章主要介紹了Docker 數(shù)據(jù)卷及數(shù)據(jù)容器詳細(xì)介紹及示例的相關(guān)資料,Docker 很強(qiáng)大,不僅部署維護(hù)提高效率,docker和宿主之間的數(shù)據(jù)共享以及docker間的數(shù)據(jù)共享需要好好研究一下,需要的朋友可以參考下

Docker 數(shù)據(jù)卷及數(shù)據(jù)容器

這兩天開始學(xué)習(xí)docker,發(fā)現(xiàn)docker確實很強(qiáng)大,讓網(wǎng)站部署和維護(hù)的效率大大提高。遂準(zhǔn)備將手頭維護(hù)的幾個小站,全部docker化。整理的過程中感覺到,docker可以以功能或者進(jìn)程為單位進(jìn)行部署和維護(hù),不用再花時間在繁瑣的配置上面,但是docker和宿主之間的數(shù)據(jù)共享以及docker間的數(shù)據(jù)共享仍然是讓人頭疼和操心的地方。

幾個基本概念:

docker: 一種容器管理技術(shù),這里也指既有的開發(fā)工具鏈。

container: 容器

image: 鏡像

volum:卷 [ 譯者:卷可以理解成計算機(jī)中的文件路徑 ]

容器中管理數(shù)據(jù)主要有兩種方式:

數(shù)據(jù)卷(Data Volumes)

數(shù)據(jù)卷容器(Data Volume Containers)

數(shù)據(jù)卷

數(shù)據(jù)卷是一個可供容器使用的特殊目錄,它繞過文件系統(tǒng),可以提供很多有用的特性:

  1. 數(shù)據(jù)卷可以在容器之間共享和重用;
  2. 對數(shù)據(jù)卷的修改會立馬有效;
  3. 對數(shù)據(jù)卷的更新,不會影響鏡像;
  4. 卷會一直存在,直到?jīng)]有容器使用。

數(shù)據(jù)卷的使用,類似于Linux下對目錄或文件進(jìn)行mount操作。

掛載本地的目錄到容器里

[root@localhost ~]# docker images
REPOSITORY          TAG         IMAGE ID      CREATED       VIRTUAL SIZE
registry           latest       5c929a8b587a    29 hours ago    33.27 MB
genesis_centos        latest       85bc3a58f134    5 days ago     277.6 MB
192.168.1.179:5000/busybox  latest       9967c5ad88de    12 days ago     1.093 MB
busybox           latest       9967c5ad88de    12 days ago     1.093 MB
centos-6-x86         latest       8fca9486a39b    13 days ago     341.3 MB
centos_with_net       latest       3e8ea8607f08    4 weeks ago     294.9 MB
centos            latest       9baab0af79c4    6 weeks ago     196.7 MB
[root@localhost ~]# ls /data/
ls: 無法訪問/data/: 沒有那個文件或目錄
[root@localhost ~]# mkdir /data/
[root@localhost ~]# docker run -itd -v /data/:/data1 centos bash
096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5
  1. -v 用來指定掛載目錄
  2. “:”前面的/data/為本地目錄
  3. “:”后面的/data1/為容器里的目錄
[root@localhost ~]# touch /data/1.txt
[root@localhost ~]# echo "test" > /data/1.txt
[root@localhost ~]# docker exec -it 09646 bash
[root@096460f831bf /]# df -h
Filesystem                                             Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5 9.8G 231M 9.0G  3% /
tmpfs                                               936M   0 936M  0% /dev
shm                                                 64M   0  64M  0% /dev/shm
/dev/mapper/VolGroup-lv_root                                    35G 6.0G  28G 18% /data1
[root@096460f831bf /]# ls /data1/
1.txt
[root@096460f831bf /]# cat /data1/1.txt
test
[root@096460f831bf /]# touch /data1/2.txt
[root@096460f831bf /]# exit
exit
[root@localhost ~]# ls /data/
1.txt 2.txt

不管是把容器停掉、還是刪除,數(shù)據(jù)還是存在的

[root@localhost ~]# docker stop 09646
09646
[root@localhost ~]# ls /data/
1.txt 2.txt
[root@localhost ~]# docker rm 09646
09646
[root@localhost ~]# ls /data/
1.txt 2.txt

掛載數(shù)據(jù)卷

[root@localhost ~]# docker run -itd -v /data/:/data1 centos bash
e136b27a8e177d878e76c60aafade32df947a60f77b3f95dcaf0680b7ffbc6e8
[root@localhost ~]# docker ps
CONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES
e136b27a8e17    centos       "bash"       14 seconds ago   Up 13 seconds              tender_euclid

其實掛載目錄的時候可以指定容器name,如果不指定就隨機(jī)定義了。比如上面我們沒有指定它,就生成了一個名字為tender_euclid,這個名字可以使用命令 Docker ps 看最右側(cè)一列。

[root@localhost ~]# docker run -itd --volumes-from tender_euclid centos bash
3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164

這樣我們使用centos鏡像創(chuàng)建了新的容器,并且使用了tender_euclid容器的數(shù)據(jù)卷。

[root@localhost ~]# docker ps
CONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES
3222c7c5c456    centos       "bash"       26 seconds ago   Up 25 seconds              sick_albattani
e136b27a8e17    centos       "bash"       6 minutes ago    Up 6 minutes              tender_euclid
[root@localhost ~]# docker exec -it 3222 bash
[root@3222c7c5c456 /]# df -h
Filesystem                                             Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164 9.8G 231M 9.0G  3% /
tmpfs                                               936M   0 936M  0% /dev
shm                                                 64M   0  64M  0% /dev/shm
/dev/mapper/VolGroup-lv_root                                    35G 6.0G  28G 18% /data1
[root@3222c7c5c456 /]# ls /data1/
1.txt 2.txt
[root@3222c7c5c456 /]# touch /data1/3.txt
[root@3222c7c5c456 /]# ls -l /data1/
total 4
-rw-r--r--. 1 root root 5 Oct 20 05:53 1.txt
-rw-r--r--. 1 root root 0 Oct 20 05:59 2.txt
-rw-r--r--. 1 root root 0 Oct 20 06:31 3.txt
[root@3222c7c5c456 /]# exit
exit
[root@localhost ~]# ls /data/
1.txt 2.txt 3.txt

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

定義數(shù)據(jù)卷容器

有時候,我們需要多個容器之間相互共享數(shù)據(jù),類似于linux里面的NFS。所以就可以搭建一個專門的數(shù)據(jù)卷容器,然后其他容器直接掛載該數(shù)據(jù)卷。

首先建立數(shù)據(jù)卷容器

[root@localhost ~]# docker run -itd -v /data/ --name cent_testv centos bash
fb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096

注意:這里的/data/是容器的/data目錄,并非本地的/data/目錄

[root@localhost ~]# docker ps
CONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES
fb45150dbc21    centos       "bash"       8 minutes ago    Up 8 minutes              cent_testv
3222c7c5c456    centos       "bash"       52 minutes ago   Up 52 minutes              sick_albattani
e136b27a8e17    centos       "bash"       58 minutes ago   Up 58 minutes              tender_euclid
[root@localhost ~]# docker exec -it cent_testv bash
[root@fb45150dbc21 /]# df -h
Filesystem                                             Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-fb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096 9.8G 231M 9.0G  3% /
tmpfs                                               936M   0 936M  0% /dev
shm                                                 64M   0  64M  0% /dev/shm
/dev/mapper/VolGroup-lv_root                                    35G 6.0G  28G 18% /data
[root@fb45150dbc21 /]# ls /data/
[root@fb45150dbc21 /]# exit
exit
[root@localhost ~]# ls /data/
1.txt 2.txt 3.txt

其他容器掛載該數(shù)據(jù)卷

[root@localhost ~]# docker run -itd --volumes-from cent_testv centos bash
0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3

注意:使用–volumes-from參數(shù)所掛載數(shù)據(jù)卷的容器自身并不需要保持在運(yùn)行狀態(tài)

[root@localhost ~]# docker ps
CONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES
0a80861145c9    centos       "bash"       3 seconds ago    Up 2 seconds              mad_carson
fb45150dbc21    centos       "bash"       14 minutes ago   Up 14 minutes              cent_testv
3222c7c5c456    centos       "bash"       58 minutes ago   Up 58 minutes              sick_albattani
e136b27a8e17    centos       "bash"       About an hour ago  Up About an hour            tender_euclid
[root@localhost ~]# docker exec -it 0a8086 bash
[root@0a80861145c9 /]# df -h
Filesystem                                             Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3 9.8G 231M 9.0G  3% /
tmpfs                                               936M   0 936M  0% /dev
shm                                                 64M   0  64M  0% /dev/shm
/dev/mapper/VolGroup-lv_root                                    35G 6.0G  28G 18% /data

[root@0a80861145c9 /]# touch /data/fight.txt
[root@0a80861145c9 /]# exit
exit
[root@localhost ~]# docker exec -it cent_testv bash
[root@fb45150dbc21 /]# ls /data/
fight.txt
[root@fb45150dbc21 /]# exit
exit

利用數(shù)據(jù)卷容器遷移數(shù)據(jù)

數(shù)據(jù)卷的備份

[root@localhost ~]# docker run -itd --volumes-from cent_testv -v /vol_data_backup/:/backup centos bash
4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20

首先我們需要使用cent_testv數(shù)據(jù)卷新開一個容器,同時我們還需要把本地的/vol_data_backup/目錄掛載到該容器的/backup下,這樣在容器中/backup目錄里面新建的文件我們就可以直接在/vol_data_backup/目錄中看到了。 然后再把/data/目錄下面的文件打包到成data.tar文件放到/backup目錄下面。

[root@localhost ~]# docker exec -it 4f5bf bash
[root@4f5bf6f33f2c /]# df -h
Filesystem                                             Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20 9.8G 231M 9.0G  3% /
tmpfs                                               936M   0 936M  0% /dev
shm                                                 64M   0  64M  0% /dev/shm
/dev/mapper/VolGroup-lv_root                                    35G 6.0G  28G 18% /data
[root@4f5bf6f33f2c /]# ls /backup/
[root@4f5bf6f33f2c /]# ls /data/
fight.txt

[root@4f5bf6f33f2c /]# tar cvf /backup/data.tar /data/
tar: Removing leading `/' from member names
/data/
/data/fight.txt
[root@4f5bf6f33f2c /]# exit
exit
[root@localhost ~]# ls /vol_data_backup/
data.tar

恢復(fù)

先新建一個數(shù)據(jù)卷容器,再建一個新的容器并掛載該數(shù)據(jù)卷容器,然后再把tar包解包。

[root@localhost ~]# docker run -itd -v /data --name cent_testv2 centos bash
4cd696928bbe6e0aec9bf8b6856323d7228eb65006b21849eff9f0d41dcea90f
[root@localhost ~]# docker run -itd --volumes-from cent_testv2 -v /vol_data_backup/:/backup centos
7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5
[root@localhost ~]# docker exec -it 7169 bash
[root@7169e8be6d3e /]# df -h
Filesystem                                             Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5 9.8G 231M 9.0G  3% /
tmpfs                                               936M   0 936M  0% /dev
shm                                                 64M   0  64M  0% /dev/shm
/dev/mapper/VolGroup-lv_root                                    35G 6.0G  28G 18% /data
[root@7169e8be6d3e /]# ls /backup/
data.tar
[root@7169e8be6d3e /]# mv /backup/data.tar .
[root@7169e8be6d3e /]# ls
anaconda-post.log bin  data.tar etc  lib  lost+found mnt proc run  srv tmp var
backup       data dev    home lib64 media    opt root sbin sys usr
[root@7169e8be6d3e /]# tar xvf data.tar
data/
data/fight.txt
[root@7169e8be6d3e /]# ls /data/
fight.txt
[root@7169e8be6d3e /]# exit
exit
[root@localhost ~]# ls /vol_data_backup/
[root@localhost ~]#



感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • docker-compose安裝yml文件配置方式

    docker-compose安裝yml文件配置方式

    這篇文章主要介紹了docker-compose安裝,yml文件配置,離線安裝及在線安裝的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • dockerfile部署前端vue打包的ist文件實戰(zhàn)

    dockerfile部署前端vue打包的ist文件實戰(zhàn)

    這篇文章主要為大家介紹了dockerfile部署前端vue打包的ist文件實戰(zhàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • docker 搭建基于prometheus的監(jiān)控體系步驟實現(xiàn)

    docker 搭建基于prometheus的監(jiān)控體系步驟實現(xiàn)

    本文主要介紹了docker 搭建基于prometheus的監(jiān)控體系步驟實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 10分鐘學(xué)會docker

    10分鐘學(xué)會docker

    Docker 是一個開源的應(yīng)用容器引擎,基于 Go 語言 并遵從Apache2.0協(xié)議開源。Docker 可以讓開發(fā)者打包他們的應(yīng)用以及依賴包到一個輕量級、可移植的容器中,然后發(fā)布到任何流行的 Linux 機(jī)器上,也可以實現(xiàn)虛擬化。
    2017-06-06
  • 詳解在Docker容器內(nèi)外互相拷貝數(shù)據(jù)的方法

    詳解在Docker容器內(nèi)外互相拷貝數(shù)據(jù)的方法

    本篇文章主要介紹了詳解在Docker容器內(nèi)外互相拷貝數(shù)據(jù)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • 關(guān)于Docker容器內(nèi)部無法解析域名問題的解決

    關(guān)于Docker容器內(nèi)部無法解析域名問題的解決

    最近工作中遇到一個問題,項目內(nèi)部需要訪問外網(wǎng),但上傳文件,但是一直報unknown host,無法解析域名,所以下面這篇文章主要給大家介紹了關(guān)于Docker容器內(nèi)部無法解析域名問題的解決方法,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-07-07
  • 詳解Windows下運(yùn)用Docker部署Node.js開發(fā)環(huán)境

    詳解Windows下運(yùn)用Docker部署Node.js開發(fā)環(huán)境

    這篇文章主要介紹了詳解Windows下運(yùn)用Docker部署Node.js開發(fā)環(huán)境,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 解決Jenkins集成docker插件問題的一些方法

    解決Jenkins集成docker插件問題的一些方法

    本文主要介紹了Jenkins集成docker插件問題的一些方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 一文搞定Docker安裝ElasticSearch的過程

    一文搞定Docker安裝ElasticSearch的過程

    通過本文可以幫助大家快速學(xué)習(xí)Docker安裝ElasticSearch的過程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-08-08
  • Docker部署Minio的實現(xiàn)方法

    Docker部署Minio的實現(xiàn)方法

    使用Docker搭建MinIO分布式對象存儲系統(tǒng)可以讓您快速搭建和配置一個高性能、可擴(kuò)展的存儲系統(tǒng),本文主要介紹了Docker部署Minio的實現(xiàn)方法,感興趣的可以了解一下
    2024-01-01

最新評論