19-數據持久化-Bind Mounting

19-數據持久化-Bind Mounting

Bind Mounting 與 Data Volume區別

Data Volume 需要在 Dockerfile 內聲明需要創建的 volume 目錄。

Bind Mounting 則不需要在 Dockerfile 聲明 volume,只需要在創建容器的時候,也就是 run 的時候聲明即可。

如:

docker run -v /home/aaa:/root/aaa demo

上一節中 -v 參數是 mysql:/var/lib/mysql,冒號 “:” 左邊是對 /var/lib/mysql 這個目錄產生的volume起一個別名。

而在 Bind Mounting 中,-v 參數冒號 “:” 左邊是本地的目錄路徑,右邊是創建容器內的路徑,做一個映射。

Bind Mounting

通過 Bind Mounting 創建的 volume,在我們修改本地的目錄時,容器內對應的目錄也會跟著修改,因為是同一個volume。

接下來我們通過一個實驗來查看。

  1. 創建一個docker-nginx文件夾,并進入

    mkdir docker-nginx
    cd docker-nginx
    
  2. 創建Dockerfiile和index.html兩個文件

    touch Dockerfile index.html
    

    修改Dockerfile文件如下:

    FROM nginx:latestWORKDIR /usr/share/nginx/htmlCOPY index.html index.html
    

    修改index.html文件如下:

    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    
  3. 創建鏡像

    docker build -t vincent/my-nginx .
    
  4. 創建容器

    docker run -d -p 80:80 --name web vincent/my-nginx
    

    查看運行狀態

    [vagrant@10 docker-nginx]$ docker ps
    CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                NAMES
    190b2e296c54        vincent/my-nginx    "nginx -g 'daemon of…"   2 seconds ago       Up 1 second         0.0.0.0:80->80/tcp   web
    

    可以看到web容器是up的。

  5. 訪問本機80端口獲取web容器的內容

    [vagrant@10 docker-nginx]$ curl 127.0.0.1
    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    

    curl使用http協議的時候默認是80端口,https默認是443,我們是可以不需要加端口號的。

    我們也可以在筆記本中去訪問這臺虛擬機的80端口服務

     vincent@dell-Inspiron-7559$: curl http://192.168.2.32
    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    

    也可以通過瀏覽器訪問查看,ip首先要在虛擬機內通過ip a獲取。

  6. 重新創建web容器并指定volume

    刪除web容器

    docker rm -f web
    

    這條命令會強制刪除一個正在運行的容器,不推薦使用。

    重新創建容器,并指定掛載 /home/vagrant/docker-nginx/ 目錄。

    docker run -d -p 80:80 -v /home/vagrant/docker-nginx/:/usr/share/nginx/html --name web vincent/my-nginx
    
  7. 查看被掛載的目錄在容器內情況

    進入web容器

    docker exec -it web /bin/bash
    

    查看 /usr/share/nginx/html 目錄下有哪些內容

    root@cb7e310d02fd:/usr/share/nginx/html# ls /usr/share/nginx/html
    Dockerfile  index.html
    

    我們發現在 /home/vagrant/docker-nginx/ 文件夾內的Dockerfile文件被映射進來了。

    那我們在 /usr/share/nginx/html 文件夾內創建一個 test.txt 文件,看看是否在 外部也能看到

    touch test.txt
    

    創建好之后退出web容器,進入/home/vagrant/docker-nginx/目錄下查看

    exit
    [vagrant@10 docker-nginx]$ ls
    Dockerfile  index.html  test.txt
    

    我們發現同樣被映射到了外面 docker-nginx 目錄下。同樣我們可以測試在容器內修改 test.txt 文件看看里外是否同步。

    進入web容器

    docker exec -it web /bin/bash
    

    修改test.txt文件

    root@cb7e310d02fd:/usr/share/nginx/html# echo "1234" >> test.txt 
    root@cb7e310d02fd:/usr/share/nginx/html# cat test.txt 
    1234
    

    完成后我們退出容器并查看這個文件是否同步了

    exit
    [vagrant@10 docker-nginx]$ cat test.txt 
    1234
    

    結果是同樣發生了同步。因為我們修改的其實是同一個文件。

熱更新

  1. 我們再次執行一次curl獲取web內容

    [vagrant@10 flask-app]$ curl 127.0.0.1
    <html>
    <body><h1>Bind Mounting</h1><p>This is a demo.</p></body>
    </html>
    
  2. 此時我們手動修改本機目錄下的index.html文件

    nano docker-nginx/index.html
    

    修改如下:

    <html>
    <body><h1>Bind Mounting</h1><p>This is a app.</p></body>
    </html>
    
  3. 驗證在不重啟nginx服務器的情況下是否web內容發生變化

    [vagrant@10 docker-nginx]$ curl 127.0.0.1
    <html>
    <body><h1>Bind Mounting</h1><p>This is a app.</p></body>
    </html>
    

    我們可以看到web內容已經發生了變化。

這對于開發或后續更新來說是很好的。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/536027.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/536027.shtml
英文地址,請注明出處:http://en.pswp.cn/news/536027.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

go自定義包教程

go自定義包教程 而是環境為 go version go1.11 linux/amd64linux mint 19 創建一個自定義的包 切換到src目錄下&#xff0c;創建demo目錄 cd src mkdir demo再創建smap 文件夾 cd demo mkdir smap創建包文件 cd smap touch map.gomap.go文件內容 package smapimport "…

在Linux中對硬盤進行分區、格式化和掛載

在Linux中對硬盤進行分區、格式化和掛載 我最近有一個全新的4-TB硬盤加入我的電腦。所以我需要在Linux中安裝它。為此&#xff0c;我需要執行以下操作&#xff1a; 分區格式化掛載檢查是否已安裝硬盤驅動器 分區 首先&#xff0c;在通過SATA和電源線將硬盤連接到計算機后&am…

Angular gitlab持續集成之runner配置

gitlab持續集成 安裝Runner 正常安裝 sudo wget -O /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-amd64sudo chmod x /usr/local/bin/gitlab-runner sudo useradd --comment GitLab Runner --creat…

javascript編譯壓縮

javascript編譯 js是JavaScript 源碼文件&#xff0c; .min.js是壓縮版的js文件。 .min.js文件經過壓縮&#xff0c;相對編譯前的js文件體積較小&#xff0c;傳輸效率快。經過編碼將變量和函數原命名改為毫無意義的命名&#xff0c;以防止他人窺視和竊取 js 源代碼 在線版 g…

vscode設置中文

vscode設置中文 當我們安裝完成vscode后&#xff0c;會發現它是中文的&#xff0c;因為默認情況下&#xff0c;vscode使用的語言為英文(us)。 那很多同學是不喜歡英文的&#xff0c;不是看不懂&#xff0c;而是不方便哈。 修改語言配置文件 使用快捷鍵組合【CtrlShiftp】 在…

linux下編譯boost

linux下編譯boost 下載boot庫 官方下載地址 下載完成會解壓。 編譯 1.進入解壓后的文件夾內 cd boost_1_69_0 執行下面的語句 ./bootstrap.sh --with-librariesall --with-toolsetgcc–with-libraries 指定編譯哪些boost庫&#xff0c;all的話就是全部編譯&#xff0c;只想…

C++通過原子變量代替互斥量

C通過原子變量代替互斥量 廢話不多說&#xff0c;直接上代碼。 實現類似lock_guard功能 #include <atomic> #include <thread>class ClockGuard { public:ClockGuard(std::atomic_flag & atomic):m_lockedFlag(atomic){lock();}~ClockGuard(){unlock();}voi…

conky安裝配置

conky安裝配置 安裝conky sudo apt-get install conky-all修改配置 在主目錄下創建’.conkyrc’ 文件內容&#xff1a; # set to yes if you want Conky to be forked in the background background no cpu_avg_samples 2 net_avg_samples 2 out_to_console no # X font w…

Windows子系統安裝圖形界面

Windows子系統安裝圖形界面 有很多同學需要使用 linux 系統,但是又不想真正安裝一個 linux 系統。于是微軟大哥就把 ubuntu 系統集成到 windows 內了&#xff0c;你說 微軟 屌不屌&#xff1f; 言歸正傳。 安裝Xlaunch 因為這個是最靠譜的圖形化界面了&#xff0c;所以不解…

C++ 判斷類是否有某變量

C 判斷類是否有某變量 話不多說上代碼。 #define HAS_MEMBER(member)\template<typename T, typename... Args>struct has_member_##member\ {\private:\template<typename U> static auto Check(int) -> decltype(std::declval<U>().member(std::declv…

C++將地址轉換為字符串

C將地址轉換為字符串 有時候在做程序設計的時候&#xff0c;有可能需要做一個類似messageBus的功能&#xff0c;并且需要一個key保證唯一&#xff0c;那么如何實現這個key的唯一呢&#xff1f;大致兩種思路: 使用函數簽名&#xff0c;因為messagebus綁定的是一個函數&#xf…

Angular 8之升級和新功能摘要

Angular 8之升級和新功能摘要 Angular 8已經到來,并帶來了大量的工作流程和性能改進。就像我們之前發布的幾個版本一樣,讓我們回顧一下Angular 8的新功能,以及如何將Angular 7應用程序升級到Angular 8。 Angular 8中明顯的新功能數量有限,但確實還有一些好東西: Differen…

Linux下查看顯卡PCIE速率x16x8x4及設定

Linux下查看顯卡PCIE速率x16x8x4 由于linux軟件并不是很齊全所以查看顯卡占用PCIE的帶寬并不直觀&#xff0c;所以本文介紹如何查看。 Windows下使用GPU-Z即可查看 Linux 確定當前顯卡型號 lspci | grep NVIDIA返回 02:00.0 3D controller: NVIDIA Corporation GM107M [GeFor…

Deepin安裝最新顯卡RTX2080Ti及CUDA10.1

Deepin安裝最新顯卡RTX2080Ti及CUDA10.1 廢話不多說直接上教程。 本系統為Deepin 15.10.2&#xff0c;是基于debian 9發布的&#xff0c;不排除后續deepin升級為debian 10&#xff0c;就目前來看是和ubuntu 16.04一樣&#xff0c;使用的是debian 9&#xff0c;所以下載安裝包等…

Anaconda安裝Tensorflow環境

Anaconda安裝Tensorflow環境 Anaconda安裝 下載安裝包&#xff0c;請到這個地址下載 安裝 打開終端執行&#xff1a; bash Anaconda3-5.3.1-Linux-x86_64.sh安裝過程全部yes即可。 然后重新啟動。 驗證是否安裝成功 conda --version如果沒有報錯&#xff0c;并且輸出下面內容…

Windows下Qt Creator設置IDE菜單字體樣式

Windows下Qt Creator設置IDE菜單字體樣式 本文為解決以下問題&#xff1a; IDE的菜單字體太小IDE的菜單字體樣式&#xff0c;可以更換為微軟雅黑 創建樣式文件 在Qt Creator目錄下C:\Qt\Qt5.12.2創建 custom-style.css 文件&#xff0c;內容如下&#xff1a; QWidget { fo…

Clonezilla再生龍備份與還原linux系統

文章目錄Clonezilla再生龍備份與還原linux系統簡介功能與要求一、制作再生龍啟動盤1.下載鏡像2.制作啟動盤二、系統分區三、備份系統四、還原系統注意事項Clonezilla再生龍備份與還原linux系統 簡介 再生龍&#xff08;Clonezilla&#xff09;是一個免費的災難恢復、硬盤克隆…

ubuntu Qt Creator不能輸入中文

ubuntu Qt Creator不能輸入中文 解決方式為下面的腳本&#xff0c;如果你的Qt是安裝在根目錄下&#xff0c;那么需要加sudo&#xff0c;如果不是&#xff0c;直接運行即可 sudo bash ChineseInputForQt-v1.1.sh# 或者bash ChineseInputForQt-v1.1.sh腳本內容為&#xff1a; …

修改gitlab數據卷的位置

修改gitlab數據卷的位置 在使用docker安裝gitlab的時候&#xff0c;一開始沒有考慮其他事情&#xff0c;直接在本地創建了一個數據卷就掛載到容器上了&#xff0c;導致后續數據越來越多&#xff0c;想將數據放到其他盤&#xff0c;大致可以這樣操作。 1.停止容器 docker sto…

Angular安裝教程

Angular安裝 安裝node和npm 參考這篇文章安裝 https://blog.csdn.net/wf19930209/article/details/84226365 正式安裝 當然&#xff0c;在安裝 angular/cli 之前需要先把 Node.js 安裝好&#xff0c;請到官方網站下載安裝包 &#xff0c;安裝過程和普通軟件沒有區別。裝好…