2021-05-12 14:32:11
docker掛載本地目錄和資料卷容器操作
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。
相關文章