中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

docker數據管理的方法是什么

發布時間:2022-02-16 10:42:33 來源:億速云 閱讀:173 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“docker數據管理的方法是什么”,內容詳細,步驟清晰,細節處理妥當,希望這篇“docker數據管理的方法是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

docker數據管理的方法是什么

數據的管理目前提供如下兩種方式:

(1)數據卷 data volumes

(2)數據卷容器 data volumes containers

數據卷

數據卷,說白了就是一個特殊目錄,類似linux下對目錄或文件進行mount掛載操作,只不過他繞過了文件系統。具有如下特點:

(1)數據卷可以在容器之間進行共享和重用

(2)對數據卷的更改會立即生效

(3)對數據卷的更新不會影響到鏡像 (鏡像只讀)

(4)卷會一直存在,直到沒有容器使用

數據卷的添加可以通過-v 參數來設定,后邊跟上目錄。一下舉例說明:

創建一個數據卷/homedata到容器os123中

[root@docker5 home]# docker  run  -d -ti --name os123   -v  /homedata  centos[root@docker5 home]# docker  exex  -ti os123 /bin/bash[root@d1a05a7d5efe /]# lltotal 40
-rw-r--r--. 1 root root 18301 Jun 2 13:27 anaconda-post.log
lrwxrwxrwx. 1 root root 7 Jun 2 13:25 bin > usr/bin
drwxr-xr-x. 5 root root 380 Jun 23 02:42 dev
drwxr-xr-x. 48 root root 4096 Jun 23 02:42 etc
drwxr-xr-x. 2 root root 6 Aug 12 2015 home
drwxr-xr-x. 2 root root 6 Jun 23 02:42 homedata
..
[root@d1a05a7d5efe /]# cd homedata/[root@d1a05a7d5efe homedata]# lltotal 0
[root@d1a05a7d5efe homedata]# touch  21yunwei.txt ;echo 123>> 21yunwei.txt[root@d1a05a7d5efe homedata]# cat  21yunwei.txt123

掛載本地服務器上的一個目錄/home/data到容器os456 目錄/homedata中

home/data事先里邊建立一個文件1.txt并內容hello world

[root@docker5 home]# docker run  -d -ti --name os456 -v /home/data:/homedata centos[root@docker5 home]# docker exec  -ti os456  /bin/bash[root@9347d5ef84ff homedata]# cd /homedata;cat  1.txthello world

通過上邊兩個容器os123 和os456,基本了解了如何創建數據卷以及如何掛載本地目錄到數據卷中。注意,兩個容器中的如果是單獨掛載的數據卷(即沒有掛載同一個數據卷容器),那么數據是互不影響的,進入不同的數據卷相同目錄下比如/homedata,內容可以不一樣。

注意:刪除容器的時候,數據卷不會刪除。如果要刪除容器的時候同時刪除數據卷,需加上-v參數。比如: docker rm os456 -v /homedata

數據卷容器

建立的容器很多時候不是單一的,需要容器之間進行數據共享,進行數據同步和更新操作。這樣就需要建立一個數據卷容器。

數據卷容器就是一個普通的容器,里邊帶有設置好的數據卷,專門提供給其他容器掛載使用。 通過–volumes-from 數據卷容器名 來實現。

我有一個網站程序放到了服務器本機的/home/webdata目錄 ,下邊創建一個數據卷容器webdata,同時將我服務器上的/home/webdata掛載到數據卷容器的/web目錄:

[root@docker5 home]# docker  run  -d  -ti  --name webdata   -v  /home/webdata:/home/web  centos

進入容器并查看數據

[root@docker5 home]# docker exec  -ti  webdata  /bin/bash[root@289598d6e24d /]# cd  /home/web/[root@289598d6e24d web]# lltotal 7872
drwxr-xr-x. 3 root root      54 Mar 27  2013 META-INF
drwxr-xr-x. 6 root root    4096 Dec 25  2014 WEB-INF
drwxr-xr-x. 3 root root      63 Mar 27  2013 css
drwxr-xr-x. 2 root root    8192 Mar 27  2013 flags
-rw-r--r--. 1 root root      97 Mar 27  2013 index.jsp
drwxr-xr-x. 2 root root    4096 Mar 27  2013 js
drwxr-xr-x. 2 root root       6 Jun 23 03:43 probe

通過這里建立1.txt 并插入內容,可以看到服務器上的/home/webdata數據是同步的。可見容器以及目錄掛載都沒問題。

[root@docker5 home]# docker  run  -dti --volumes-from webdata --name os147 centos[root@docker5 home]# docker  run  -dti --volumes-from webdata --name os258 centos

分別創建了兩個容器,都通過–volumes-from webdata 掛載了同一個數據卷容器,進入os147 和os258 分別查看/home/web可見數據都是存在的,于是這里就實現了數據的共享同步。

[root@docker5 home]# docker exec  -ti  os147  /bin/bash[root@b4cfa4c4e11c /]# cd  /home/web/[root@b4cfa4c4e11c web]# lltotal 7876
-rw-r--r--. 1 root root      11 Jun 23 03:46 1.txt
drwxr-xr-x. 3 root root      54 Mar 27  2013 META-INF
drwxr-xr-x. 6 root root    4096 Dec 25  2014 WEB-INF
drwxr-xr-x. 3 root root      63 Mar 27  2013 css
drwxr-xr-x. 2 root root    8192 Mar 27  2013 flags
-rw-r--r--. 1 root root      97 Mar 27  2013 index.jsp
drwxr-xr-x. 2 root root    4096 Mar 27  2013 js
drwxr-xr-x. 2 root root       6 Jun 23 03:43 probe

說明:

1,可以多次使用–volume-from參數從多個容器掛載多個目錄。 也可以從其他已經掛載了數據卷的容器來掛載數據卷(類似傳遞)。

2,再次強調:如果刪除了掛載的容器,數據卷不會被自動刪除。如果要刪除容器的時候同時刪除數據卷,需加上-v參數。

通過數據卷容器進行數據備份、數據恢復和數據遷移

備份

我們創建一個專門用來備份probe的容器:probebak進行備份數據卷容器中的數據,命令如下

 docker run  -dti --volumes-from webdata  --name probebak -v /home/web_probebak:/backup   centos tar zcvf /backup/web_probe.tar.gz  /home/web

命令為創建一個專用備份的容器probebak,掛載了數據卷容器webdata,同時將服務器本地目錄 /home/web_probebak掛載到了備份容器上的/backup目錄容器啟動以后,會執行tar zcvf /backup/web_proce.tar.gz /home/web操作,完成服務器上/home/web備份,打包到/backup/web_proce.tar.gz,也就是打包到了/home/web_probebak/web_probe.tar.gz 實現了數據備份。

恢復

創建一個容器os999 ,掛載有數據卷 /testdata

[root@docker5 home]# docker run  -v  /testdata --name os999  centos  /bin/bash

再建一個容器,通過–volumes-from os999掛載剛才設置好的數據卷,解壓數據:

[root@docker5 home]# docker run --volumes-from os999 -v /home/web_probebak:/backup busybox tar zxvf /backup/web_probe.tar.gzUsage of loopback devices is strongly discouraged for production use. Either use `--storage-opt dm.thinpooldev` or use `--storage-opt dm.no_warn_on_loop_devices=true` to suppress this warning.
home/web/
home/web/probe.zip
home/web/probe/
home/web/css/
home/web/css/classic/
home/web/css/classic/datasourcetest.css

讀到這里,這篇“docker數據管理的方法是什么”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巫山县| 渝北区| 武定县| 闵行区| 三穗县| 黄平县| 云浮市| 溧水县| 稷山县| 石渠县| 呼玛县| 巴青县| 富阳市| 玉龙| 延津县| 修水县| 玛多县| 汤阴县| 万山特区| 云和县| 沂源县| 梁平县| 武定县| 灵台县| 嘉峪关市| 三河市| 海门市| 通化县| 固镇县| 牙克石市| 尉氏县| 金乡县| 罗定市| 卢湾区| 荃湾区| 正安县| 平远县| 思茅市| 上杭县| 清苑县| 兴安县|