2016-06-19

Docker Container 外掛磁碟儲存資料

阿舍覺得,很廣義的來說,Docker Container 就像個 Runtime 的程式,東西都放在記憶體,程式關掉後,就什麼都沒留下來了 ... 意思是說,Docker Container 的裡面所存的東西,在 Docker Container 被停止 ( docker stop) 並用 docker rm 指令移除後,放在 Container 裡的資料也會跟著徹底的被移除哩 !



有關 Docker Container 的這般深奧的道理,阿舍也是在犧牲數次的資料隨著 Docker Container 的消失而消失的經驗而換來的瞭解哩 ! 不過,也因為有這樣令阿舍印象深刻的經驗後,阿舍每次在用新的 Docker Image 的時候,都會先注意一下,這個 Docker Image 的資料要掛在那裡才不會跟著 Docker Container 被移除而一起消失哩 ...

其實,外掛 Docker Container 的概念,就是用一個實體的磁碟路徑或檔案來取代 Docker Container 裡的磁碟路徑或檔案,舉例來說,MySQL 官方的 Docker Image 會把 MySQL 的資料庫存在 Docker Container 的 /var/lib/mysql 資料夾之下,所以,當阿舍想要把這個 MySQL Container 所產生的資料庫檔案放在阿舍的電腦 (Host) 上的 /home/ayu/mysql (阿舍在家目錄下建立一個名為「mysql」的資料夾時)資料夾時,那麼阿舍就可以利用 docker 的 -v 選項來要求 docker 把阿舍的 /home/ayu/mysql 資料夾當做 Container 裡的 /var/lib/mysql 資料夾來用哩 ..

以阿舍上面舉的例子來說,阿舍所要執行的 MySQL Container 的啟動指令就會是像下面這一行這樣,要注意的是,-v 選項的後面是先放「實體的完整路徑」,接著,在冒號的後面才是放 Container 內部的路徑哩 !

$ sudo docker --name ayu-mysql -v /home/ayu/mysql:/var/lib/mysql -d mysql

上面的指令執行後,阿舍之後在這個 MySQL Container 所建立的 MySQL 資料庫的檔案,就會出現在 /home/ayu/mysql 資料夾裡了,如果想要做個簡單的測試來驗證的話,可以執行下面的第一行指令來下載 MySQL 的 Docker Imgae,然後,再用第二行指令讓 docker 在啟動 MySQL Container 後,立即建立一個名為「ayu」的資料庫,這樣,阿舍在到 /home/ayu/mysql 資料夾來看時,就會出現一堆檔案,其中,會有一個資料夾叫做「ayu」,那個,就是阿舍建的 MySQL 資料庫的檔案哩 ...

$ sudo docker pull mysql

$ docker run --name ayu-mysql -e MYSQL_ROOT_PASSWORD='123456789' -e MYSQL_DATABASE='ayu' -v /home/ayu/mysql:/var/lib/mysql -d mysql

所以,當阿舍把這個已經有建立資料庫的 MySQL Container 停掉 (docker stop)並移除(docker rm),然後,在下次阿舍啟用新的 MySQL Container 時(如下面的指令),只要把 /var/lib/mysql 同樣指到相同的 /home/ayu/mysql 資料夾,那麼,這個新的 MySQL Container 在一啟動後,就會有一個已建立的「ayu」資料庫可用了,而且,這個資料庫的使用者帳號和密碼都還是存在的,因此,透過 -v 選項來外掛磁碟,把檔案放在 Container 之外的磁碟空間上,就可以不用擔心檔案和資料會隨著消失囉 ...

$ docker run --name ayu-mysql -v /home/ayu/mysql:/var/lib/mysql -d mysql

另外,Docker 的 -v 選項除了可以用來指定 Docker Container 對應的實體資料夾之外,也可以用來對應檔案,一般來說,就是用來把設定給拉出來的,例如,下面這一行指令是用來啟動一個 Couchdb 的 Container 的,阿舍除了用第一個 -v 選項來把 Couchdb 的資料庫檔案指到實體的 /home/ayu/couchdb 資料夾外,還用第二個 -v 選項來把 Couchdb 的設定檔也指到實體的 /home/ayu/couchdb/local.ini 檔案上,這樣,不用進入 Container 就可以改設定檔,在改好後,直接重啟這個 Container 就可以讓設定生效,不用每次都要把設定檔放進 Container 或手動去調整哩 ...

$ docker run --name couchdb -p 5984:5984 -v /home/ayu/couchdb:/usr/local/var/lib/couchdb -v /home/ayu/couchdb/local.ini:/usr/local/etc/couchdb/local.ini -d couchdb

最後,阿舍要提醒一下,在 Docker 指令的選項上,通常是一個選項跟著一項設定,不能一次帶很多個來用,以上面這一行指令為例,有外掛二組磁碟就要分別用二個 -v 選項來指定,而不用只用一個 -v 選項來設定二組外掛的磁碟哩 ...

還有,就是,在實務的操作上,可以評估讓多個 Container 來共同「讀取」同一個檔案(像是設定檔之類的檔案內容) 以簡化管理,但是,可能不太適合讓多個 Container 來共同來「讀、寫」同一個檔案 (例如,資料庫類型的檔案),否則,大概就有機會會遇到一些不可預期的神奇情形哩 ...

推薦閱讀


有疑問? 問題還是沒解決嗎? 歡迎下方留言提問和討論 😁

沒有留言 :

張貼留言

歡迎留言提問和討論 .... 😁