首頁 > 軟體

docker掛載本地目錄和資料卷容器操作

2020-11-26 18:01:43

1、docker掛載本地目錄

docker可以支援把一個宿主機上的目錄掛載到映象裡。

互動模式執行

docker run -it -v /home/dock/Downloads:/usr/Downloads ubuntu64 /bin/bash

後臺執行

docker run -d -v /home/dock/Downloads:/usr/Downloads --name ubuntu1 ubuntu64

通過-v引數,冒號前為宿主機目錄,必須為絕對路徑,冒號後為映象內掛載的路徑。

現在映象內就可以共用宿主機裡的檔案了。

預設掛載的路徑許可權為讀寫。如果指定為唯讀可以用:ro

docker run -it -v /home/dock/Downloads:/usr/Downloads:ro ubuntu64 /bin/bash

2、docker資料卷容器

docker還提供了一種高階的用法。叫資料卷。

資料卷:「其實就是一個正常的容器,專門用來提供資料卷供其它容器掛載的」。感覺像是由一個容器定義的一個資料掛載資訊。其他的容器啟動可以直接掛載資料卷容器中定義的掛載資訊。

範例:

docker run -v /home/dock/Downloads:/usr/Downloads --name dataVol ubuntu64 /bin/bash

建立一個普通的容器。用--name給他指定了一個名(不指定的話會生成一個隨機的名子)。

再建立一個新的容器,來使用這個資料卷。

docker run -it --volumes-from dataVol ubuntu64 /bin/bash

--volumes-from用來指定要從哪個資料捲來掛載資料。

這樣在新建立的容器裡/usr/Downloads目錄會和宿主機目錄/home/dock/Downloads同步

補充知識:Linux系列之——docker通過掛載資料捲到 mysql實現容器設定在地化

拉取mysql映象

docker pull mysql

建立並執行mysql容器(掛載資料捲到 mysql)

docker run -p 3306:3306 --name mysql 
-v /usr/local/docker/mysql/conf:/etc/mysql 
-v /usr/local/docker/mysql/logs:/var/log/mysql 
-v /usr/local/docker/mysql/data:/var/lib/mysql 
-e MYSQL_ROOT_PASSWORD=123123 
-d mysql

進行上面的指令操作,結果mysql容器啟動不了,檢視報錯是讀取檔案/var/lib/mysql-file錯誤。

###############解決上面mysql啟動不了的問題################

暫時把本地設定目錄 /usr/local/docker/mysql/conf 和容器中的 app 資料夾關聯(不能直接關聯容器設定目錄,由於檔案同步原因,會導致容器設定目錄為空無法啟動容器),後續會把容器的組態檔複製到. /conf,以達到複製容器檔案的目的

docker run -d -p 3306:3306 -v /usr/local/docker/mysql/conf:/app --name tempMysql -e MYSQL_ROOT_PASSWORD=123123 mysql

進入mysql容器

docker exec -it tempMysql /bin/bash

把 etc/mysql 目錄下的所有檔案,複製到 app 目錄下,由於之前做了本地同步,所以能看到本地資料夾./conf 內有mysql組態檔

cp -r /etc/mysql/* /app

刪除容器

docker stop tempMysql

docker rm tempMysql

建立新容器, 是本地mysql資料夾和容器中的 mysql相關檔案做同步。

docker run -p 3306:3306 --name mysql 
-v /usr/local/docker/mysql/conf:/etc/mysql 
-v /usr/local/docker/mysql/logs:/var/log/mysql 
-v /usr/local/docker/mysql/data:/var/lib/mysql 
-e MYSQL_ROOT_PASSWORD=123123 
-d mysql

以上這篇docker掛載本地目錄和資料卷容器操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com