Python開發加薪利器之Docker的使用實踐
虛擬機技術:
資源占用 多冗余步驟多 啟動慢容器化技術:容器化技術不是模擬一個完整的操作系統。
1.2 名詞概念鏡像(image)
docker鏡像好比是一個模版,可以通過這個模版來創建容器服務,mysql鏡像==>run==>mysql01容器(提供服務),通過這個鏡像可以創建多個容器。
容器(container)
docker利用容器技術,獨立運行一個或者一組應用。通過鏡像來創建的。
基本命令有啟動、停止、刪除等。
目前可以把容器理解為就是一個簡易的Linux系統。
倉庫(repository)
倉庫就是存放鏡像的地方。倉庫分為公有倉庫和私有倉庫。默認是國外的倉庫(DockerHub),國內有阿里云等(配置鏡像加速)
2. Docker安裝2.1 環境查看2.1.1 查看內核版本
uname -r
2.1.2 查看系統信息
sudo cat /etc/os-release
sudo apt-get remove docker docker-engine docker.io containerd runc
2.3 安裝必要的包2.3.1 更新apt程序包索引
sudo apt-get update
2.3.2 安裝必要的包
sudo apt-get install apt-transport-https ca-certificates curl gnupg lsb-release2.4 添加GPG密鑰
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
上面是官網提供的,但是速度很慢,建議使用阿里云的GPG Key。
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
2.5 添加穩定Docker-ce軟件源
echo 'deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable' | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
上面是官網提供的,但是速度很慢,建議使用阿里云提供的。
sudo add-apt-repository 'deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable'
注意:添加錯了可以用以下命令刪除
#查詢keyid,下圖sudo apt-key list#keyid 就是9DC8那一串sudo apt-key del <keyid>#加參數-r可以移除sudo add-apt-repository -r 'deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable'
2.6.1 安裝apt包索引
這樣就可以安裝Docker Engine和containerd的最新版本
sudo apt-get update
2.6.2 安裝
sudo apt-get install docker-ce docker-ce-cli containerd.io
如果要安裝指定版本的Docker引擎,在repo中列出可用版本,然后選擇安裝
apt-cache madison docker-ce
sudo apt-get install docker-ce=<VERSION_STRING> docker-ce-cli=<VERSION_STRING> containerd.io2.7 添加當前用戶到 docker 用戶組
添加后,以后就可以不用 sudo 運行 docker 了。
將當前用戶添加到 docker 組
sudo gpasswd -a ${USER} docker
重新登錄或者用以下命令切換到docker組(建議重啟Ubuntu)
newgrp - docker
重啟docker服務
sudo service docker restart
不加sudo直接執行docker命令檢查效果
docker ps
2.8 測試是否安裝成功
首先啟動Docker
systemctl start docker
查看Docker版本來判斷是否安裝成功
docker version
sudo mkdir -p /etc/dockersudo tee /etc/docker/daemon.json <<-’EOF’{ 'registry-mirrors': ['https://eko3tl65.mirror.aliyuncs.com']}EOFsudo systemctl daemon-reloadsudo systemctl restart docker3. Docker run 運行流程圖
Docker是一個Client·Server結構的系統,Docker的守護進程運行在主機上,通過Socket從客戶端訪問,DockerServer接受到DockerClient的指令,就會去執行這個指令。
# 顯示docker的版本信息docker version# 顯示docker的系統信息 包括鏡像和容器的數量docker info# 幫助命令docker 命令 --help
幫助文檔地址:官方文檔
5.2 鏡像命令5.2.1 docker images
查看所有本地的主機上的鏡像
malulu@malulu:~/桌面$ docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEnginx latest 519e12e2a84a 4 days ago 133MBhello-world latest d1165f221234 5 weeks ago 13.3kB# 解釋REPOSITORY鏡像的倉庫源TAG鏡像的標簽IMAGE ID鏡像的IDCREATED鏡像的創建時間SIZE鏡像的大小# 可選項 -a, --all # 列出所有鏡像 -q, --quiet # 只顯示鏡像的ID
5.2.2 docker search
搜索鏡像
# 可選項--filter=STARS=3000# 搜索出來的鏡像就是STARS大于3000的
5.2.3 docker pull
下載鏡像
# 下載鏡像docker pull 鏡像名[:tag]malulu@malulu:~/桌面$ docker pull mysqlUsing default tag: latest# 如果不寫tag(版本) 默認就是latestlatest: Pulling from library/mysqlf7ec5a41d630: Already exists# 分層下載 docker image的核心 聯合文件系統 9444bb562699: Pull complete 6a4207b96940: Pull complete 181cefd361ce: Pull complete 8a2090759d8a: Pull complete 15f235e0d7ee: Pull complete d870539cd9db: Pull complete 5726073179b6: Pull complete eadfac8b2520: Pull complete f5936a8c3f2b: Pull complete cca8ee89e625: Pull complete 6c79df02586a: Pull complete Digest: sha256:6e0014cdd88092545557dee5e9eb7e1a3c84c9a14ad2418d5f2231e930967a38# 簽名Status: Downloaded newer image for mysql:latestdocker.io/library/mysql:latest# 真實地址# 下面兩條命令等價docker pull mysqldocker pull docker.io/library/mysql:latest# 指定版本下載 必須在倉庫有這個版本malulu@malulu:~/桌面$ docker pull mysql:5.75.7: Pulling from library/mysqlf7ec5a41d630: Already exists 9444bb562699: Already exists 6a4207b96940: Already exists 181cefd361ce: Already exists 8a2090759d8a: Already exists 15f235e0d7ee: Already exists d870539cd9db: Already exists 7310c448ab4f: Pull complete 4a72aac2e800: Pull complete b1ab932f17c4: Pull complete 1a985de740ee: Pull complete Digest: sha256:e42a18d0bd0aa746a734a49cbbcc079ccdf6681c474a238d38e79dc0884e0eccStatus: Downloaded newer image for mysql:5.7docker.io/library/mysql:5.7
5.2.4 docker rmi
刪除鏡像
# 刪除指定的鏡像docker rmi -f 鏡像ID# 刪除多個鏡像docker rmi -f 鏡像ID 鏡像ID 鏡像ID 鏡像ID # 刪除全部鏡像docker rmi -f $(docker images -aq)5.3 容器命令
說明:我們有了鏡像才可以創建容器。
這里下載一個centos鏡像來測試學習。
docker pull centos
5.3.1 新建容器并啟動
docker run [可選參數] image# 參數說明--name='Name'# 容器名字 mysql01 mysql02 用來區分容器-d# 后臺方式運行-it# 使用交互方式運行(需要提供一個控制臺) 進入容器查看內容-p# 指定容器的端口 -p 8080:8080-p ip:主機端口:容器端口-p 主機端口:容器端口 (常用)-p 容器端口容器端口-P# 隨機指定端口# 測試# 啟動并進入容器malulu@malulu:~/桌面$ docker run -it centos /bin/bash[root@a8d9ce9627a4 /]# ls# 查看容器內的centos 基礎鏡像 很多命令都是不完善的bin etc lib lost+found mnt proc run srv tmp vardev home lib64 media opt root sbin sys usr# 從容器中退回主機[root@a8d9ce9627a4 /]# exitexitmalulu@malulu:~/桌面$
5.3.2 列出所有的運行的容器
# 列出當前正在運行的容器docker ps# 可選項-a# 列出當前正在運行的容器 + 歷史運行過的容器-n=?# 顯示最近創建的n個容器-q# 只顯示容器的編號
5.3.3 退出容器
exit# 直接停止容器并退出ctrl+P+Q# 容器不停止退出
5.3.4 刪除容器
# 刪除指定的容器 不能刪除正在運行的容器 強制刪除用rm -fdocker rm 容器ID# 刪除所有的容器# 方式一 常用docker rm -f $(docker ps -aq)# 方式二docker ps -a -q|xargs docker rm
5.3.5 啟動和停止容器的操作
docker start 容器ID# 啟動容器docker restart 容器ID# 重啟容器docker stop 容器ID# 停止當前正在運行的容器docker kill 容器ID# 強制刪除當前容器5.4 常見其他命令
5.4.1 后臺啟動容器
# 后臺啟動容器docker run -d 鏡像名# 比如 后臺啟動centosdocker run -d centos# 問題 docker ps 時 發現 centos 停止了# 常見的坑:docker容器使用后臺運行,就必須要有一個前臺進程,docker發現沒有應用,就會自動停止# 比如nginx,容器啟動后,發現自己沒有提供服務,就會立刻停止,就是沒有程序了
5.4.2 查看日志
docker logs -f -t --tail number 容器ID# 可選項 -tf# 顯示日志 --tail number# 要顯示日志條數# 自己編寫一段shell腳本docker run -d centos /bin/sh -c 'while true;do echo 666;sleep 1;done'
5.4.3 查看容器中進程信息
docker top 容器ID
5.4.4 查看鏡像的元數據
docker inspect 容器ID
5.4.5 進入當前正在運行的容器
我們通常容器都是使用后臺方式運行的,有時需要進入容器,修改一些配置
# 方式一# 命令docker exec -it 容器ID bashShell# 測試malulu@malulu:~/桌面$ docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES9ff3b9c7ebd5 centos '/bin/sh -c ’while t…' 8 seconds ago Up 6 seconds lucid_wrightmalulu@malulu:~/桌面$ docker exec -it 9ff3b9c7ebd5 /bin/bash[root@9ff3b9c7ebd5 /]# lsbin etc lib lost+found mnt proc run srv tmp vardev home lib64 media opt root sbin sys usr[root@9ff3b9c7ebd5 /]# # 方式二docker attach 容器ID# 測試malulu@malulu:~/桌面$ docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES9ff3b9c7ebd5 centos '/bin/sh -c ’while t…' 8 minutes ago Up 8 minutes lucid_wrightmalulu@malulu:~/桌面$ docker attach 9ff3b9c7ebd5666666666666666666# docker exec# 進入容器后開啟一個新的終端 可以在里面操作(常用)# docker attach# 進入容器正在執行的終端 不會啟動新的終端
5.4.6 從容器內拷貝文件到主機
注意:是從容器內拷貝到主機。
docker cp 容器Id:容器內路徑 目的的主機路徑
只要容器存在就可以,跟容器是否運行沒有關系。
拷貝是一個手動過程,后面我們使用 -V 數據卷的技術,可以實現自動同步。
5.4.5 小結
attach Attach local standard input, output, and error streams to a running containerbuild Build an image from a Dockerfilecommit Create a new image from a container’s changescp Copy files/folders between a container and the local filesystemcreate Create a new containerdiffInspect changes to files or directories on a container’s filesystemevents Get real time events from the serverexecRun a command in a running containerexport Export a container’s filesystem as a tar archivehistory Show the history of an imageimages List imagesimport Import the contents from a tarball to create a filesystem imageinfoDisplay system-wide informationinspect Return low-level information on Docker objectskillKill one or more running containersloadLoad an image from a tar archive or STDINlogin Log in to a Docker registrylogout Log out from a Docker registrylogsFetch the logs of a containerpause Pause all processes within one or more containersportList port mappings or a specific mapping for the containerps List containerspullPull an image or a repository from a registrypushPush an image or a repository to a registryrename Rename a containerrestart Restart one or more containersrm Remove one or more containersrmi Remove one or more imagesrun Run a command in a new containersaveSave one or more images to a tar archive (streamed to STDOUT by default)search Search the Docker Hub for imagesstart Start one or more stopped containersstats Display a live stream of container(s) resource usage statisticsstopStop one or more running containerstag Create a tag TARGET_IMAGE that refers to SOURCE_IMAGEtop Display the running processes of a containerunpause Unpause all processes within one or more containersupdate Update configuration of one or more containersversion Show the Docker version informationwaitBlock until one or more containers stop, then print their exit codes6. 實戰6.1 部署Nginx
第一步:搜索鏡像,建議去DockerHub搜索,可以看到幫助文檔
https://registry.hub.docker.com/search?q=nginx&type=image
第二步:拉取鏡像
malulu@malulu:~/桌面$ docker pull nginxUsing default tag: latestlatest: Pulling from library/nginxf7ec5a41d630: Already exists aa1efa14b3bf: Pull complete b78b95af9b17: Pull complete c7d6bca2b8dc: Pull complete cf16cd8e71e0: Pull complete 0241c68333ef: Pull complete Digest: sha256:75a55d33ecc73c2a242450a9f1cc858499d468f077ea942867e662c247b5e412Status: Downloaded newer image for nginx:latestdocker.io/library/nginx:latestmalulu@malulu:~/桌面$
第三步:運行測試
# -d 后臺運行# --name 給容器命名# -p 宿主機端口:容器內部端口malulu@malulu:~/桌面$ docker run -d --name nginx01 -p 3344:80 nginx699b9cecd0a07f8db6e888722a2dada1c9b9be6d77efc7996c4b6758dd72f587malulu@malulu:~/桌面$ docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES699b9cecd0a0 nginx '/docker-entrypoint.…' About a minute ago Up About a minute 0.0.0.0:3344->80/tcp nginx01malulu@malulu:~/桌面$ curl localhost:3344# 進入容器malulu@malulu:~/桌面$ docker exec -it nginx01 /bin/bashroot@699b9cecd0a0:/# whereis nginxnginx: /usr/sbin/nginx /usr/lib/nginx /etc/nginx /usr/share/nginxroot@699b9cecd0a0:/# cd /etc/nginx/root@699b9cecd0a0:/etc/nginx# lsconf.dfastcgi_paramskoi-utf koi-win mime.types modules nginx.conf scgi_paramsuwsgi_params win-utfroot@699b9cecd0a0:/etc/nginx# exit
第四步:公網訪問
# es 暴露的端口很多# es 十分的耗內存# es 數據一般需要放置到安全目錄 掛載docker run -d --name elasticsearch --net somenetwork -p 9200:9200 -p 9300:9300 -e 'discovery.type=single-node' elasticsearch:tag
# --net somenetwork 網絡配置# 啟動 Elasticsearchdocker run -d --name elasticsearch01 -p 9200:9200 -p 9300:9300 -e 'discovery.type=single-node' elasticsearch:7.12.0# 啟動之后,服務器會特別卡# 所以需要增加內存的限制# 修改配置文件 -e 環境配置修改docker run -d --name elasticsearch02 -p 9200:9200 -p 9300:9300 -e 'discovery.type=single-node' -e ES_JAVA_OPTS='-Xms64m -Xmx512m' elasticsearch:7.12.0
# 查看CPU使用情況docker stats 容器ID
# 測試es是否安裝成功curl localhost:9200
Docker圖形化界面管理工具,提供一個后臺面板供我們操作。
訪問測試:
http://192.168.2.143:8088http://localhost:8088
為用戶 admin 設置密碼 admin123456
登錄成功后,選擇本地Docker環境
進入之后的面板
可視化面板我們平時不會使用,用來測試玩玩。
7. Docker鏡像講解7.1 鏡像是什么鏡像是一種輕量級、可執行的獨立軟件包,用來打包軟件運行環境和基于運行環境開發的軟件,它包含運行某個軟件所需的所有內容,包括代碼、運行所需庫、環境變量和配置文件。所有的應用,直接打包docker鏡像,就可以直接跑起來。
如何獲取到鏡像:
從遠程倉庫下載 朋友拷貝給你 自己制作一個鏡像DockerFile7.2 Docker鏡像加載原理UnionFS(聯合文件系統)
我們下載的時候看到的一層層就是這個!Union文件系統(UnionFS)是一種分層、輕量級并且高性能的文件系統,它支持對文件系統的修改作為一次提交來一層層的疊加,同時可以將不同目錄掛載到同一個虛擬文件系統下(unite several directories into a single virtual filesystem)。Union文件系統是Docker鏡像的基礎。鏡像可以通過分層來進行繼承,基于基礎鏡像(沒有父鏡像),可以制作各種具體的應用鏡像。
特性:一次同時加載多個文件系統,但從外面看起來,只能看到一個文件系統,聯合加載會把各層文件系統疊加起來,這樣最終的文件系統會包含所有底層的文件和目錄。
Docker鏡像加載原理
Docker的鏡像實際上由一層層的文件系統組成,這種層級的文件系統叫做UnionFS。
系統啟動需要引導加載。
bootfs(boot file system)主要包含bootloader(加載器)和kernel(內核),bootloader主要是引導加載kernel,Linux剛啟動時會加載bootfs文件系統,在Docker鏡像的最底層是bootfs。這一層與我們典型的Linux/Unix系統是一樣的,包含boot加載器和內核。當boot加載完成之后整個內核就都在內存中了,此時內存的使用權已由bootfs轉交給內核,此時系統也會卸載bootfs。
rootfs(root file system),在bootfs之上,包含的就是典型Linux系統中的 /dev,/proc,/bin,/etc 等標準目錄和文件。rootfs就是各種不同的操作系統發行版,比如Ubuntu, Centos等等。容器就是一個小的虛擬機環境。
平時我們在虛擬機中安裝CentOs都是好幾個G,為什么在Docker里面才200多M?
對于一個精簡的OS,rootfs可以很小,只需要包含最基本的命令,工具和程序庫就可以了,因為底層直接用Host的kernel,自己只需要提供rootfs就可以了。由此可見對于不同的linux發行版,bootfs基本是一致的,rootfs會有差別,因此不同的發行版可以公用bootfs。
所以說,虛擬機是分鐘級別,容器是秒級別。是因為啟動虛擬機需要啟動內核引導,非常慢,而容器底層還是使用主機的內核。
7.3 分層理解分層的鏡像
我們可以去下載一個鏡像,注意觀察下載的日志輸出,可以看到的是一層一層的在下載。
**思考:**為什么Docker鏡像要采用這種分層的結構呢?最大的好處,我覺得莫過于是資源共享了。比如有多個鏡像都從相同的Base鏡像構建而來,那么宿主機只需在磁盤上保留一份Base鏡像,同時內存中也只需要加載一份Base鏡像,這樣就可以為所有的容器服務了,而且鏡像的每一層都可以被共享。查看鏡像分層的方式可以通過 docker image inspect 命令。
docker image inspect redis:latest
理解:
所有的Docker鏡像都起始于一個基礎鏡像層,當進行修改或增加新的內容時,就會在當前鏡像層之上,創建新的鏡像層。舉一個簡單的例子,假如基于Ubuntu Linux 16.04創建一個新的鏡像,這就是新鏡像的第一層;如果在該鏡像中添加Python包,就會在基礎鏡像層之上創建第二個鏡像層;如果繼續添加一個安全補丁,就會創建第三個鏡像層。該鏡像當前已經包含3個鏡像層,如下圖所示(這只是一個用于演示的很簡單的例子)
在添加額外的鏡像層的同時,鏡像始終保持是當前所有鏡像的組合,理解這一點非常重要。下圖中舉了一個簡單的例子,每個鏡像層包含3個文件,而鏡像包含了來自兩個鏡像層的6個文件。
上圖中的鏡像層跟之前圖中的略有區別,主要目的是便于展示文件。下圖中展示了一個稍微復雜的三層鏡像,在外部看來整個鏡像只有6個文件,這是因為最上層中的文件7是文件5的一個更新版本。
這種情況下,上層鏡像層中的文件覆蓋了底層鏡像層中的文件。這樣就使得文件的更新版本作為一個新鏡像層添加到鏡像當中。Docker通過存儲引擎(新版本采用快照機制)的方式來實現鏡像層堆棧,并保證多鏡像層對外展示為統一的文件系統。Linux上可用的存儲引擎有AUFS、Overlay2、Device Mapper、Btrfs 以及ZFS。顧名思義,每種存儲引擎都基于Linux中對應的文件系統或者塊設備技術,并且每種存儲引擎都有其獨有的性能特點。Docker在Windows上僅支持windowsfilter一種存儲引擎。下圖展示了與系統顯示相同的三層鏡像。所有鏡像層堆疊并合并,對外提供統一的視圖。
特點
Docker鏡像都是只讀的,當容器啟動時,一個新的可寫層被加載到鏡像的頂部。這一層就是我們通常說的容器層,容器之下的都叫鏡像層。
如何提交一個自己的鏡像呢?
docker commit 提交容器成為一個新的鏡像docker commit -m='提交的描述信息' -a='作者' 容器Id 目標鏡像名:[TAG]
實戰測試:
# 1.啟動一個默認的tomcat# 2.發現這個默認的tomcat是沒有webapps應用,是因為官方鏡像默認webapps下面是沒有文件的# 3.自己拷貝進去了基本的文件
# 4.將我們操作過的容器通過commit提交為一個鏡像。我們以后就使用我們修改過的鏡像即可。
如果你想要保存當前容器的狀態 ,就可以通過commit來提交,獲得一個鏡像。就好比虛擬機的快照。
8. 容器數據卷8.1 容器數據卷是什么將應用和環境打包成一個鏡像!
數據?如果數據都在容器中,那么我們容器刪除,數據就會丟失!需求:數據可以持久化
MySQL,容器刪了,相當于刪庫跑路!需求:MySQL數據可以存儲到本地
容器之間可以有一個數據共享的技術!Docker容器中產生的數據,同步到本地!
這就是卷技術!相當于目錄的掛載,將我們容器內的目錄,掛載到Linux上面!
**總結:**為什么使用容器卷?為了容器的持久化和同步操作,容器間也是可以數據共享的(即多個容器使用同一個本地目錄)
8.2 使用數據卷方式一:直接使用命令來掛載 -v
docker run -v 主機內目錄:容器內目錄
通過命令 docker inspect 來查看掛載信息,如下:
'Mounts': [ {'Type': 'bind','Source': '/home/ceshi',# 主機內地址'Destination': '/home',# docker容器內地址'Mode': '','RW': true,'Propagation': 'rprivate' }],
測試文件的同步:
思考:MySQL的數據持久化問題。
# 獲取鏡像docker pull mysql:5.7# 運行容器 需要做數據掛載# 注意: 安裝啟動mysql時 需要配置密碼的# 官方測試(DockerHub) docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag# 啟動docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=Malulu@960610 --name mysql01 mysql:5.7# 啟動成功后 在使用Navicat來測試# Navicat連接到Ubuntu的3310 3310和容器內的3306映射 此時我們就可以連接上了
假設我們將容器刪除,我們掛載到本地的數據卷依舊沒有丟失,這就實現了容器數據持久化的功能。
8.4 匿名掛載和具名掛載8.4.1 匿名掛載
# 查看所有卷的信息docker volume ls# 匿名掛載-v 容器內目錄docker run -d -P --name nginx -v /etc/nginx nginx# 這樣就屬于匿名掛載 在 -v 后只寫了容器內目錄 沒有寫主機的目錄
8.4.2 具名掛載
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
通過 -v 卷名:容器內目錄 的格式屬于具名掛載。
使用命令 docker volume inspect 卷名 來查看這個這個卷的信息。
所有的Docker容器內的卷,在沒有指定目錄的情況下都是在主機的 /var/lib/docker/volumes/xxx/_data 目錄下。
我們通過具名掛載可以方便的找到我們的一個卷,大多數情況下使用具名掛載。
如何確定是具名掛載還是匿名掛載還是指定路徑掛載?
-v 容器內路徑 # 匿名掛載-v 卷名:容器內路徑# 具名掛載-v /宿主機路徑:容器內路徑 # 指定路徑掛載
擴展:
# 通過 -v 容器內路徑:ro rw 改變讀寫權限ro readonly # 只讀rw readwrite# 可讀可寫# 一旦設置了這個權限 容器對我們掛載出來的內容就有限定了docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginxdocker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx# ro 只要看到ro就說明這個路徑只能通過宿主機來操作 容器內部是無法操作的
8.5 初識DockerFile
DockerFile就是用來構建Docker鏡像的構建文件,這個文件其實就是一個命令腳本。
通過這個腳本可以生成鏡像,鏡像是一層一層的,腳本是一個一個的命令,每個命令都是一層。
# 創建一個dockerfile文件 名字可以隨機 建議Dockerfile# 文件中的內容 # 指令(大寫) 參數FROM centosVOLUME ['volume01','volume02']CMD echo '-----end-----'CMD /bin/bash# 這里的每個命令鏡像的一層
通過 docker build 來創建自己的命令。
docker build -f ./dockerfile1 -t malulu-centos:1.0 .
啟動自己創建的鏡像
這兩個卷在外部一定有同步的目錄。
查看一下卷掛載的路徑。
然后測試一下剛才創建的兩個文件是否同步到宿主機。
這種方式我們以后用的非常多,因為我們通常會構建自己的鏡像。假設構建鏡像時沒有掛載卷,就需要手動掛載(具名掛載)。
未完待續,值得期待!
相關文章:
