docker實(shí)現(xiàn)批量下載pull?k8s鏡像并打標(biāo)簽tag、推送push至鏡像倉庫
docker批量下載pull k8s鏡像并打標(biāo)簽tag、推送push至鏡像倉庫
#!/bin/bash # set -eux; images=" nginx:1.19-alpine haproxy:2.3-alpine traefik:2.4.8 openresty/openresty:1.19.3.1-alpine envoyproxy/envoy:v1.16.2 osixia/keepalived:2.0.20 setzero/chrony:3.5 calico/typha:v3.19.1 calico/cni:v3.19.1 calico/node:v3.19.1 calico/kube-controllers:v3.19.1 calico/pod2daemon-flexvol:v3.19.1 calico/ctl:v3.19.1 jettech/kube-webhook-certgen:v1.5.1 kubernetesui/dashboard:v2.3.1 kubernetesui/metrics-scraper:v1.0.6 quay.io/coreos/flannel:v0.14.0 quay.io/jetstack/cert-manager-cainjector:v1.4.0 quay.io/jetstack/cert-manager-webhook:v1.4.0 quay.io/jetstack/cert-manager-controller:v1.4.0 k8s.gcr.io/kube-apiserver:v1.21.14 k8s.gcr.io/kube-controller-manager:v1.21.14 k8s.gcr.io/kube-scheduler:v1.21.14 k8s.gcr.io/kube-proxy:v1.21.14 k8s.gcr.io/pause:3.4.1 k8s.gcr.io/etcd:3.5.4-0 k8s.gcr.io/coredns/coredns:v1.8.0 k8s.gcr.io/ingress-nginx/controller:v0.47.0 k8s.gcr.io/metrics-server/metrics-server:v0.5.0 " dest_registry=${dest_registry:-'127.0.0.1:5000/kubeadm-ha'} for image in $images ; do docker pull --platform ${1:-'linux/amd64'} $image count=$(echo $image | grep -o '/*' | wc -l) if [[ $count -eq 0 ]]; then dest=$dest_registry/$image elif [[ $count -eq 1 ]]; then if [[ $image =~ 'k8s.gcr.io' ]]; then dest=$dest_registry/$(echo ${image#*/} | sed 's / _ g') else dest=$dest_registry/$(echo ${image} | sed 's / _ g') fi else if [[ $image =~ 'coredns' ]]; then dest=$dest_registry/$(echo ${image##*/} | sed 's / _ g') else dest=$dest_registry/$(echo ${image#*/} | sed 's / _ g') fi fi docker tag $image $dest docker push $dest done
這個Bash腳本的主要功能是從公共鏡像倉庫拉取多個Kubernetes相關(guān)鏡像,重新打標(biāo)簽后推送到本地或私有的Docker鏡像倉庫。
以下是詳細(xì)解釋:
腳本結(jié)構(gòu)解析
Shebang與調(diào)試選項
#!/bin/bash # set -eux;
#!/bin/bash
:指定使用Bash解釋器。set -eux
(注釋狀態(tài)):若啟用,會開啟嚴(yán)格模式(報錯退出)、打印變量展開和命令執(zhí)行日志,用于調(diào)試。
鏡像列表
images=" nginx:1.19-alpine haproxy:2.3-alpine ... k8s.gcr.io/ingress-nginx/controller:v0.47.0 "
- 定義了一系列鏡像地址,涵蓋Kubernetes核心組件(如
kube-apiserver
)、網(wǎng)絡(luò)插件(如calico
、flannel
)、工具(如cert-manager
、dashboard
)等。
目標(biāo)倉庫設(shè)置
dest_registry=${dest_registry:-'127.0.0.1:5000/kubeadm-ha'}
- 目標(biāo)鏡像倉庫地址,默認(rèn)為本地倉庫
127.0.0.1:5000/kubeadm-ha
,可通過環(huán)境變量dest_registry
覆蓋。
主循環(huán)處理鏡像
for image in $images ; do docker pull --platform ${1:-'linux/amd64'} $image ... done
遍歷所有鏡像,執(zhí)行以下操作:
- 拉取鏡像:
docker pull --platform
指定平臺(默認(rèn)為linux/amd64
)。 - 計算路徑層級:通過斜杠數(shù)量(
count
)判斷鏡像路徑結(jié)構(gòu)。 - 生成目標(biāo)標(biāo)簽:根據(jù)路徑結(jié)構(gòu)調(diào)整鏡像名稱,適應(yīng)目標(biāo)倉庫格式。
- 重新打標(biāo)簽并推送:
docker tag
和docker push
。
鏡像標(biāo)簽處理邏輯
根據(jù)鏡像路徑的斜杠數(shù)量(count
),分三種情況生成目標(biāo)標(biāo)簽:
無斜杠(count=0
)
- 鏡像名直接拼接至目標(biāo)倉庫。
- 示例:
nginx:1.19-alpine
→127.0.0.1:5000/kubeadm-ha/nginx:1.19-alpine
一個斜杠(count=1
)
- 來自
k8s.gcr.io
的鏡像:去除倉庫前綴,剩余部分拼接。 - 示例:
k8s.gcr.io/kube-apiserver:v1.21.14
→kubeadm-ha/kube-apiserver:v1.21.14
- 其他鏡像:將斜杠替換為下劃線。
- 示例:
calico/typha:v3.19.1
→kubeadm-ha/calico_typha:v3.19.1
多個斜杠(count≥2
)
- 包含
coredns
的鏡像:取最后一段路徑。 - 示例:
k8s.gcr.io/coredns/coredns:v1.8.0
→kubeadm-ha/coredns:v1.8.0
- 其他鏡像:去除第一個斜杠前的倉庫前綴,剩余斜杠替換為下劃線。
- 示例:
quay.io/coreos/flannel:v0.14.0
→kubeadm-ha/coreos_flannel:v0.14.0
關(guān)鍵命令說明
拉取鏡像
docker pull --platform ${1:-'linux/amd64'} $image
--platform
:指定鏡像架構(gòu)(如linux/arm64
),需鏡像支持多平臺。
處理標(biāo)簽邏輯
docker tag $image $dest docker push $dest
- 根據(jù)生成的
$dest
標(biāo)簽推送鏡像到目標(biāo)倉庫。
使用場景
- 離線環(huán)境部署:在內(nèi)網(wǎng)中搭建私有鏡像倉庫,預(yù)先拉取并推送所有依賴鏡像。
- 統(tǒng)一鏡像來源:將分散在多個倉庫的鏡像集中管理,避免依賴外部網(wǎng)絡(luò)。
- 解決拉取限制:規(guī)避從
k8s.gcr.io
等倉庫拉取鏡像的網(wǎng)絡(luò)問題。
注意事項
Sed命令潛在問題
- 腳本中
sed 's / _ g'
應(yīng)為sed 's/\//_/g'
,否則無法正確替換斜杠。
鏡像多平臺支持
- 需確保目標(biāo)鏡像支持指定的平臺(如
linux/amd64
或linux/arm64
)。
本地倉庫配置
- 需提前部署Docker Registry服務(wù)(如
docker run -d -p 5000:5000 --name registry registry:2
)。
示例執(zhí)行
假設(shè)目標(biāo)倉庫為 192.168.1.100:5000/myrepo
,執(zhí)行命令:
dest_registry=192.168.1.100:5000/myrepo ./script.sh linux/amd64
所有鏡像將被拉取、重新打標(biāo)簽,并推送至 192.168.1.100:5000/myrepo
。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Docker運(yùn)行Nacos容器自動退出問題的解決方法
使用Docker運(yùn)行Nacos容器的時候發(fā)現(xiàn)總是自動退出。Nacos日志里面沒有明顯的報錯信息。查了一下是內(nèi)存溢出錯誤,怎么處理呢,下面小編給大家介紹下Docker運(yùn)行Nacos容器自動退出問題及解決方法,需要的朋友可以參考下2022-07-07Docker daemon 無法啟動: does not match with stored UUID錯誤解決辦法
這篇文章主要介紹了Docker daemon 無法啟動: does not match with stored UUID錯誤解決辦法的相關(guān)資料,需要的朋友可以參考下2016-11-11數(shù)據(jù)卷(Data Volumes)及dockefile詳解
在生產(chǎn)環(huán)境中使用Docker,往往需要對數(shù)據(jù)進(jìn)行持久化,或者需要在多個容器之間進(jìn)行數(shù)據(jù)共享,這必然涉及容器的數(shù)據(jù)管理操作,今天給大家介紹下數(shù)據(jù)卷(Data Volumes)及dockefile的相關(guān)知識,感興趣的朋友一起看看吧2023-01-01docker images本地遷移的實(shí)現(xiàn)
這篇文章主要介紹了docker images本地遷移的實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03在docker創(chuàng)建的mysql容器中如何執(zhí)行mysql腳本
在Docker容器中執(zhí)行MySQL腳本的步驟包括進(jìn)入容器、連接MySQL服務(wù)并執(zhí)行腳本,如果腳本在主機(jī)上,可以直接通過命令執(zhí)行,無需進(jìn)入容器2024-11-11