docker中的映像會自動更新;可以利用Watchtower工具來自動更新映像,Watchtower是一個可以監控正在運行的容器映像是否更新的工具,當本地映像與遠端映像有差異的時候,可以自動使用目前容器的運行參數以新鏡像重新建立新的容器,並刪除舊的容器。
本教學操作環境:linux7.3系統、docker19.03版、Dell G3電腦。
docker映像自動更新
watchtower 是一個可以監控正在運行的容器映像是否有更新的工具,當本地映像與遠端映像有差異的時候,可以自動使用當前容器的運行參數以新鏡像重新建立一個新的容器,並刪除舊的容器。
在使用Docker時有的映像可能需要經常更新,通常是手動更新容器比較繁瑣,需要四個步驟:
1.停止容器docker stop
2.刪除容器docker rm
3.檢查映像更新情況,更新映像 docker pull
4.重新啟動容器docker run ……
容器較少還比較好如果有大量容器需要更新,那將會產生巨大的工作量。現在為大家介紹一種自動更新容器的方式,該方法同樣適用於群暉下的Docker。
Watchtower 會監視運行容器並監視這些容器最初啟動時的映像是否需要更新。當 Watchtower 偵測到一個鏡像已經有變動時,它會使用新鏡像,使用相同的參數自動重新啟動對應的容器。同時 Watchtower 本身也被包裝成 Docker 映像,用一行指令即可使用 Watchtower 監控所有容器,然後所有容器都會自動更新,當然也包括 Watchtower 本身。
快速開始
Watchtower 本身被打包為Docker 映像,因此可以像運行任何其他容器一樣運行它,其他的Docker環境下使用Docker命令直接下載映像:
docker pull containrrr/watchtower
群暉中的Docker可以直接到註冊表搜尋下載:
其他Docker執行指令
docker run -d \ --name watchtower \ -v /var/run/docker.sock:/var/run/docker.sock \
用上面的程式碼即可在背景啟動watchtower 容器,並監控目前所有鏡像的更新情況。因為 watchtower 需要與 Docker API 進行互動以監控正在運行的容器,所以在使用時需要加上 -v 參數將 /var/run/docker.sock 對應到容器內。
在群暉中使用群暉的計劃任務運行watchtower
打開群暉任務計劃,新建一個計劃任務-用戶自訂腳本,填入以下腳本,運行一次,更新所有的容器,並清除舊的容器
docker run -d --name watchtower -v /var/run/docker.sock:/var/run/docker.sock containrrr/watchtower --cleanup --run-once
可以在計劃任務中設定自動運行,或者需要的時候手動運行一次。然後所有容器都會自動更新,也包括 Watchtower 本身。
選項參數
預設情況下,watchtower 將監視它所指向的 Docker 守護程式內執行的所有容器。但你也可以在啟動 watchtower 時指定特定容器的名稱,從而只監視那幾個特定的容器。例如:
docker run -d --name watchtower -v /var/run/docker.sock:/var/run/docker.sock containrrr/watchtower --cleanup --run-once nginx redis
這時 watchtower 將只監視名為「nginx」和「redis」的容器,所有其他正在運行的容器將被忽略。如果你不想把 watchtower 放在後台運行,你可以加入 --run-once 參數,watchtower 容器將在前台執行。
使用--cleanup 參數在更新後自動刪除舊的鏡像
使用--monitor-only 將僅監控新鏡像並發送通知,不會更新容器
使用--interval 設定設更新偵測時間間隔,單位為秒。例如每隔 1 小時檢查一次更新則為 --interval 3600
更多具體的使用方式可以查看watchtower 的官方文檔,此處只列出了常用的兩種方式。群暉因為可以使用自動排程任務可以不使用--interval參數。
推薦學習:《docker影片教學》
以上是docker中的映像會自動更新嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Docker簡化開發和運維流程的方式包括:1)提供一致的環境,確保應用程序在不同環境中一致運行;2)通過Dockerfile和鏡像構建優化應用程序部署;3)使用DockerCompose管理多個服務。 Docker通過容器化技術實現這些功能,但使用過程中需注意鏡像構建、容器啟動和網絡配置等常見問題,並通過鏡像優化和資源管理提升性能。

Docker和Kubernetes的關係是:Docker用於打包應用,Kubernetes用於編排和管理容器。 1.Docker通過容器技術簡化應用打包和分發。 2.Kubernetes管理容器,確保高可用性和可擴展性。它們結合使用可提升應用部署和管理效率。

Docker通過容器技術解決了軟件在不同環境中運行一致性的問題。其發展歷程從2013年至今,推動了雲計算生態系統的演進。 Docker利用Linux內核技術實現進程隔離和資源限制,提高了應用的可移植性。在開發和部署中,Docker提升了資源利用率和部署速度,支持DevOps和微服務架構,但也面臨鏡像管理、安全性和容器編排的挑戰。

Docker和虛擬機各有優缺點,選擇應根據具體需求。 1.Docker輕量、快速,適合微服務和CI/CD,啟動快,資源佔用少。 2.虛擬機提供高隔離性和多操作系統支持,但資源消耗大,啟動慢。

Docker架構的核心概念是容器和鏡像:1.鏡像是容器的藍圖,包含應用及其依賴。 2.容器是鏡像的運行實例,基於鏡像創建。 3.鏡像由多個只讀層組成,容器運行時添加可寫層。 4.通過Linux命名空間和控制組實現資源隔離和管理。

Docker通過容器化技術簡化了應用程序的構建、部署和運行。 1)Docker是一個開源平台,使用容器技術打包應用及其依賴,確保跨環境一致性。 2)鏡像和容器是Docker的核心,鏡像為應用的可執行包,容器為鏡像的運行實例。 3)Docker的基本用法如運行Nginx服務器,高級用法如使用DockerCompose管理多容器應用。 4)常見錯誤包括鏡像下載失敗和容器啟動失敗,調試技巧包括查看日誌和檢查端口。 5)性能優化和最佳實踐包括鏡像優化、資源管理和安全性提升。

使用Kubernetes和Docker部署容器化應用的步驟包括:1.構建Docker鏡像,使用Dockerfile定義應用鏡像並推送到DockerHub。 2.在Kubernetes中創建Deployment和Service來管理和暴露應用。 3.使用HorizontalPodAutoscaler實現動態擴展。 4.通過kubectl命令調試常見問題。 5.優化性能,定義資源限制和請求,並使用Helm管理配置。

Docker是一個開源平台,用於開發、打包和運行應用程序,通過容器化技術解決應用在不同環境中的一致性問題。 1.構建鏡像:通過Dockerfile定義應用環境和依賴,使用dockerbuild命令構建。 2.運行容器:使用dockerrun命令從鏡像啟動容器。 3.管理容器:通過dockerps、dockerstop、dockerrm等命令管理容器生命週期。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1
強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器