在容器里增加、洗掉或修改檔案,其實都是對可寫層里的檔案副本進行了操作,在容器關閉后,該可寫層也會被洗掉,對容器的所有修改都會失效,因此需要解決容器內檔案持久化的問題,Docker提供了兩種方案來實作:
一、Docker掛載時創建卷:把宿主機檔案系統里的目錄映射到容器內的目錄,如此一來,容器內在該目錄里創建的所有檔案,都存盤到宿主機的對應目錄中,在關閉容器后,宿主機的目錄依然存在,再次啟動容器時還能讀取到之前創建的檔案,因此實作了容器的檔案持久化,當然同時要明白,如果是對鏡像自帶檔案進行了修改,由于鏡像是只讀的,該修改操作無法在關閉容器時保存下來,除非在修改了檔案后構建一個新的鏡像,
1、Docker 掛載卷
從nginx鏡像中拉取一個名為nginx-test01的容器,指定映射到宿主機80埠,將宿主機的/data掛載到容器/usr/share/nginx/html下,從而使宿主機的/data成為掛載卷
[root@docker ~]# docker run -d -p 80:80 -v /data:/usr/share/nginx/html --name nginx-test01 nginx 4fdbb1bdfcb36348643f0c2e64a72e9750ee0b2e1b6dbae3d41fcec179209ce6
訪問測驗:
[root@docker ~]# curl 192.168.22.135:80 <html> <head><title>403 Forbidden</title></head> <body> <center><h1>403 Forbidden</h1></center> <hr><center>nginx/1.17.5</center> </body> </html>
由于/data中并沒有主頁資源,所以訪問結果顯示403(在下一步中寫入)
2、宿主機寫入資料再次訪問驗證:
[root@docker ~]# cd /data [root@docker data]# ls [root@docker data]# echo 123asd > index.html [root@docker data]# curl 192.168.22.135:80 123asd
3、設定共享卷
使用同一個卷啟動一個新容器并訪問測驗:
從nginx鏡像中拉取一個名為nginx-test02的容器,指定映射到宿主機8080埠,仍將宿主機的/data掛載到容器/usr/share/nginx/html下,由于/data已作為了容器nginx-test01的掛在卷,在這里又成為了nginx-test02掛載卷,因此宿主機/data成為共享卷,
[root@docker ~]# docker run -d -p 8080:80 -v /data:/usr/share/nginx/html --name nginx-test02 nginx 0c609176a6f77df1d467d679f18221de900943ddbc9aba9c589c00b6ed9e6405 [root@docker ~]# curl 192.168.22.135:8080 123asd
二、Docker創建卷后掛載:把多臺宿主機的磁盤目錄通過網路聯合為共享存盤,然后把共享存盤中的特定目錄映射給特定的容器,這樣容器在重啟時,還是能讀取到關閉前創建的檔案,生產環境中常用NFS作為共享存盤方案,
1、創建一個名為nginx-j01的簡單卷并查看卷串列
[root@docker ~]# docker volume create --name nginx-j01 nginx-j01 [root@docker ~]# docker volume ls DRIVER VOLUME NAME local nginx-j01
2、查看卷路徑
[root@docker ~]# docker volume inspect nginx-j01
[
{
"CreatedAt": "2020-07-29T17:50:21+08:00",
"Driver": "local",
"Labels": {},
"Mountpoint": "/var/lib/docker/volumes/nginx-j01/_data",
"Name": "nginx-j01",
"Options": {},
"Scope": "local"
}
]
可查看出卷所在路徑為/var/lib/docker/volumes/nginx-j01/_data
3、創建docker共享卷掛載
從鏡像nginx中拉取一個名為nginx-test03的容器,映射宿主機埠9000,將之前創建的共享卷nginx-j01掛載到名為nginx-test03的容器中;將資料寫入主頁檔案,并做訪問測驗,
[root@docker ~]# docker run -d -p 9000:80 -v nginx-j01:/usr/share/nginx/html --name nginx-test03 nginx c40c65a2060d34319ac33a2263fb11cffdf50075b8efd4209cbd97ee163fb2e7 [root@docker ~]# echo 888 > /var/lib/docker/volumes/nginx-j01/_data/index.html [root@docker ~]# curl 192.168.22.135:9000 888
4、實作docker共享卷掛載
從鏡像nginx中拉取一個名為nginx-test04的容器,自動映射一個宿主機埠,將之前創建的共享卷掛載到該容器中,因為該共享卷之前掛載到了nginx-test03又掛載到了nginx-test04中,所以正在成為了共享卷,
[root@docker ~]# docker run -d -P --volumes-from nginx-test03 --name nginx-test04 nginx 862e2f3867cb33a91dcc3b3809bde7a0de951a11fea8fea77163db7c39a227b2
--volumes-from # 指定共享卷所在的容器
5、查看使用的埠并做訪問測驗
[root@docker ~]# netstat -lntup Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 1104/master tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1015/sshd tcp6 0 0 ::1:25 :::* LISTEN 1104/master tcp6 0 0 :::32768 :::* LISTEN 88573/docker-proxy tcp6 0 0 :::9000 :::* LISTEN 55370/docker-proxy tcp6 0 0 :::8080 :::* LISTEN 53960/docker-proxy tcp6 0 0 :::80 :::* LISTEN 52152/docker-proxy tcp6 0 0 :::22 :::* LISTEN 1015/sshd [root@docker ~]# curl 192.168.22.135:32768 888
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/17176.html
標籤:Linux
