一键安装畅享快乐,国产乱子乱人伦电影在线观看,CHINESE熟妇与小伙子MATURE,国产做a爰片久久毛片a片

您的位置:要聞 > 正文

零基礎(chǔ)學(xué)習(xí)docker

來(lái)源: 時(shí)間:2023-08-08 20:22:23

Docker教程

視頻學(xué)習(xí)地址:


【資料圖】

什么是Docker

Docker是一種開源的容器化平臺(tái),用于幫助開發(fā)者更輕松地打包、分發(fā)和運(yùn)行應(yīng)用程序。它通過(guò)使用操作系統(tǒng)級(jí)虛擬化技術(shù),將應(yīng)用程序及其所有依賴項(xiàng)打包到稱為"容器"的獨(dú)立運(yùn)行環(huán)境中。這些容器可以在不同的系統(tǒng)上運(yùn)行,而無(wú)需擔(dān)心環(huán)境差異和依賴沖突。

Docker的核心概念是鏡像(Image)和容器(Container):

鏡像是一個(gè)只讀的文件,包含了運(yùn)行應(yīng)用程序所需的所有文件系統(tǒng)、庫(kù)和依賴項(xiàng)。它可以被認(rèn)為是一個(gè)應(yīng)用程序的模板。

容器是鏡像的運(yùn)行實(shí)例,可以被啟動(dòng)、停止、刪除等。每個(gè)容器都是相互隔離的、獨(dú)立運(yùn)行的環(huán)境,具有自己的文件系統(tǒng)、進(jìn)程空間、網(wǎng)絡(luò)配置等。

使用Docker可以帶來(lái)許多優(yōu)勢(shì):

簡(jiǎn)化部署:Docker允許開發(fā)人員將應(yīng)用程序和其依賴項(xiàng)打包到一個(gè)獨(dú)立的、可移植的容器中,使得部署變得非常簡(jiǎn)單和一致。

跨平臺(tái):Docker容器可以在不同的操作系統(tǒng)和硬件平臺(tái)上運(yùn)行,無(wú)需擔(dān)心環(huán)境差異和依賴問(wèn)題。

高效資源利用:Docker使用操作系統(tǒng)級(jí)虛擬化技術(shù),可以在主機(jī)上同時(shí)運(yùn)行多個(gè)容器,以更高效地利用硬件資源。

快速開發(fā)和測(cè)試:容器的輕量級(jí)和快速啟動(dòng)能力使得開發(fā)人員可以快速創(chuàng)建、修改和測(cè)試應(yīng)用程序。

總的來(lái)說(shuō),Docker是一個(gè)強(qiáng)大的工具,可以幫助開發(fā)者簡(jiǎn)化應(yīng)用程序的交付和運(yùn)行,提高開發(fā)效率和系統(tǒng)的可移植性。

配置環(huán)境

版本

鏡像源(加速下載)

北京大學(xué)鏡像源

/Mirrors

方式一:通過(guò)命令替換

sudo wget /repoconfig/ -O /etc/apt/

方式二:修改鏡像源頭位置。

gedit /etc/apt/

粘貼下面內(nèi)容并保存。

deb /ubuntu hirsute main restricted universe multiverse# deb-src /ubuntu hirsute main restricted universe multiversedeb /ubuntu hirsute-updates main restricted universe multiverse# deb-src /ubuntu hirsute-updates main restricted universe multiversedeb /ubuntu hirsute-backports main restricted universe multiverse# deb-src /ubuntu hirsute-backports main restricted universe multiversedeb /ubuntu hirsute-security main restricted universe multiverse# deb-src /ubuntu hirsute-security main restricted universe multiverse## Uncomment the following two lines to add software from Canonical's## 'partner' repository.## This software is not part of Ubuntu, but is offered by Canonical and the## respective vendors as a service to Ubuntu users.# deb /ubuntu hirsute partner# deb-src /ubuntu hirsute partner

更新軟件包列表

sudo apt update

升級(jí)軟件包到最新版

sudo apt upgrade

安裝

刪除已經(jīng)安裝的docker

sudo apt-get remove docker docker-engine containerd runc

安裝依賴

sudo apt-get install apt-transport-https ca-certificates curl gnupg2 software-properties-common

添加Docker官方GPG密鑰

curl -fsSL /docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/

添加軟件倉(cāng)庫(kù)

echo \ ?"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/] /docker-ce/linux/ubuntu \ ?$(lsb_release -cs) stable" | sudo tee /etc/apt/ > /dev/null

更新安裝包

sudo apt-get update

安裝docker社區(qū)版本(免費(fèi))

sudo apt-get update

檢查安裝狀態(tài)

sudo systemctl status docker

返回結(jié)果

● - Docker Application Container Engine ? ? Loaded: loaded (/lib/systemd/system/; enabled; vendor preset: enabled) ? ? Active: active (running) since Mon 2021-09-20 10:18:47 UTC; 2 weeks 0 days agoTriggeredBy: ● ? ? ? Docs: ? Main PID: 891 (dockerd) ? ? ?Tasks: 8 ? ? Memory: ? ? CGroup: / ? ? ? ? ? ? └─891 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/ 20 10:18:47 ubuntu systemd[1]: Started Docker Application Container Engine.

Loaded:顯示 Docker 服務(wù)的配置文件位置。

Active:顯示 Docker 服務(wù)是否正在運(yùn)行。

Main PID:顯示 Docker 守護(hù)進(jìn)程(dockerd)的進(jìn)程 ID。

Memory:顯示 Docker 服務(wù)當(dāng)前的內(nèi)存使用情況。

CGroup:顯示 Docker 服務(wù)運(yùn)行在的控制組(CGroup)。

在示例輸出中,Active字段的值為 active (running),表示 Docker 服務(wù)正在運(yùn)行。如果狀態(tài)為 inactive,表示 Docker 服務(wù)未運(yùn)行。

驗(yàn)證docker安裝

docker run hello-world

鏡像

鏡像加速

網(wǎng)易docker加速器

創(chuàng)建docker配置文件

sudo gedit /etc/default/docker

修改docker配置文件

DOCKER_OPTS="--registry-mirror="

重啟服務(wù)

systemctl daemon-reloadsystemctl restart docker

方法2

$ sudo echo "DOCKER_OPTS=\"--registry-mirror=\"" >> /etc/default/docker$ service docker restart

方法3

gedit /etc/docker/{"registry-mirrors":[""]}

鏡像列表

docker images

返回結(jié)果

REPOSITORY:鏡像的倉(cāng)庫(kù)名稱。這通常是Docker鏡像的名稱,如ubuntu、nginx等。

TAG:鏡像的標(biāo)簽。標(biāo)簽是用于區(qū)分不同版本或變體的附加標(biāo)識(shí)符。例如,latest等。

IMAGE ID:鏡像的唯一標(biāo)識(shí)符。每個(gè)鏡像都有一個(gè)唯一的ID,它由Docker生成。

CREATED:鏡像創(chuàng)建的時(shí)間。它顯示了鏡像的創(chuàng)建日期和時(shí)間。

SIZE:鏡像的大小。以字節(jié)、千字節(jié)(KB)、兆字節(jié)(MB)等形式表示。

下載

docker pull [鏡像名]

刪除

docker rmi [鏡像名]

容器

獲取

下載官方案例

docker pull hello-world

下載Ubuntu鏡像

docker pull ubuntu

啟動(dòng)

啟動(dòng)Ubuntu容器

docker run -it ubuntu /bin/bash

docker run是 Docker 命令,用于在容器中運(yùn)行一個(gè)新的進(jìn)程。

-it參數(shù)使得容器中的標(biāo)準(zhǔn)輸入(stdin)保持打開狀態(tài),并分配一個(gè)偽終端(tty)。這樣,我們就可以與容器進(jìn)行交互了。

ubuntu是要運(yùn)行的容器鏡像的名稱。在這種情況下,我們選擇了 Ubuntu 操作系統(tǒng)的官方鏡像。

/bin/bash是要在容器中運(yùn)行的命令,即進(jìn)入容器的 bash 終端。

這個(gè)命令的作用是在一個(gè)新的容器中啟動(dòng) Ubuntu 操作系統(tǒng),并打開一個(gè)交互式 bash 終端,以便您可以在容器中執(zhí)行各種操作和命令。

偽終端(tty)是一個(gè)模擬終端設(shè)備的軟件實(shí)現(xiàn)。它允許用戶與計(jì)算機(jī)進(jìn)行交互,就像在物理終端上一樣。當(dāng)在容器中使用-it參數(shù)時(shí),Docker會(huì)為容器提供一個(gè)偽終端,使得我們可以通過(guò)標(biāo)準(zhǔn)輸入(stdin)與容器進(jìn)行交互。

偽終端在容器中的作用類似于用戶與計(jì)算機(jī)交互的終端或命令行界面。它允許我們?cè)谌萜髦休斎朊睢⑦\(yùn)行程序,并在終端中查看程序的輸出。通過(guò)交互式終端,我們可以像在實(shí)際操作系統(tǒng)中一樣,與容器中運(yùn)行的程序進(jìn)行交互。

停止

列出所有的容器,包括正在運(yùn)行的和已經(jīng)停止的容器。

docker ps -a

docker是 Docker 命令的前綴。

ps是 Docker 命令,用于列出容器的信息。

-a參數(shù)用于顯示所有的容器,包括正在運(yùn)行的和已經(jīng)停止的容器。

該命令的作用是顯示所有的容器的信息,包括容器的 ID、狀態(tài)、創(chuàng)建時(shí)間、鏡像名稱、對(duì)外映射的端口等。通過(guò)執(zhí)行 docker ps -a命令,您可以查看系統(tǒng)中所有容器的狀態(tài),包括已經(jīng)停止的容器,以便進(jìn)行管理或進(jìn)一步操作。

停止一個(gè)容器

docker stop [容器 ID]

docker是 Docker 命令的前綴。

stop是 Docker 命令,用于停止容器的運(yùn)行。

[容器 ID]是要停止的容器的唯一標(biāo)識(shí)符。

該命令的作用是停止正在運(yùn)行的容器。當(dāng)執(zhí)行 docker stop [容器 ID]命令后,Docker 會(huì)向指定的容器發(fā)送停止信號(hào)(SIGTERM),容器會(huì)收到該信號(hào)并進(jìn)行相應(yīng)的處理。如果容器沒有在一定時(shí)間內(nèi)響應(yīng)停止信號(hào),Docker 會(huì)發(fā)送強(qiáng)制停止信號(hào)(SIGKILL)。停止容器后,容器中運(yùn)行的進(jìn)程會(huì)被終止,并釋放相應(yīng)的系統(tǒng)資源。

注意:請(qǐng)將 [容器 ID]替換為實(shí)際要停止的容器的 ID。您可以使用 docker ps命令查看容器的 ID。

啟動(dòng)一個(gè)容器

docker start [容器 ID]

docker是 Docker 命令的前綴。

start是 Docker 命令,用于啟動(dòng)容器的運(yùn)行。

[容器 ID]是要啟動(dòng)的容器的唯一標(biāo)識(shí)符。

該命令的作用是啟動(dòng)已經(jīng)停止的容器。當(dāng)執(zhí)行 docker start [容器 ID]命令后,Docker 會(huì)嘗試重新啟動(dòng)指定的容器。容器會(huì)使用原先的配置和狀態(tài)恢復(fù)運(yùn)行。需要注意的是,只有處于停止?fàn)顟B(tài)的容器才能被啟動(dòng)。

通過(guò)執(zhí)行 docker start [容器 ID]命令,您可以重新啟動(dòng)已經(jīng)停止運(yùn)行的容器,使其繼續(xù)運(yùn)行。這樣可以方便地管理容器,避免每次都需要重新創(chuàng)建容器。

注意:請(qǐng)將 [容器 ID]替換為實(shí)際要啟動(dòng)的容器的 ID。您可以使用 docker ps -a命令查看所有容器的 ID。

重啟一個(gè)容器

docker restart [容器 ID]

docker是 Docker 命令的前綴。

restart是 Docker 命令,用于重啟容器的運(yùn)行。

[容器 ID]是要重啟的容器的唯一標(biāo)識(shí)符。

該命令的作用是停止并重新啟動(dòng)指定容器。執(zhí)行 docker restart [容器 ID]命令后,Docker 會(huì)先發(fā)送停止信號(hào)(SIGTERM)給指定的容器,然后等待一段時(shí)間后,再發(fā)送啟動(dòng)信號(hào),重新啟動(dòng)容器。這個(gè)過(guò)程相當(dāng)于先執(zhí)行了 docker stop [容器 ID]命令,再執(zhí)行了 docker start [容器 ID]命令。

通過(guò)執(zhí)行 docker restart [容器 ID]命令,您可以方便地重啟運(yùn)行中的容器,使其重新加載配置或應(yīng)用程序的更新,或應(yīng)用其他更改。

注意:請(qǐng)將 [容器 ID]替換為實(shí)際要重啟的容器的 ID。您可以使用 docker ps命令查看運(yùn)行中的容器的 ID。

進(jìn)入

進(jìn)入方式一

docker exec -it [容器 ID] /bin/bash

docker是 Docker 命令的前綴。

exec是 Docker 命令,用于在容器內(nèi)部執(zhí)行命令。

-itdocker exec命令的選項(xiàng),將命令綁定到交互式的終端。

[容器 ID]是要進(jìn)入的容器的唯一標(biāo)識(shí)符。

/bin/bash是要在容器內(nèi)執(zhí)行的命令,此處是指定進(jìn)入容器并打開一個(gè)交互式的 Bash Shell。

該命令的作用是進(jìn)入指定容器的內(nèi)部,并在容器內(nèi)部打開一個(gè)交互式的 Bash Shell。通過(guò)執(zhí)行 docker exec -it [容器 ID] /bin/bash命令,您可以在容器內(nèi)部執(zhí)行命令、調(diào)試、配置和管理容器。

注意:請(qǐng)將 [容器 ID]替換為實(shí)際要進(jìn)入的容器的 ID。您可以使用 docker ps命令查看運(yùn)行中的容器的 ID。

進(jìn)入容器后,您可以像在本地計(jì)算機(jī)的終端中一樣使用 Bash Shell,執(zhí)行任意命令、查看容器內(nèi)部的文件系統(tǒng)、修改配置等。這個(gè)功能非常有用,尤其在調(diào)試容器或執(zhí)行一些特定任務(wù)時(shí)。

進(jìn)入方式二

docker attach [容器 ID]

docker -it和-d不可以同時(shí)使用

docker一共有兩種模式,交互模式和守護(hù)進(jìn)程模式(或后臺(tái)模式)。

交互模式

-it選項(xiàng)用于創(chuàng)建一個(gè)交互式的終端會(huì)話,可以與容器進(jìn)行交互,類似于在本機(jī)操作系統(tǒng)中打開一個(gè)終端窗口并連接到容器。當(dāng)您退出終端會(huì)話時(shí),容器也會(huì)停止。

守護(hù)進(jìn)程模式(或后臺(tái)模式)

-d選項(xiàng)用于將容器置于后臺(tái)運(yùn)行模式,也稱為守護(hù)進(jìn)程模式或分離模式。容器將在后臺(tái)運(yùn)行,不會(huì)附加到當(dāng)前終端會(huì)話。當(dāng)您退出終端會(huì)話時(shí),容器將繼續(xù)在后臺(tái)運(yùn)行。

因此,您需要根據(jù)自己的需求選擇使用-it選項(xiàng)或-d選項(xiàng)。如果您需要與容器進(jìn)行交互并查看輸出,可以使用-it選項(xiàng)。如果您只想在后臺(tái)運(yùn)行容器而不需要交互,可以使用-d選項(xiàng)。

剛啟動(dòng)容器就關(guān)閉

主要原因:后臺(tái)沒有進(jìn)程運(yùn)行

通過(guò)日志查看是否正常關(guān)閉。

docker logs [容器ID]

如果沒有內(nèi)容返回,則是剛啟動(dòng)因?yàn)闆]有進(jìn)程運(yùn)行,就自動(dòng)關(guān)閉了。

查看容器狀

docker ps -a Exited (0)

如果容器的狀態(tài)顯示為 Exited (0),這表示容器已正常退出,并且退出代碼為 0。

如果"Status"字段顯示為"exited",并且"ExitCode"字段為非零值,那么容器可能是由于執(zhí)行的命令或應(yīng)用程序發(fā)生錯(cuò)誤而停止。

退出

請(qǐng)使用 exit命令或 Ctrl + D組合鍵來(lái)退出容器。

使用"exit"命令退出容器: 當(dāng)您在容器的命令行中輸入"exit"命令并按下回車鍵時(shí),該命令會(huì)告訴容器中的主要進(jìn)程以正常的方式退出,并終止容器。這相當(dāng)于在容器內(nèi)部執(zhí)行了一個(gè)退出指令,這將關(guān)閉容器并結(jié)束容器的生命周期。

使用"Ctrl+D"組合鍵退出容器: 在容器的命令行中,按下"Ctrl+D"組合鍵,這將模擬輸入文件的結(jié)尾(EOF字符),導(dǎo)致終端會(huì)話結(jié)束。對(duì)于大多數(shù)交互式終端,這相當(dāng)于發(fā)送了一個(gè)信號(hào)(SIGQUIT)給容器中的主要進(jìn)程,要求它退出。容器中的主要進(jìn)程收到這個(gè)信號(hào)后,將會(huì)先處理自己的退出邏輯,然后自行退出。這樣也會(huì)導(dǎo)致容器的終止和生命周期結(jié)束。

總的來(lái)說(shuō),"exit"命令是直接在容器內(nèi)部執(zhí)行的指令,而"Ctrl+D"是通過(guò)發(fā)送信號(hào)的方式請(qǐng)求容器內(nèi)的主要進(jìn)程退出。無(wú)論使用哪種方式,容器的退出和生命周期的結(jié)束都是相同的。

退出容器,同時(shí)不關(guān)閉容器

使用"Ctrl+P"組合鍵。

使用"Ctrl+Q"組合鍵。

按下Ctrl + p,然后按下 q

Ctrl + P:從容器終端中分離,保持容器在后臺(tái)運(yùn)行。 Ctrl + Q:分離(退出)容器終端,但保持容器繼續(xù)在后臺(tái)運(yùn)行。 這兩個(gè)組合鍵通常在交互式模式下使用,用于在保持容器運(yùn)行的同時(shí)退出容器終端,以便在后續(xù)需要時(shí)重新附加到容器終端。

小提示

由于我現(xiàn)在案例中的是Ubuntu鏡像容器,它本身里面沒有任何進(jìn)程在運(yùn)行,因此我們使用-d參數(shù)會(huì)出現(xiàn)剛啟動(dòng)就自動(dòng)關(guān)閉了。

如果我們有項(xiàng)目在容器內(nèi)運(yùn)行,啟動(dòng)容器后,就不會(huì)自動(dòng)關(guān)閉。

導(dǎo)出

首先,確保您的容器正在運(yùn)行。您可以使用 docker ps命令查看正在運(yùn)行的容器列表。

執(zhí)行以下命令導(dǎo)出容器:

docker export [容器 ID] >

其中,[容器 ID]是要導(dǎo)出的容器的 ID,是導(dǎo)出的容器文件的名稱。您可以自定義 的名稱和路徑。

注意:導(dǎo)出的容器將被壓縮為單個(gè) tar 文件。

導(dǎo)出完成后,您可以使用 ls命令確認(rèn)導(dǎo)出的文件是否創(chuàng)建成功。

現(xiàn)在,您已經(jīng)成功地導(dǎo)出了 Docker 容器。您可以將這個(gè)導(dǎo)出的文件(tar 文件)傳輸?shù)狡渌麢C(jī)器上,并通過(guò)docker import命令導(dǎo)入到 Docker 中,以創(chuàng)建相同的容器?;蛘撸梢栽谛枰獣r(shí)保留該文件作為容器的備份。

導(dǎo)入

首先,將包含要導(dǎo)入的容器的鏡像文件(tar 文件)傳輸?shù)侥繕?biāo)機(jī)器上。

在目標(biāo)機(jī)器上執(zhí)行以下命令導(dǎo)入容器:

docker import [新鏡像名稱]

其中,是包含要導(dǎo)入的容器的 tar 文件,[新鏡像名稱]是為新鏡像指定的名稱。您可以自定義 [新鏡像名稱]。

注意:導(dǎo)入的容器將被作為一個(gè)新的鏡像創(chuàng)建。

導(dǎo)入完成后,您可以使用 docker images命令查看導(dǎo)入的鏡像是否創(chuàng)建成功,并顯示其相關(guān)的信息。

現(xiàn)在,您已經(jīng)成功地將 Docker 容器導(dǎo)入為一個(gè)新的鏡像。您可以使用這個(gè)新鏡像創(chuàng)建和運(yùn)行新的容器。

刪除

普通刪除

首先,使用 docker ps -a命令查看所有的容器,包括已停止的容器。

找到要?jiǎng)h除的容器的 ID 或名稱。

執(zhí)行以下命令刪除容器:

docker rm [容器 ID 或名稱]

其中,[容器 ID 或名稱]是要?jiǎng)h除的容器的 ID 或名稱。您可以根據(jù)需要選擇使用容器的 ID 或名稱。

注意:刪除容器將永久刪除容器及其關(guān)聯(lián)的數(shù)據(jù)。

您可以使用 docker ps -a命令再次驗(yàn)證容器是否已成功刪除。

現(xiàn)在,您已經(jīng)成功地刪除了 Docker 容器。請(qǐng)注意,刪除容器后,與該容器關(guān)聯(lián)的數(shù)據(jù)也將被永久刪除。

強(qiáng)制刪除容器

docker rm -f [容器 ID 或名稱]

可以實(shí)現(xiàn)停止正在運(yùn)行的容器,并卸載,減去手動(dòng)停止容器的步驟。

批量強(qiáng)制刪除所有容器

docker rm -f $(docker ps -aq)

docker ps -aq:這個(gè)命令將列出所有容器的ID,選項(xiàng)-a用于顯示所有容器,而選項(xiàng)-q用于只顯示容器的ID。

docker rm -f:這個(gè)命令將強(qiáng)制刪除指定的容器。選項(xiàng)-f用于強(qiáng)制刪除容器,即使容器正在運(yùn)行中。

通過(guò)將這兩個(gè)命令結(jié)合起來(lái),并使用子命令$(...)將第一個(gè)命令的輸出作為第二個(gè)命令的參數(shù),我們可以批量刪除所有容器。

查看狀態(tài)

列出所有的容器,包括正在運(yùn)行的和已經(jīng)停止的容器。

docker ps -a

docker是 Docker 命令的前綴。

ps是 Docker 命令,用于列出容器的信息。

-a參數(shù)用于顯示所有的容器,包括正在運(yùn)行的和已經(jīng)停止的容器。

該命令的作用是顯示所有的容器的信息,包括容器的 ID、狀態(tài)、創(chuàng)建時(shí)間、鏡像名稱、對(duì)外映射的端口等。通過(guò)執(zhí)行 docker ps -a命令,您可以查看系統(tǒng)中所有容器的狀態(tài),包括已經(jīng)停止的容器,以便進(jìn)行管理或進(jìn)一步操作。

下載

打開終端或命令行窗口。

在終端或命令行中,輸入以下命令來(lái)下載容器鏡像:

docker pull [鏡像名稱]

其中,[鏡像名稱]是您要下載的容器鏡像的名稱。您可以使用 Docker 鏡像倉(cāng)庫(kù)中的公共鏡像,也可以使用自己私有的鏡像。

例如,要下載官方的 Nginx 鏡像,可以執(zhí)行以下命令:

docker pull nginx

Docker 將從 Docker 鏡像倉(cāng)庫(kù)中下載指定的鏡像,并保存到本地。

下載的鏡像將顯示下載進(jìn)度和狀態(tài)。

完成下載后,您可以使用 docker images命令來(lái)查看已下載的鏡像列表:

docker images

該命令將顯示已下載的容器鏡像的列表,包括鏡像的名稱、版本、大小等信息。

現(xiàn)在,您已經(jīng)成功地下載了 Docker 容器鏡像。您可以根據(jù)需要,下載所需的容器鏡像,并使用它們創(chuàng)建和運(yùn)行容器。

定義容器名稱

使用 --name選項(xiàng),可以在創(chuàng)建容器時(shí)為其指定一個(gè)可讀性高的名稱,方便在后續(xù)的操作中引用和管理容器。默認(rèn)情況下,Docker 將為容器分配一個(gè)隨機(jī)的名稱。

docker run --name mycontainer nginx

上述命令會(huì)創(chuàng)建一個(gè)名為 "mycontainer" 的容器,并使用 "nginx" 鏡像作為其基礎(chǔ)。

網(wǎng)絡(luò)

Docker網(wǎng)絡(luò)是Docker容器間進(jìn)行通信的網(wǎng)絡(luò)環(huán)境。在Docker中,每個(gè)容器都有一個(gè)獨(dú)立的網(wǎng)絡(luò)棧,這樣它們可以相互通信,并且與宿主機(jī)和其他容器隔離開來(lái)。

Docker提供了多種網(wǎng)絡(luò)模式,可以根據(jù)實(shí)際需求選擇適合的模式。

默認(rèn)橋接網(wǎng)絡(luò)(bridge network):這是Docker默認(rèn)的網(wǎng)絡(luò)模式。在這種模式下,所有容器連接到單個(gè)特定的網(wǎng)橋(default bridge)上,并被分配IP地址。默認(rèn)橋接網(wǎng)絡(luò)只允許同一主機(jī)上的容器通信。

主機(jī)網(wǎng)絡(luò)(host network):使用主機(jī)網(wǎng)絡(luò)模式時(shí),容器與宿主機(jī)共享網(wǎng)絡(luò)棧,即容器使用宿主機(jī)的網(wǎng)絡(luò)接口,與宿主機(jī)共享IP地址。這種模式下容器可以直接使用宿主機(jī)上的端口。

自定義橋接網(wǎng)絡(luò)(user-defined bridge network):用戶可以創(chuàng)建自己的橋接網(wǎng)絡(luò)并將容器連接到這個(gè)網(wǎng)絡(luò)中。在自定義橋接網(wǎng)絡(luò)中,容器之間可以相互通信,并且與默認(rèn)橋接網(wǎng)絡(luò)隔離開來(lái)??梢詾樽远x橋接網(wǎng)絡(luò)配置子網(wǎng)、網(wǎng)關(guān)、IP地址等。

Overlay網(wǎng)絡(luò):Overlay網(wǎng)絡(luò)是在多個(gè)Docker宿主機(jī)之間創(chuàng)建的虛擬網(wǎng)絡(luò),用于在跨主機(jī)的容器之間提供通信。這種網(wǎng)絡(luò)模式適用于分布式應(yīng)用程序和集群環(huán)境。

除了以上幾種網(wǎng)絡(luò)模式,Docker還支持其他網(wǎng)絡(luò)插件和第三方工具,用于擴(kuò)展網(wǎng)絡(luò)功能和提供更高級(jí)的網(wǎng)絡(luò)服務(wù)。

日志

docker logs [容器名稱或ID]

-f--follow:實(shí)時(shí)顯示日志輸出,并保持連接,類似于 tail -f命令。

--tail [行數(shù)]:僅顯示最后指定行數(shù)的日志,默認(rèn)為全部日志。

-t--timestamps:顯示日志的時(shí)間戳。

查看容器的實(shí)時(shí)日志:使用 docker logs -fdocker logs --follow命令可以實(shí)時(shí)查看容器的日志輸出。這對(duì)于觀察容器的運(yùn)行狀態(tài)、調(diào)試問(wèn)題以及監(jiān)視應(yīng)用程序的實(shí)時(shí)日志非常有用。

故障排查:通過(guò)查看容器的日志,您可以識(shí)別容器是否出現(xiàn)了異常、錯(cuò)誤或崩潰。它可以幫助您找到容器啟動(dòng)失敗、應(yīng)用程序錯(cuò)誤等問(wèn)題的原因,從而進(jìn)行相應(yīng)的故障排查和修復(fù)。

記錄應(yīng)用程序日志:如果您的應(yīng)用程序在容器內(nèi)生成日志,例如日志文件或控制臺(tái)輸出,您可以使用 docker logs命令來(lái)查看這些日志。這是一種方便的方式,可以從已運(yùn)行的容器中獲取應(yīng)用程序的日志信息。

監(jiān)控和分析:通過(guò)查看容器的日志,您可以監(jiān)控應(yīng)用程序的活動(dòng)并進(jìn)行分析。您可以建立監(jiān)控系統(tǒng),收集容器的日志數(shù)據(jù),并進(jìn)行檢索、過(guò)濾、聚合和可視化等操作,以了解應(yīng)用程序的性能、行為和趨勢(shì)。

總而言之,docker logs命令是在 Docker 環(huán)境中查看容器日志的主要工具,是監(jiān)控、故障排查和分析容器的重要手段之一。它可以幫助您了解容器的運(yùn)行狀態(tài)和應(yīng)用程序的日志輸出。

數(shù)據(jù)卷

Docker數(shù)據(jù)卷是將宿主機(jī)上的目錄或文件與容器內(nèi)的目錄或文件進(jìn)行映射的一種機(jī)制。通過(guò)使用數(shù)據(jù)卷,可以在容器之外創(chuàng)建、持久化和共享數(shù)據(jù)。

使用數(shù)據(jù)卷的好處包括:

數(shù)據(jù)持久性:數(shù)據(jù)卷允許在容器終止或重新創(chuàng)建時(shí)保留數(shù)據(jù)。即使刪除容器,數(shù)據(jù)卷仍然存在,并且可以重新掛載到新的容器中,以保留數(shù)據(jù)。

數(shù)據(jù)共享:可以通過(guò)將多個(gè)容器掛載到同一個(gè)數(shù)據(jù)卷,實(shí)現(xiàn)容器之間的數(shù)據(jù)共享。這使得數(shù)據(jù)在多個(gè)容器之間的傳遞和共享變得更加容易,無(wú)需復(fù)制或移動(dòng)數(shù)據(jù)。

數(shù)據(jù)備份和恢復(fù):通過(guò)將數(shù)據(jù)卷映射到宿主機(jī)上的特定目錄,可以方便地對(duì)數(shù)據(jù)進(jìn)行備份和恢復(fù)。這樣即使容器或Docker環(huán)境出現(xiàn)故障,數(shù)據(jù)仍然安全可靠。

使用數(shù)據(jù)卷可以通過(guò)兩種方式進(jìn)行:

匿名數(shù)據(jù)卷:在創(chuàng)建容器時(shí)可以使用 -v--volume參數(shù)創(chuàng)建匿名數(shù)據(jù)卷,Docker將自動(dòng)為其生成一個(gè)唯一的目錄并與容器中指定的路徑進(jìn)行映射。

示例命令:docker run -v /path/in/host:/path/in/container image:tag

命名數(shù)據(jù)卷:可以使用 docker volume create命令顯式創(chuàng)建命名數(shù)據(jù)卷,這樣可以更方便地管理和重用數(shù)據(jù)卷。

示例命令:

創(chuàng)建數(shù)據(jù)卷:docker volume create myvolume

掛載數(shù)據(jù)卷:docker run -v myvolume:/path/in/container image:tag

一旦數(shù)據(jù)卷創(chuàng)建成功并且與容器建立了映射關(guān)系,容器內(nèi)的操作就會(huì)直接影響到映射的宿主機(jī)上的目錄或文件。但需要注意的是,Docker數(shù)據(jù)卷是與容器關(guān)聯(lián)的,一旦容器被刪除,數(shù)據(jù)卷也會(huì)一起被刪除。如果需要保留數(shù)據(jù)卷,可以將其掛載到另一個(gè)容器或使用 docker volume prune命令進(jìn)行清理。

端口映射

單個(gè)端口映射

docker run -p [宿主機(jī)端口]:[docker容器內(nèi)部端口] ...

案例

docker run -p 8080:80 ...

這樣,當(dāng)你在主機(jī)上訪問(wèn) http://localhost:8080時(shí),實(shí)際上是在訪問(wèn)容器內(nèi)的服務(wù)。

多個(gè)端口映射

docker run -p 8080:80 -p 3000:3000 ...

這將同時(shí)將容器內(nèi)的 80 端口映射到主機(jī)的 8080 端口上,以及將容器內(nèi)的 3000 端口映射到主機(jī)的 3000 端口上。

Docker -p和-P區(qū)別

-p選項(xiàng)的語(yǔ)法是-p hostPort:containerPort,它允許你將主機(jī)的端口映射到容器的指定端口。例如,使用-p 8080:80將主機(jī)的8080端口映射到容器的80端口。

相反地,-P選項(xiàng)會(huì)自動(dòng)將容器的所有公開端口映射到主機(jī)上的任意端口。Docker會(huì)隨機(jī)分配一個(gè)未使用的主機(jī)端口并映射到容器的相應(yīng)端口。這個(gè)選項(xiàng)在你不需要指定特定的主機(jī)端口時(shí)很方便。

下面是一個(gè)簡(jiǎn)單的例子來(lái)說(shuō)明這兩個(gè)選項(xiàng)的區(qū)別:

docker run -d -p 8080:80 nginx

上面的命令將在后臺(tái)運(yùn)行一個(gè)nginx容器,并將主機(jī)的8080端口映射到容器的80端口。

docker run -d -P nginx

而這個(gè)命令會(huì)在后臺(tái)運(yùn)行一個(gè)nginx容器,并自動(dòng)將容器的所有公開端口映射到主機(jī)上的任意端口。

總結(jié)來(lái)說(shuō),-p選項(xiàng)允許你顯式地指定主機(jī)端口與容器端口的映射關(guān)系,而-P選項(xiàng)則會(huì)自動(dòng)隨機(jī)分配主機(jī)端口并映射容器的所有公開端口。

容器互聯(lián)

在 Docker 中,容器互聯(lián)允許不同的容器之間進(jìn)行通信和交互。通過(guò)容器互聯(lián),可以在不使用端口映射的情況下,在容器之間建立網(wǎng)絡(luò)連接。

要實(shí)現(xiàn)容器互聯(lián),可以使用 Docker 的網(wǎng)絡(luò)功能。有兩種主要的網(wǎng)絡(luò)模式可以實(shí)現(xiàn)容器之間的互聯(lián):橋接模式(Bridge Mode)和用戶定義網(wǎng)絡(luò)(User-defined Network)。

橋接模式

橋接模式(Bridge Mode): 橋接模式是 Docker 默認(rèn)使用的網(wǎng)絡(luò)模式。在橋接模式下,Docker 會(huì)為每個(gè)容器分配一個(gè)唯一的 IP 地址,并且容器之間可以相互訪問(wèn)。你可以創(chuàng)建多個(gè)容器并將它們加入同一個(gè)網(wǎng)絡(luò)中,這樣它們就可以通過(guò)容器名稱或 IP 地址進(jìn)行通信。Docker 創(chuàng)建的默認(rèn)網(wǎng)絡(luò)名為 bridge。例如,可以使用以下命令創(chuàng)建兩個(gè)容器并加入同一個(gè)網(wǎng)絡(luò):

docker network create my-networkdocker run --name container1 --network my-network -d image1docker run --name container2 --network my-network -d image2

在這個(gè)例子中,container1container2將加入名為 my-network的網(wǎng)絡(luò),并且可以通過(guò)容器名稱相互訪問(wèn)。

用戶定義網(wǎng)絡(luò)

用戶定義網(wǎng)絡(luò)(User-defined Network): 用戶定義網(wǎng)絡(luò)允許你創(chuàng)建自己的網(wǎng)絡(luò),并在該網(wǎng)絡(luò)上運(yùn)行容器。通過(guò)使用用戶定義網(wǎng)絡(luò),你可以更好地管理容器之間的互聯(lián)。創(chuàng)建用戶定義網(wǎng)絡(luò)的步驟如下:

docker network create my-networkdocker network connect my-network container1docker network connect my-network container2

在這個(gè)例子中,container1container2將加入名為 my-network的網(wǎng)絡(luò)。它們之間可以通過(guò)容器名稱或 IP 地址進(jìn)行通信。如果要從網(wǎng)絡(luò)中刪除容器,可以使用 docker network disconnect命令。

無(wú)論是橋接模式還是用戶定義網(wǎng)絡(luò),容器之間的通信都可以通過(guò)它們的名稱或 IP 地址進(jìn)行。你可以像使用普通網(wǎng)絡(luò)一樣使用容器之間的互聯(lián)來(lái)建立各種通信和交互場(chǎng)景。

查看已經(jīng)創(chuàng)建的網(wǎng)絡(luò)

docker network list

該命令將列出當(dāng)前系統(tǒng)中的所有 Docker 網(wǎng)絡(luò)。輸出結(jié)果將包含網(wǎng)絡(luò)的名稱(NAME)、唯一標(biāo)識(shí)符(ID)、驅(qū)動(dòng)程序(DRIVER)以及網(wǎng)絡(luò)范圍(SCOPE)等信息。

示例輸出:

NETWORK ID ? ? NAME ? ? ? ? ? ?DRIVER ? ?SCOPE1a4c7f14e867 ? bridge ? ? ? ? ?bridge ? ?localdf7bd7a75196 ? host ? ? ? ? ? ?host ? ? ?local84aa34d3fdf7 ? none ? ? ? ? ? ?null ? ? ?local

其中,bridge是 Docker 默認(rèn)的橋接網(wǎng)絡(luò),host是主機(jī)網(wǎng)絡(luò)模式,none是無(wú)網(wǎng)絡(luò)模式。

如果想查看特定網(wǎng)絡(luò)的詳細(xì)信息,可以使用以下命令,將 <network_name>替換為具體的網(wǎng)絡(luò)名稱:

docker network inspect <network_name>

這將在終端中顯示有關(guān)該網(wǎng)絡(luò)的詳細(xì)信息,包括網(wǎng)絡(luò)的子網(wǎng)、網(wǎng)關(guān)和連接到該網(wǎng)絡(luò)的容器列表等。

刪除網(wǎng)絡(luò)

docker network rm [network_name]

將 "[network_name]" 替換為要?jiǎng)h除的網(wǎng)絡(luò)的名稱。

請(qǐng)注意,只有當(dāng)該網(wǎng)絡(luò)沒有正在運(yùn)行的容器時(shí),才能成功刪除網(wǎng)絡(luò)。如果網(wǎng)絡(luò)仍在被使用,您需要先停止或刪除使用該網(wǎng)絡(luò)的容器,然后才能刪除網(wǎng)絡(luò)。

網(wǎng)絡(luò)中刪除容器

使用 docker network disconnect命令將容器從網(wǎng)絡(luò)中斷開連接:

docker network disconnect [network_name] [container_id or container_name]

將 "[network_name]" 替換為要從中斷開連接的網(wǎng)絡(luò)的名稱,"[container_id or container_name]" 替換為要從網(wǎng)絡(luò)中斷開連接的容器的 CONTAINER ID 或名稱。

如此,您就成功將容器從指定的 Docker 網(wǎng)絡(luò)中刪除了。請(qǐng)注意,此操作只是將容器與網(wǎng)絡(luò)斷開連接,并不會(huì)刪除容器本身。如果需要完全刪除容器,請(qǐng)使用 docker rm命令。

DockerFile(制作鏡像)

案例制作nginx鏡像

準(zhǔn)備工作

首先,創(chuàng)建一個(gè)名為Dockerfile的文件。

touch Dockerfile

2.創(chuàng)建配置文件

touch ?nginx;worker_processes ?auto;error_log ?/var/log/nginx/ notice;pid ? ? ? ?/var/run/;events { ? ?worker_connections ?1024;}http { ? ?include ? ? ? /etc/nginx/; ? ?default_type ?application/octet-stream; ? ?log_format ?main ?'$remote_addr - $remote_user [$time_local] "$request" ' ? ? ? ? ? ? ? ? ? ? ?'$status $body_bytes_sent "$http_referer" ' ? ? ? ? ? ? ? ? ? ? ?'"$http_user_agent" "$http_x_forwarded_for"'; ? ?access_log ?/var/log/nginx/ ?main; ? ?sendfile ? ? ? ?on; ? ?tcp_nopush ? ? ?on; ? ?tcp_nodelay ? ? on; ? ?keepalive_timeout ?65; ? ?types_hash_max_size 2048; ? ?include /etc/nginx//*.conf; ? ?include /etc/nginx/sites-enabled/*;}

3.創(chuàng)建網(wǎng)頁(yè)源代碼文件

touch <!DOCTYPE html><html> <head> <meta charset="utf-8"> <title>滄桑docker教程</title> </head> <body> <p>作者:滄桑</p> <p>嗶哩嗶哩平臺(tái)</p> <p>搜索UID:507560163</p> <p>經(jīng)常拍攝電腦編程、軟件等知識(shí)分享</p> </body></html>

制作鏡像

1.在Dockerfile文件中,使用以下內(nèi)容來(lái)定義鏡像構(gòu)建過(guò)程:

# 使用Nginx官方的基礎(chǔ)鏡像FROM nginx:latest# 將本地的自定義 Nginx 配置文件復(fù)制到容器中COPY /etc/nginx/# 將本地的網(wǎng)站文件復(fù)制到容器中的默認(rèn) Nginx 網(wǎng)站目錄COPY /usr/share/nginx/html# 定義容器啟動(dòng)時(shí)需要暴露的端口EXPOSE 80# 在容器啟動(dòng)時(shí)運(yùn)行 NginxCMD ["nginx", "-g", "daemon off;"]

在這個(gè)例子中,我們使用了nginx:latest作為基礎(chǔ)鏡像。然后,我們將我們自定義的Nginx配置文件()復(fù)制到容器的/etc/nginx/目錄下,將網(wǎng)站文件復(fù)制到容器的默認(rèn)Nginx網(wǎng)站目錄(/usr/share/nginx/html)下。我們還通過(guò)EXPOSE命令暴露了容器的80端口,并使用CMD命令指定在容器啟動(dòng)時(shí)運(yùn)行Nginx。

2.在同一目錄下,創(chuàng)建自定義的Nginx配置文件和網(wǎng)站文件website。

touch -R website

根據(jù)自己的需求,可以在文件中配置Nginx服務(wù)器的具體設(shè)置,將網(wǎng)站文件放在website目錄中。

3.構(gòu)建Docker鏡像。在終端中進(jìn)入包含Dockerfile文件的目錄,并執(zhí)行以下命令:

docker build -t my-nginx-image .

這將根據(jù)Dockerfile文件的內(nèi)容構(gòu)建一個(gè)名為my-nginx-image的新的Docker鏡像。請(qǐng)注意最后的點(diǎn)號(hào).表示使用當(dāng)前目錄作為構(gòu)建上下文。

4.等待鏡像構(gòu)建完成后,可以使用以下命令運(yùn)行容器:

docker run -p 80:80 --name my-nginx-container my-nginx-image

這將在端口80上運(yùn)行一個(gè)名為my-nginx-container的新容器,并將該容器的80端口映射到主機(jī)的80端口。

現(xiàn)在你應(yīng)該擁有一個(gè)基于Nginx的Docker鏡像,并且可以運(yùn)行一個(gè)Nginx服務(wù)器的容器了。請(qǐng)根據(jù)你的實(shí)際需求進(jìn)行自定義配置和修改。

構(gòu)建鏡像

在Docker主機(jī)上構(gòu)建鏡像:在已經(jīng)安裝了Docker的主機(jī)上,使用docker build命令來(lái)構(gòu)建鏡像。在命令行中進(jìn)入Dockerfile所在的目錄,然后運(yùn)行以下命令:

docker build -t <image_name> .

其中,<image_name>是你想要為鏡像命名的名字。命令中的.表示Dockerfile所在的當(dāng)前目錄。

查看已構(gòu)建的鏡像:完成構(gòu)建后,你可以使用以下命令來(lái)查看已構(gòu)建的鏡像:

docker images

這將顯示一個(gè)列表,其中包含已構(gòu)建的鏡像以及它們的標(biāo)簽和大小。

運(yùn)行鏡像

運(yùn)行容器:基于已構(gòu)建的鏡像,你可以使用docker run命令來(lái)運(yùn)行容器。例如:

docker run --name <container_name> -d -p <host_port>:<container_port> <image_name>

其中,<container_name>是你為容器指定的名字,<host_port>是你要映射到容器的端口號(hào),<container_port>是容器內(nèi)部運(yùn)行的應(yīng)用程序的端口號(hào),<image_name>是之前構(gòu)建的鏡像的名字。

注意,根據(jù)你的需求,可以使用不同的標(biāo)志來(lái)調(diào)整容器的配置和行為。

查看運(yùn)行中的容器:運(yùn)行以下命令來(lái)查看正在運(yùn)行的容器:

docker ps

這將顯示當(dāng)前正在運(yùn)行的容器的列表,包括容器的ID、名稱、運(yùn)行時(shí)間等信息。

發(fā)布

注意:Docker原本所有鏡像都是通過(guò)Docker Hub下載資源,但是這個(gè)平臺(tái)今年開始收費(fèi)了,不交錢的倉(cāng)庫(kù)就要被強(qiáng)制下架,我為了方便大家學(xué)習(xí),選中阿里云倉(cāng)庫(kù)。

以后阿里云倉(cāng)庫(kù)收不收費(fèi),我也不知道,視頻內(nèi)容也用不了了。

大家知道大致的流程,并且可以理解,就算學(xué)會(huì)發(fā)布了。

登錄阿里云官網(wǎng)

1.搜索容器鏡像服務(wù)

2.選擇管理控制臺(tái)

3.創(chuàng)建個(gè)人實(shí)例,點(diǎn)擊并進(jìn)入

4.選擇鏡像倉(cāng)庫(kù),并創(chuàng)建

5.創(chuàng)建倉(cāng)庫(kù)信息

輸入倉(cāng)庫(kù)名稱、是否公開、私有,以及倉(cāng)庫(kù)的描述。

6.來(lái)源選擇本地倉(cāng)庫(kù),并且點(diǎn)擊創(chuàng)建。

7.復(fù)制倉(cāng)庫(kù)推送信息并使用

8.登錄失敗怎么辦

請(qǐng)回到個(gè)人實(shí)例位置,點(diǎn)擊訪問(wèn)憑證并重新設(shè)置密碼。

下載鏡像

$ docker pull /docker8886/cangsangdockerdemo:

因?yàn)槲覄?chuàng)建的這個(gè)鏡像倉(cāng)庫(kù)是“公開”,所以他人下載的時(shí)候,不需要輸入登錄密碼。

運(yùn)行容器

docker run -p 8080:80 -d [鏡像名稱或ID]

修改DNS

編輯/etc/文件,可以使用以下命令打開編輯器:

sudo gedit /etc/

在文件中,找到并刪除所有已存在的nameserver行。

添加以下兩行來(lái)指定新的DNS服務(wù)器地址:

nameserver

這將把和作為首選DNS服務(wù)器地址。

Dockerfile和容器導(dǎo)入導(dǎo)出區(qū)別

Dockerfile:Dockerfile是用于定義和構(gòu)建Docker鏡像的文本文件。它包含一系列的指令和參數(shù),用于描述Docker鏡像的構(gòu)建過(guò)程。通過(guò)執(zhí)行Dockerfile中的指令,我們可以自動(dòng)化地構(gòu)建出一個(gè)可重復(fù)部署的鏡像。Dockerfile通常包含了基礎(chǔ)鏡像的選擇、軟件安裝、配置文件、環(huán)境變量、暴露端口等信息,以及構(gòu)建鏡像所需要的其他步驟。Dockerfile的主要作用是定義鏡像的構(gòu)建過(guò)程,并提供了一種可重復(fù)和可移植的方式來(lái)構(gòu)建鏡像。

容器的導(dǎo)入導(dǎo)出:容器的導(dǎo)入導(dǎo)出是指將正在運(yùn)行的Docker容器導(dǎo)出為一個(gè)文件,并且可以將這個(gè)文件導(dǎo)入到另外一臺(tái)Docker主機(jī)上。通過(guò)導(dǎo)出容器,可以將容器的狀態(tài)和數(shù)據(jù)打包成一個(gè)文件,然后在其他主機(jī)上導(dǎo)入并保留原有的狀態(tài)和數(shù)據(jù)。導(dǎo)出的文件包含了容器的文件系統(tǒng)和元數(shù)據(jù),可以用于備份、遷移容器和共享容器狀態(tài)。導(dǎo)入導(dǎo)出容器的常用命令是docker exportdocker import

總結(jié)來(lái)說(shuō),Dockerfile用于定義和構(gòu)建鏡像,而容器的導(dǎo)入導(dǎo)出用于將運(yùn)行中的容器保存成文件以及將導(dǎo)出文件導(dǎo)入到其他主機(jī)上。兩者分別針對(duì)不同的場(chǎng)景和需求。

FROM

"FROM"是Dockerfile中的一條指令,它用于指定基礎(chǔ)鏡像?;A(chǔ)鏡像是構(gòu)建Docker容器所需的起點(diǎn),可以理解為一個(gè)用于構(gòu)建應(yīng)用程序環(huán)境的空白板。

在Dockerfile中,使用"FROM"指令可以選擇一個(gè)現(xiàn)有的基礎(chǔ)鏡像作為構(gòu)建的起點(diǎn),然后在該基礎(chǔ)鏡像的基礎(chǔ)上進(jìn)行進(jìn)一步的定制。

使用"FROM"指令時(shí),可以指定一個(gè)完整的鏡像名稱,或者使用一個(gè)簡(jiǎn)寫名稱。如果指定的鏡像名稱不是完整的URL,Docker引擎會(huì)去預(yù)定義的鏡像倉(cāng)庫(kù)中查找該鏡像。

例如,下面是一個(gè)簡(jiǎn)單的Dockerfile示例,使用FROM指令選擇了一個(gè)基礎(chǔ)鏡像:

FROM ubuntu:latest

這個(gè)示例中,基礎(chǔ)鏡像選擇了Ubuntu操作系統(tǒng)的最新版本。接著,你可以在Dockerfile中添加更多的指令來(lái)定制你的應(yīng)用程序環(huán)境,例如安裝軟件包、復(fù)制文件等。

總之,"FROM"指令的作用是選擇一個(gè)基礎(chǔ)鏡像,該基礎(chǔ)鏡像將成為構(gòu)建Docker容器的起點(diǎn)。

MAINTAINER

在早期版本的Docker中,可以使用MAINTAINER指令來(lái)指定維護(hù)者(maintainer)的信息。維護(hù)者通常是負(fù)責(zé)創(chuàng)建和維護(hù)Docker鏡像的人或團(tuán)隊(duì)。

MAINTAINER指令的作用是向用戶提供關(guān)于維護(hù)者的信息。它的語(yǔ)法如下:

MAINTAINER <name>

<name>可以是維護(hù)者的任意文本信息,例如維護(hù)者的姓名、郵箱地址或組織名稱。

然而,在Docker 版本以后,MAINTAINER指令已被棄用,取而代之的是通過(guò)標(biāo)簽(label)來(lái)提供鏡像的相關(guān)信息。通過(guò)標(biāo)簽,你可以為鏡像指定一系列自定義的鍵值對(duì),其中包括維護(hù)者的信息。

以下是一個(gè)使用標(biāo)簽代替MAINTAINER指令的示例:

LABEL maintainer="your_email@"

這樣,你就可以使用docker image inspect命令來(lái)查看鏡像的標(biāo)簽,其中就會(huì)包含維護(hù)者的信息:

$ docker image inspect your_image_name"Labels": { ? ?"maintainer": "your_email@"},

總結(jié)來(lái)說(shuō),MAINTAINER指令的作用是在Dockerfile中提供維護(hù)者的信息。然而,最好的做法是使用標(biāo)簽來(lái)代替MAINTAINER指令,以便提供更多靈活性和自定義性。

RUN

在Dockerfile中,"RUN"指令用于在鏡像構(gòu)建過(guò)程中執(zhí)行命令。它的作用是在構(gòu)建鏡像的過(guò)程中運(yùn)行指定的命令,以便安裝軟件包、創(chuàng)建文件、設(shè)置環(huán)境變量等。

"RUN"指令的語(yǔ)法如下:

RUN <command>

""可以是任意的命令或命令串,可以使用Shell執(zhí)行命令。Docker引擎將按照Dockerfile中的順序逐行執(zhí)行"RUN"指令。每個(gè)"RUN"指令都會(huì)在容器中執(zhí)行一個(gè)新的臨時(shí)容器,并且對(duì)該容器的更改都會(huì)被記錄到鏡像中。

以下是一個(gè)示例,展示了在Dockerfile中使用"RUN"指令安裝軟件包的例子:

FROM ubuntu:latestRUN apt-get update && apt-get install -y \ ? ?package1 \ ? ?package2 \ ? ?package3

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后使用"RUN"指令運(yùn)行了兩個(gè)命令。第一個(gè)命令是更新Ubuntu系統(tǒng)的軟件源列表,第二個(gè)命令通過(guò)apt-get命令安裝了三個(gè)軟件包。

在構(gòu)建鏡像時(shí),Docker引擎會(huì)執(zhí)行這兩個(gè)命令,并將生成的更改記錄到最終的鏡像中。這樣,在之后的容器中,這些軟件包就都已經(jīng)預(yù)先安裝好了。

總之,"RUN"指令在Dockerfile中用于執(zhí)行命令,以便在構(gòu)建鏡像的過(guò)程中進(jìn)行一系列操作,如安裝軟件包、創(chuàng)建文件、設(shè)置環(huán)境變量等。

CMD

在Dockerfile中,"CMD"指令用于設(shè)置容器啟動(dòng)時(shí)要執(zhí)行的默認(rèn)命令或者程序。

"CMD"指令的語(yǔ)法有兩種不同的方式:

Exec 格式:

CMD ["executable","param1","param2"]

這種格式使用 JSON 數(shù)組的形式來(lái)指定要執(zhí)行的命令。其中,可執(zhí)行文件和參數(shù)都必須以字符串的形式進(jìn)行指定。當(dāng)容器啟動(dòng)時(shí),會(huì)執(zhí)行這個(gè)命令。

Shell 格式:

CMD command param1 param2

這種格式以字符串形式直接指定要執(zhí)行的命令。當(dāng)容器啟動(dòng)時(shí),會(huì)將這個(gè)字符串交給默認(rèn)的 Shell 進(jìn)行解析執(zhí)行。

需要注意的是,Dockerfile中只能有一個(gè)"CMD"指令。如果在一個(gè)Dockerfile中出現(xiàn)了多個(gè)"CMD"指令,則只有最后一個(gè)會(huì)生效。

另外,如果在運(yùn)行Docker容器時(shí)指定了要執(zhí)行的命令(通過(guò)docker run命令的參數(shù)來(lái)指定),則會(huì)覆蓋掉"Dockerfile"中設(shè)置的默認(rèn)命令。

以下是一個(gè)使用"CMD"指令的示例:

FROM ubuntu:latestRUN apt-get update && apt-get install -y \ ? ?package1 \ ? ?package2 \ ? ?package3CMD ["echo", "Hello, Docker!"]

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后通過(guò)"RUN"指令安裝了一些軟件包。最后,通過(guò)"CMD"指令設(shè)置了默認(rèn)的命令"echo Hello, Docker!"。

當(dāng)我們構(gòu)建這個(gè)鏡像并在容器中運(yùn)行時(shí),會(huì)自動(dòng)執(zhí)行默認(rèn)命令"echo Hello, Docker!"。

總結(jié)來(lái)說(shuō),"CMD"指令在Dockerfile中用于設(shè)置容器啟動(dòng)時(shí)要執(zhí)行的默認(rèn)命令或程序。它有兩種語(yǔ)法格式,可以通過(guò)配置Dockerfile中的"CMD"指令來(lái)定義容器的默認(rèn)行為。

VOLUME

在Dockerfile中,"VOLUME"指令用于在容器中創(chuàng)建一個(gè)或多個(gè)掛載點(diǎn),使得容器內(nèi)的特定路徑可以與宿主機(jī)或其他容器進(jìn)行數(shù)據(jù)共享。

"VOLUME"指令的語(yǔ)法如下:

VOLUME ["<path>"]

或者

VOLUME <path>

其中,<path>表示容器中的目錄路徑,可以是絕對(duì)路徑或相對(duì)路徑。

使用"VOLUME"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

數(shù)據(jù)共享:通過(guò)將容器內(nèi)的某個(gè)目錄路徑掛載到宿主機(jī)或其他容器上的目錄,可以實(shí)現(xiàn)數(shù)據(jù)的共享和持久化。這樣在容器啟動(dòng)、停止、重新創(chuàng)建等操作時(shí),數(shù)據(jù)都能保持不變,使得容器更加可移植和可靠。

數(shù)據(jù)持久化:通過(guò)掛載容器內(nèi)的目錄到宿主機(jī)上的目錄,可以將容器中的數(shù)據(jù)持久化保存到宿主機(jī)上,而不會(huì)隨著容器的刪除而丟失。這樣在容器重新啟動(dòng)時(shí),可以通過(guò)掛載同樣的目錄,恢復(fù)之前的數(shù)據(jù)。

以下是一個(gè)使用"VOLUME"指令的示例:

FROM ubuntu:latestVOLUME /data

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后使用"VOLUME"指令創(chuàng)建了一個(gè)掛載點(diǎn)。它將容器內(nèi)的/data目錄路徑映射到宿主機(jī)上的某個(gè)目錄,以實(shí)現(xiàn)數(shù)據(jù)共享和持久化。

在運(yùn)行容器時(shí),可以通過(guò)-v參數(shù)指定宿主機(jī)上的目錄與容器內(nèi)的掛載點(diǎn)之間的映射關(guān)系,例如:

docker run -v /host/data:/data image_name

這樣就將宿主機(jī)上的/host/data目錄與容器內(nèi)的/data目錄進(jìn)行了映射,實(shí)現(xiàn)了數(shù)據(jù)共享和持久化。

總結(jié)來(lái)說(shuō),"VOLUME"指令在Dockerfile中用于創(chuàng)建一個(gè)或多個(gè)掛載點(diǎn),以實(shí)現(xiàn)容器內(nèi)數(shù)據(jù)的共享和持久化。通過(guò)在運(yùn)行容器時(shí),指定宿主機(jī)上的目錄與容器內(nèi)的掛載點(diǎn)之間的映射關(guān)系,可以將數(shù)據(jù)存儲(chǔ)在宿主機(jī)上,而不會(huì)隨著容器的生命周期改變。

USER

在Dockerfile中,"USER"指令用于指定在容器中運(yùn)行應(yīng)用程序時(shí)使用的用戶或用戶組。它的作用是在容器中設(shè)置一個(gè)特定的用戶身份,以增加容器的安全性和隔離性。

"USER"指令的語(yǔ)法如下:

USER <user>[:<group>] or USER <UID>[:<GID>]

其中,<user>可以是用戶名或用戶ID(UID), <group>可以是組名或組ID(GID),也可以省略不寫。如果省略了<group>,則容器中的默認(rèn)組將會(huì)被使用。

使用"USER"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

提高容器的安全性:在容器中運(yùn)行應(yīng)用程序時(shí),使用非特權(quán)用戶身份可以減少潛在的安全風(fēng)險(xiǎn)。通過(guò)使用"USER"指令,可以將容器中的進(jìn)程限制在一個(gè)非特權(quán)用戶的權(quán)限范圍內(nèi),減少潛在的攻擊面。

隔離應(yīng)用程序環(huán)境:通過(guò)指定特定的用戶身份,可以將應(yīng)用程序與宿主機(jī)或其他容器隔離開來(lái),避免可能的沖突和干擾。這有助于增加應(yīng)用程序的可移植性和可靠性。

以下是一個(gè)使用"USER"指令的示例:

FROM ubuntu:latestRUN groupadd -r mygroup && useradd -r -g mygroup myuserUSER myuser:mygroup

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后通過(guò)RUN指令創(chuàng)建了一個(gè)用戶組和用戶。最后,使用"USER"指令將容器中的進(jìn)程限制在myuser用戶和mygroup組的權(quán)限范圍內(nèi)。

請(qǐng)注意,"USER"指令只影響通過(guò)Dockerfile構(gòu)建的鏡像中的用戶身份。在運(yùn)行鏡像時(shí),可以通過(guò)--user參數(shù)來(lái)指定要使用的用戶身份,覆蓋Dockerfile中的設(shè)置。

總結(jié)來(lái)說(shuō),"USER"指令在Dockerfile中用于指定容器中運(yùn)行應(yīng)用程序時(shí)使用的用戶或用戶組,以增加容器的安全性和隔離性。

WORKDIR

在Dockerfile中,"WORKDIR"指令用于設(shè)置容器內(nèi)部工作目錄,即在容器中執(zhí)行命令時(shí)的默認(rèn)目錄。

使用"WORKDIR"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

指定默認(rèn)工作目錄:通過(guò)使用"WORKDIR"指令,可以設(shè)置容器中的默認(rèn)工作目錄。這樣,當(dāng)在容器內(nèi)部執(zhí)行命令時(shí),可以省略完整路徑,直接相對(duì)于該工作目錄執(zhí)行命令。這提供了簡(jiǎn)潔性和便利性。

簡(jiǎn)化指令路徑:容器中的每個(gè)指令都會(huì)在指定的工作目錄中執(zhí)行。這樣可以避免在每個(gè)執(zhí)行命令時(shí)都寫入長(zhǎng)路徑,簡(jiǎn)化了指令的編寫。

支持相對(duì)路徑:"WORKDIR"指令可以接受相對(duì)路徑和絕對(duì)路徑。使用相對(duì)路徑時(shí),它會(huì)相對(duì)于當(dāng)前工作目錄進(jìn)行解析。這樣可以更靈活地操作容器中的文件和目錄。

以下是一個(gè)使用"WORKDIR"指令的示例:

FROM ubuntu:latestWORKDIR /appCOPY . .RUN makeCMD [ "./app" ]

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后使用"WORKDIR"指令將工作目錄設(shè)置為/app。接下來(lái),使用COPY指令將當(dāng)前目錄的文件復(fù)制到容器中的工作目錄。然后使用make命令構(gòu)建應(yīng)用程序。最后,使用CMD指令定義了容器啟動(dòng)時(shí)默認(rèn)執(zhí)行的命令,相對(duì)路徑"./app"會(huì)在工作目錄/app中執(zhí)行。

簡(jiǎn)單來(lái)說(shuō),"WORKDIR"指令用于設(shè)置容器內(nèi)部的工作目錄,以方便在容器中執(zhí)行命令時(shí)使用相對(duì)路徑。

HEALTHCHECH

在Dockerfile中,"HEALTHCHECK"指令用于指定容器運(yùn)行時(shí)的健康檢查命令。

使用"HEALTHCHECK"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

容器健康狀態(tài)檢查:通過(guò)定義健康檢查命令,可以在容器運(yùn)行時(shí)定期或定時(shí)檢查容器的健康狀態(tài)。健康檢查可以包括各種類型的檢查,如執(zhí)行命令、發(fā)送HTTP請(qǐng)求、檢查端口等。

自動(dòng)容器重啟:當(dāng)容器的健康狀態(tài)檢查失敗時(shí),Docker守護(hù)進(jìn)程可以自動(dòng)在指定條件下重啟容器,以使其恢復(fù)正常運(yùn)行狀態(tài)。這樣可以實(shí)現(xiàn)容器的自動(dòng)恢復(fù)和高可用性。

以下是一個(gè)使用"HEALTHCHECK"指令的示例:

FROM ubuntu:latestHEALTHCHECK --interval=30s --timeout=10s --retries=3 CMD curl -f http://localhost/ || exit 1CMD [ "nginx" ]

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后使用"HEALTHCHECK"指令定義了容器的健康檢查命令。該命令使用"curl"命令發(fā)送HTTP請(qǐng)求來(lái)測(cè)試容器是否可以成功訪問(wèn)http://localhost/。如果請(qǐng)求失敗,則返回狀態(tài)碼1,這將被Docker守護(hù)進(jìn)程視為容器的健康檢查失敗。最后,使用"CMD"指令定義了容器啟動(dòng)時(shí)默認(rèn)執(zhí)行的命令,此例中為啟動(dòng)"nginx"服務(wù)。

總結(jié)來(lái)說(shuō),"HEALTHCHECK"指令用于定義容器的健康檢查命令,以檢查容器的健康狀態(tài)并實(shí)現(xiàn)自動(dòng)容器重啟功能。這有助于提高容器的可靠性和可用性。

ARG

在Dockerfile中,"ARG"指令用于定義構(gòu)建時(shí)的變量。這些變量可以在構(gòu)建過(guò)程中被引用,但在容器運(yùn)行時(shí)不可見。

使用"ARG"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

設(shè)置構(gòu)建時(shí)的參數(shù):通過(guò)使用"ARG"指令,可以設(shè)置構(gòu)建過(guò)程中的參數(shù)。這些參數(shù)可以在構(gòu)建過(guò)程中被引用,如設(shè)置環(huán)境變量、鏡像標(biāo)簽等。

可在構(gòu)建命令中傳遞參數(shù):構(gòu)建鏡像時(shí),可以通過(guò)命令行傳遞參數(shù)給"ARG"指令定義的變量。這樣可以在構(gòu)建過(guò)程中根據(jù)不同的參數(shù)值執(zhí)行不同的操作,使構(gòu)建過(guò)程更加靈活。

以下是一個(gè)使用"ARG"指令的示例:

FROM ubuntu:latestARG VERSION= APP_VERSION=$VERSION

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后使用"ARG"指令定義了一個(gè)名為"VERSION"的變量,并設(shè)置其默認(rèn)值為""。接下來(lái),使用"ENV"指令將這個(gè)變量的值賦給一個(gè)環(huán)境變量"APP_VERSION"。在構(gòu)建過(guò)程中,可以通過(guò)修改"ARG"指令定義的變量值,或者通過(guò)構(gòu)建命令傳遞參數(shù)來(lái)改變環(huán)境變量的值。

總結(jié)來(lái)說(shuō),"ARG"指令用于定義構(gòu)建時(shí)的變量,在構(gòu)建過(guò)程中可以根據(jù)這些變量執(zhí)行不同的操作,如設(shè)置環(huán)境變量、鏡像標(biāo)簽等。這增加了構(gòu)建過(guò)程的靈活性和可配置性。

EXPOSE

在Dockerfile中,"EXPOSE"指令用于聲明容器運(yùn)行時(shí)所監(jiān)聽的網(wǎng)絡(luò)端口。

使用"EXPOSE"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

聲明容器對(duì)外暴露的端口:通過(guò)使用"EXPOSE"指令,可以告訴Docker守護(hù)進(jìn)程容器將要監(jiān)聽的網(wǎng)絡(luò)端口。這樣,其他容器或主機(jī)可以通過(guò)網(wǎng)絡(luò)與該端口進(jìn)行通信。

僅作為文檔使用:"EXPOSE"指令還可以作為Dockerfile中的文檔說(shuō)明,用于指示容器設(shè)計(jì)者或使用者應(yīng)該將哪些端口暴露出來(lái)。

需要注意的是,"EXPOSE"指令并不會(huì)自動(dòng)在主機(jī)上映射這些端口,它只是聲明這些端口可以被容器監(jiān)聽。在運(yùn)行容器時(shí),可以使用"-p"或"-P"選項(xiàng)來(lái)映射容器內(nèi)部的某個(gè)端口到主機(jī)上,以使外部可以訪問(wèn)。

以下是一個(gè)使用"EXPOSE"指令的示例:

FROM nginx:latestEXPOSE 80 443

在這個(gè)示例中,選擇了一個(gè)基于最新版的nginx鏡像。然后,使用"EXPOSE"指令聲明容器將會(huì)監(jiān)聽80和443端口。這意味著其他容器或主機(jī)可以通過(guò)網(wǎng)絡(luò)與容器內(nèi)的這兩個(gè)端口進(jìn)行通信。

總結(jié)來(lái)說(shuō),"EXPOSE"指令用于聲明容器運(yùn)行時(shí)所監(jiān)聽的網(wǎng)絡(luò)端口,是一種向Docker守護(hù)進(jìn)程提供容器服務(wù)端口信息的方式。它并不會(huì)自動(dòng)在主機(jī)上映射這些端口,而是需要在運(yùn)行容器時(shí)使用"-p"或"-P"選項(xiàng)進(jìn)行端口映射。

ENV

在Dockerfile中,"ENV"指令用于設(shè)置容器中的環(huán)境變量。

使用"ENV"指令可以實(shí)現(xiàn)以下幾個(gè)功能:

定義容器中的環(huán)境變量:通過(guò)使用"ENV"指令,可以設(shè)置容器中的環(huán)境變量。這些環(huán)境變量可以在容器運(yùn)行時(shí)被訪問(wèn),供應(yīng)用程序使用。

傳遞構(gòu)建時(shí)的參數(shù):"ENV"指令還可以通過(guò)引用構(gòu)建時(shí)的參數(shù),將構(gòu)建時(shí)的參數(shù)值傳遞給容器中的環(huán)境變量。這樣可以在構(gòu)建過(guò)程中根據(jù)不同的參數(shù)值設(shè)置不同的環(huán)境變量。

以下是一個(gè)使用"ENV"指令的示例:

FROM ubuntu:latestENV VERSION= \ ? ?PORT=8080

在這個(gè)示例中,首先選擇了一個(gè)基礎(chǔ)鏡像,然后使用"ENV"指令定義了兩個(gè)環(huán)境變量,分別是"VERSION"和"PORT"。"VERSION"的值被設(shè)置為"","PORT"的值被設(shè)置為"8080"。在容器運(yùn)行時(shí),可以通過(guò)這兩個(gè)環(huán)境變量訪問(wèn)其值。

總結(jié)來(lái)說(shuō),"ENV"指令用于設(shè)置容器中的環(huán)境變量,可以在容器運(yùn)行時(shí)被訪問(wèn)。它可以用于定義靜態(tài)的環(huán)境變量,也可以通過(guò)引用構(gòu)建時(shí)的參數(shù)來(lái)設(shè)置動(dòng)態(tài)的環(huán)境變量。

ADD

在Dockerfile中,"ADD"指令用于將文件、目錄或遠(yuǎn)程URL添加到容器中。

"ADD"指令的作用包括:

將本地文件或目錄添加到容器中:可以使用"ADD"指令將主機(jī)上的文件或目錄添加到容器中。Docker會(huì)將這些文件或目錄復(fù)制到鏡像中的相應(yīng)位置。

ADD <src> <dest>

其中,""指定了主機(jī)上的文件或目錄路徑,""指定了容器中放置文件或目錄的路徑。如果""是一個(gè)目錄,那么將會(huì)把""中的內(nèi)容復(fù)制到""目錄下。

解壓縮文件:如果""是一個(gè)壓縮文件(例如.tar,.,.),Docker會(huì)自動(dòng)解壓縮該文件并將解壓后的內(nèi)容添加到容器中。

添加遠(yuǎn)程URL中的文件:可以使用"ADD"指令將來(lái)自遠(yuǎn)程服務(wù)器的文件添加到容器中。Docker會(huì)從遠(yuǎn)程URL下載文件,然后將其復(fù)制到鏡像中。

ADD <src>... <dest>

這種情況下,可以指定多個(gè)""參數(shù),每個(gè)參數(shù)都是一個(gè)URL地址,Docker會(huì)依次下載文件并將其添加到鏡像中。

需要注意的是,相對(duì)路徑的文件或目錄會(huì)相對(duì)于當(dāng)前的構(gòu)建上下文(通過(guò)docker build命令指定的目錄)進(jìn)行解析。同時(shí),使用"ADD"指令時(shí)會(huì)觸發(fā)Docker的緩存策略,只有當(dāng)""的內(nèi)容改變時(shí),Docker才會(huì)重新復(fù)制文件。

在實(shí)際使用中,"COPY"指令更常用于文件和目錄的復(fù)制操作,而"ADD"指令則主要用于需要自動(dòng)解壓縮或從遠(yuǎn)程URL下載文件的場(chǎng)景。

總結(jié)來(lái)說(shuō),"ADD"指令用于將文件、目錄或遠(yuǎn)程URL添加到容器中。它可以將主機(jī)上的文件或目錄復(fù)制到容器中,也可以解壓縮文件或從遠(yuǎn)程URL下載文件并添加到鏡像中。

COPY

在Dockerfile中,"COPY"指令用于將文件或目錄從主機(jī)復(fù)制到容器中。

"COPY"指令的作用包括:

復(fù)制本地文件或目錄到容器中:可以使用"COPY"指令將主機(jī)上的文件或目錄復(fù)制到容器中。Docker會(huì)將這些文件或目錄復(fù)制到鏡像中的相應(yīng)位置。

COPY <src> <dest>

其中,""指定了主機(jī)上的文件或目錄路徑,""指定了容器中放置文件或目錄的路徑。如果""是一個(gè)目錄,那么將會(huì)把""中的內(nèi)容復(fù)制到""目錄下。

復(fù)制文件或目錄的權(quán)限:使用"COPY"指令復(fù)制文件或目錄時(shí),Docker會(huì)保留這些文件或目錄的權(quán)限,并將其應(yīng)用于鏡像中的相應(yīng)文件或目錄。

需要注意的是,相對(duì)路徑的文件或目錄會(huì)相對(duì)于當(dāng)前的構(gòu)建上下文(通過(guò)docker build命令指定的目錄)進(jìn)行解析。同時(shí),使用"COPY"指令時(shí)會(huì)觸發(fā)Docker的緩存策略,只有當(dāng)""的內(nèi)容改變時(shí),Docker才會(huì)重新復(fù)制文件。

與"ADD"指令相比,"COPY"指令更適合簡(jiǎn)單的文件和目錄復(fù)制操作,不支持自動(dòng)解壓縮和從遠(yuǎn)程URL下載文件的功能。

以下是一個(gè)使用"COPY"指令的示例:

FROM ubuntu:latestCOPY /app/

在這個(gè)示例中,選擇了一個(gè)基礎(chǔ)鏡像,然后使用"COPY"指令將主機(jī)上的""文件復(fù)制到容器中的"/app/"路徑下。

總結(jié)來(lái)說(shuō),"COPY"指令用于將文件或目錄從主機(jī)復(fù)制到容器中。它可以用于復(fù)制本地文件或目錄,并保留權(quán)限。相對(duì)于"ADD"指令,"COPY"更適合簡(jiǎn)單的文件和目錄復(fù)制操作。

ENTRYPOINT

在Dockerfile中,"ENTRYPOINT"指令用于配置容器啟動(dòng)時(shí)要執(zhí)行的命令。

"ENTRYPOINT"指令的作用包括:

設(shè)置容器的默認(rèn)執(zhí)行命令:通過(guò)指定"ENTRYPOINT"指令,可以將容器的默認(rèn)執(zhí)行命令設(shè)置為特定的命令或腳本。這些命令在容器啟動(dòng)時(shí)會(huì)自動(dòng)執(zhí)行。

ENTRYPOINT ["command", "arg1", "arg2"]

在這個(gè)例子中,"command"是要執(zhí)行的命令,"arg1"和"arg2"是命令的參數(shù)??梢酝ㄟ^(guò)添加多個(gè)參數(shù)來(lái)指定命令的參數(shù)列表。

支持傳遞額外的參數(shù):使用"ENTRYPOINT"指令定義容器的默認(rèn)執(zhí)行命令后,可以在啟動(dòng)容器時(shí)傳遞額外的參數(shù)來(lái)修改默認(rèn)行為。傳遞的參數(shù)將作為默認(rèn)執(zhí)行命令的參數(shù)。

docker run --rm myimage extra-arg

在這個(gè)例子中,"extra-arg"是額外的參數(shù),它將作為默認(rèn)執(zhí)行命令的參數(shù)。

需要注意的是,"ENTRYPOINT"指令中使用的形式是JSON數(shù)組形式,而不是常規(guī)的命令行形式。這是因?yàn)镴SON數(shù)組形式可以避免由于特殊字符解析問(wèn)題引起的錯(cuò)誤,并允許更好地處理參數(shù)。

"ENTRYPOINT"指令還可以與"Dockerfile"中的其他指令(如"CMD")結(jié)合使用,以組合多個(gè)命令,并定義容器的啟動(dòng)命令和默認(rèn)參數(shù)。

以下是一個(gè)使用"ENTRYPOINT"指令的示例:

FROM ubuntu:latestENTRYPOINT ["echo"]CMD ["Hello, Docker!"]

在這個(gè)示例中,選擇了一個(gè)基礎(chǔ)鏡像,然后使用"ENTRYPOINT"指令將默認(rèn)執(zhí)行命令設(shè)置為"echo"命令,使用"CMD"指令將默認(rèn)參數(shù)設(shè)置為"Hello, Docker!"。當(dāng)容器啟動(dòng)時(shí),默認(rèn)執(zhí)行命令為"echo",并將"Hello, Docker!"作為參數(shù)傳遞。

總結(jié)來(lái)說(shuō),"ENTRYPOINT"指令用于配置容器啟動(dòng)時(shí)要執(zhí)行的命令,并可以支持傳遞額外的參數(shù)。它可以設(shè)置容器的默認(rèn)執(zhí)行命令,并與其他指令組合使用以定義容器的啟動(dòng)命令和默認(rèn)參數(shù)。

視頻學(xué)習(xí)地址:

關(guān)鍵詞:

精彩推送

公司

7月27日達(dá)茂旗那達(dá)慕大會(huì)開幕當(dāng)日,一場(chǎng)清晨的雨仿佛送來(lái)吉祥的祝福。

詳細(xì)>>

8月2日,2023年《財(cái)富》世界500強(qiáng)排行榜揭曉,今年共有4家四川本土企業(yè)

詳細(xì)>>

近日,為充分發(fā)揮金融支持山西加快建設(shè)內(nèi)陸地區(qū)對(duì)外開放新高地的積極作

詳細(xì)>>

看病難、掛號(hào)難,候診時(shí)間長(zhǎng)、就診時(shí)間短……提起看病就醫(yī),這些正是讓

詳細(xì)>>

記者從三峽集團(tuán)獲悉,位于海拔5000米以上的西藏措美哲古風(fēng)電場(chǎng)首批5臺(tái)

詳細(xì)>>

7月份,苯乙烯市場(chǎng)一改上半年頹勢(shì),走出一波觸底反彈行情,一舉突破800

詳細(xì)>>