Docker數據捲的創建與應用

来源:https://www.cnblogs.com/lz-200/archive/2020/07/29/13399492.html
-Advertisement-
Play Games

在容器里增加、刪除或修改文件,其實都是對可寫層里的文件副本進行了操作。在容器關閉後,該可寫層也會被刪除,對容器的所有修改都會失效,因此需要解決容器內文件持久化的問題。Docker提供了兩種方案來實現: 一、Docker掛載時創建捲:把宿主機文件系統里的目錄映射到容器內的目錄。如此一來,容器內在該目錄 ...


在容器里增加、刪除或修改文件,其實都是對可寫層里的文件副本進行了操作。在容器關閉後,該可寫層也會被刪除,對容器的所有修改都會失效,因此需要解決容器內文件持久化的問題。Docker提供了兩種方案來實現:

一、Docker掛載時創建捲:把宿主機文件系統里的目錄映射到容器內的目錄。如此一來,容器內在該目錄里創建的所有文件,都存儲到宿主機的對應目錄中,在關閉容器後,宿主機的目錄依然存在,再次啟動容器時還能讀取到之前創建的文件,因此實現了容器的文件持久化。當然同時要明白,如果是對鏡像自帶文件進行了修改,由於鏡像是只讀的,該修改操作無法在關閉容器時保存下來,除非在修改了文件後構建一個新的鏡像。

1、Docker 掛載捲

從nginx鏡像中拉取一個名為nginx-test01的容器,指定映射到宿主機80埠,將宿主機的/data掛載到容器/usr/share/nginx/html下,從而使宿主機的/data成為掛載捲

[[email protected] ~]# docker run -d -p 80:80 -v /data:/usr/share/nginx/html --name nginx-test01 nginx
4fdbb1bdfcb36348643f0c2e64a72e9750ee0b2e1b6dbae3d41fcec179209ce6

訪問測試:

[[email protected] ~]# curl 192.168.22.135:80
<html>
<head><title>403 Forbidden</title></head>
<body>
<center><h1>403 Forbidden</h1></center>
<hr><center>nginx/1.17.5</center>
</body>
</html>

由於/data中並沒有主頁資源,所以訪問結果顯示403(在下一步中寫入)

2、宿主機寫入數據再次訪問驗證:

[[email protected] ~]# cd /data
[[email protected] data]# ls
[[email protected] data]# echo 123asd > index.html
[[email protected] data]# curl 192.168.22.135:80
123asd

3、設置共用捲

使用同一個捲啟動一個新容器並訪問測試:

從nginx鏡像中拉取一個名為nginx-test02的容器,指定映射到宿主機8080埠,仍將宿主機的/data掛載到容器/usr/share/nginx/html下,由於/data已作為了容器nginx-test01的掛在捲,在這裡又成為了nginx-test02掛載捲,因此宿主機/data成為共用捲。

[[email protected] ~]# docker run -d -p 8080:80 -v /data:/usr/share/nginx/html --name nginx-test02 nginx
0c609176a6f77df1d467d679f18221de900943ddbc9aba9c589c00b6ed9e6405

[[email protected] ~]# curl 192.168.22.135:8080
123asd

二、Docker創建捲後掛載把多台宿主機的磁碟目錄通過網路聯合為共用存儲,然後把共用存儲中的特定目錄映射給特定的容器,這樣容器在重啟時,還是能讀取到關閉前創建的文件。生產環境中常用NFS作為共用存儲方案。

1、創建一個名為nginx-j01的簡單捲並查看捲列表

[[email protected] ~]# docker volume create --name nginx-j01
nginx-j01

[[email protected] ~]# docker volume ls
DRIVER              VOLUME NAME
local               nginx-j01

2、查看捲路徑

[[email protected] ~]# docker volume inspect nginx-j01
[
    {
        "CreatedAt": "2020-07-29T17:50:21+08:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/nginx-j01/_data",
        "Name": "nginx-j01",
        "Options": {},
        "Scope": "local"
    }
]

可查看出捲所在路徑為/var/lib/docker/volumes/nginx-j01/_data

3、創建docker共用捲掛載

從鏡像nginx中拉取一個名為nginx-test03的容器,映射宿主機埠9000,將之前創建的共用捲nginx-j01掛載到名為nginx-test03的容器中;將數據寫入主頁文件,並做訪問測試。

[[email protected] ~]# docker run -d -p 9000:80 -v nginx-j01:/usr/share/nginx/html --name nginx-test03 nginx
c40c65a2060d34319ac33a2263fb11cffdf50075b8efd4209cbd97ee163fb2e7

[[email protected] ~]# echo 888 > /var/lib/docker/volumes/nginx-j01/_data/index.html

[[email protected] ~]# curl 192.168.22.135:9000
888

4、實現docker共用捲掛載

從鏡像nginx中拉取一個名為nginx-test04的容器,自動映射一個宿主機埠,將之前創建的共用捲掛載到該容器中,因為該共用捲之前掛載到了nginx-test03又掛載到了nginx-test04中,所以正在成為了共用捲。

[[email protected] ~]# docker run -d -P --volumes-from nginx-test03 --name nginx-test04 nginx
862e2f3867cb33a91dcc3b3809bde7a0de951a11fea8fea77163db7c39a227b2

--volumes-from # 指定共用捲所在的容器

5、查看使用的埠並做訪問測試

[[email protected] ~]# netstat -lntup
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      1104/master
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1015/sshd
tcp6       0      0 ::1:25                  :::*                    LISTEN      1104/master
tcp6       0      0 :::32768                :::*                    LISTEN      88573/docker-proxy
tcp6       0      0 :::9000                 :::*                    LISTEN      55370/docker-proxy
tcp6       0      0 :::8080                 :::*                    LISTEN      53960/docker-proxy
tcp6       0      0 :::80                   :::*                    LISTEN      52152/docker-proxy
tcp6       0      0 :::22                   :::*                    LISTEN      1015/sshd

[[email protected] ~]# curl 192.168.22.135:32768
888

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 練習1:題目:有四個數字:1、2、3、4,能組成多少個互不相同且無重覆數字的三位數?各是多少?語句: # coding: utf-8 print ('題目:有四個數字:1、2、3、4,能組成多少個互不相同且無重覆數字的三位數?各是多少?')for aa in range(1, 5): for ab ...
  • 原文:https://almirai.live/Coding/Java/JavaWeb/Basics/type/ 數據類型 基本類型 類型 占用空間(Byte) 取值範圍 byte(位元組型) 1 -128~127 short(短整型) 2 −216~216−1 int(整型) 4 −231~231− ...
  • 提起AI,大家都會先想到Python,確實Python作為一門好幾十年的老語言,上一波的AI大流行使它煥發了青春。大家用Phtyon來做AI,最主要的原因無非就是編碼量更少,很多數學和AI相關的Api都是現成的。但是隨著ML.net的問世,我們現在可以在.netcore平臺上使用比Python更少的 ...
  • 環境: Vs 2015 .net 4.5.2 源碼: public static void toScreen() { ThreadStart ts = new ThreadStart(() =>//開線程 { Screen scr = Screen.PrimaryScreen; Rectangle ...
  • 效果圖片: 分步解析實現過程: 一.新建報表所需要的文件以及類: 1.新建一個WindowForm項目WindowsFormsReport; 2. 添加Entity文件夾,並添加StudentEntity.cs類; public class StudentEntity { /// <summary> ...
  • 一 使用背景: 通過Http 請求下載一個壓縮的文件到伺服器記憶體中(重點:不用保存到本地),然後通過代碼直接提取壓縮包的文件 二 實現思路:(註:需要提前安裝 ICSharpCode.SharpZipLib.dll) 1 通過Http請求下載壓縮文件到伺服器的記憶體中 2 讀取記憶體中壓縮的包的流(註意 ...
  • 上篇我們完成了數據源保存功能,並順便看了保存後的數據源列表展示功能。 本篇我們開始開發預覽功能,用戶預覽主要步驟: 1、點擊數據源卡片預覽按鈕 2、查看數據源包含的表 3、點擊表名,預覽表中數據 一、前端結構及樣式 效果如下圖(靜態html示意圖): 左側是數據源及包含的表。 右上為篩選條件(篩選條 ...
  • 基於kubeadm快速部署kubernetes K8S V1.17.4集群,並部署Dashboard Web頁面,實現可視化查看Kubernetes資源 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文將以 C# 語言來實現一個簡單的布隆過濾器,為簡化說明,設計得很簡單,僅供學習使用。 感謝@時總百忙之中的指導。 布隆過濾器簡介 布隆過濾器(Bloom filter)是一種特殊的 Hash Table,能夠以較小的存儲空間較快地判斷出數據是否存在。常用於允許一定誤判率的數據過濾及防止緩存 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 「簡單有價值的事情長期堅持做」 這是成功最簡單,但也最難學的秘訣。不經過訓練,人很難意識到時間複利的威力。 仙劍奇俠傳的「十里坡劍神」和金庸群俠傳的「十級野球拳」,就是簡單的事情持之以恆反覆做,最後就有巨大的威力 唐家三少成為網文收入第一,最重要的一步是十四年從未斷日更 這樣的案例很多,一開始可能成 ...
  • 迎面走來了你的面試官,身穿格子衫,挺著啤酒肚,髮際線嚴重後移的中年男子。 手拿泡著枸杞的保溫杯,胳膊夾著MacBook,MacBook上還貼著公司標語:“我愛加班”。 面試開始,直入正題。 面試官: 看你簡歷上面寫著精通MySQL,我先問你事務的特性是什麼? 老生常談,這個還有誰不會背的嗎? 我: ...
  • 基礎知識 python是一門腳本語言,它是解釋執行的。 python使用縮進做為語法,而且python2環境下同一個py文件中不能同時存在tab和空格縮進,否則會出錯,建議在IDE中顯示縮進符。 python在聲明變數時不寫數據類型,可以type(xx)來獲取欄位的類型,然後可以int(),list ...
  • 為什麼要多線程下載 俗話說要以終為始,那麼我們首先要明確多線程下載的目標是什麼,不外乎是為了更快的下載文件。那麼問題來了,多線程下載文件相比於單線程是不是更快? 對於這個問題可以看下圖。 橫坐標是線程數,縱坐標是使用對應線程數下載對應文件時花費的時間,藍橙綠代表下載文件的大小,每個線程下載對應文件2 ...
  • 詳細講解python爬蟲代碼,爬微博搜索結果的博文數據。 爬取欄位: 頁碼、微博id、微博bid、微博作者、發佈時間、微博內容、轉發數、評論數、點贊數。 爬蟲技術: 1、requests 發送請求 2、datetime 時間格式轉換 3、jsonpath 快速解析json數據 4、re 正則表達式提... ...
  • 背景: 一般我們可以用HashMap做本地緩存,但是HashMap功能比較弱,不支持Key過期,不支持數據範圍查找等。故在此實現了一個簡易的本地緩存,取名叫fastmap。 功能: 1.支持數據過期 2.支持等值查找 3.支持範圍查找 4.支持key排序 實現思路: 1.等值查找採用HashMap2 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 本章是系列文章的第八章,用著色演算法進行寄存器的分配過程。 本文中的所有內容來自學習DCC888的學習筆記或者自己理解的整理,如需轉載請註明出處。周榮華@燧原科技 寄存器分配 寄存器分配是為程式處理的值找到存儲位置的問題 這些值可以存放到寄存器,也可以存放在記憶體中 寄存器更快,但數量有限 記憶體很多,但 ...