Docker匿名掛載和具名掛載的具體使用

數據卷volume

提到這個匿名掛在和具名掛載,其實要先普及一個知識,就是什麼是volumes,這個volumes就是數據卷的意思。我們docker掛載會用到這個卷。

數據卷的用處就是一個可供一個或者多個容器使用的特殊目錄,他繞過UFS就是什麼聯合文件系統,提供瞭很多功能:
(1)數據卷可以多個容器共享或者重用
(2)對數據卷修改會立馬生效
(3)對數據卷的更新不會影響鏡像
(4)數據卷默認會一直存在,即使容器被刪除瞭(結合2,3點特別像nacos)

查看數據卷的命令可以用:

docker volume --help

實際上命令內容也不多如下:

在這裡插入圖片描述

實際上創建volume不用之前去創建,你掛載的時候命名,找不到他就會去根據你給的名字的創建一個新的有名字而不是一串哈希碼的名字的數據卷volume。

匿名掛載和具名掛載

在前面的數據卷volume的知識補充下,實際上匿名掛在和具命掛載就能知道瞭,一個是沒給數據卷名字的掛載,一個是給瞭指定數據卷名字的掛載。

比如接著上次的掛載,我們是指定瞭指定路徑的掛載,其實我們可以更簡單掛載,連宿主機的指定路徑不給,直接-v掛載docker容器的路徑就可以。如下匿名掛載安裝nginx。

# 匿名掛載
-P 大寫的P, 映射隨機端口
-v 容器內路徑
docker run -d -P --name nginx01 -v /etc/nginx nginx

實際上會返回一個哈希碼,這個就是匿名掛載的數據卷的名字,你根據這個哈希碼也可以找到對應的數據卷,對你來說是匿名的,實際人傢還會給一個名字的。我們可以通過 volume ls命令來查看都有什麼數據卷。

docker volume ls

那這個具名掛載就要指定數據卷,類似我們之前的指定路徑掛載,但是這個我們不適用具體的指定路徑而是數據卷的名字。

# VOLUME NAME 當前顯示為匿名數據卷, 在 -v 掛載的時候隻寫瞭容器內的路徑,沒有寫宿主機的路徑
# 具名掛載
# 通過 -v 卷名:容器內路徑
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx

數據卷的位置

我們既然設置瞭具體的數據卷,且對容器進行瞭掛載,也知道數據卷的用處,那數據卷在哪裡呢?畢竟掛載的東西都在那裡,看一眼位置在哪省著被誤刪瞭。

實際他在docker的下面具體路徑是:

/var/lib/docker/volumes/xxxx/_data

我們可以cd到這個路徑下面看一下數據卷,像我就cd到第二個具名掛載nginx的數據卷目錄下面看一下具體結構

在這裡插入圖片描述

總結一下我們掛載的方式都有哪些:

如何確定是具名掛載還是匿名掛載, 亦或是指定路徑掛載?
-v 容器內路徑 # 匿名掛載
-v 數據卷名:/容器內路徑 # 具名掛載
-v /宿主機路徑:/容器內路徑 # 指定路徑掛載

# 通過 -v 容器內路徑: ro rw 改變讀寫權限
# ro readonly           隻讀
# rw readwrite        讀寫
# 如果設置瞭容器權限, 容器對掛載出來的數據就有權限限定瞭. 
docker run -d -P --name nginx04 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx04 -v juming-nginx:/etc/nginx:rw nginx
# ro    隻要看到ro就說明這個路徑隻能通過宿主機來操作, 容器內部是無法操作

到此這篇關於Docker匿名掛載和具名掛載的具體使用的文章就介紹到這瞭,更多相關Docker匿名掛載和具名掛載內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: