skopeo使用

已删除用户
发布于 2023-10-09 / 173 阅读 / 0 评论 / 0 点赞

skopeo使用

skopeo 命令

1. skopeo 命令安装

1.1 centos7 安装skopeo

yum install skopeo -y

1.2 ubuntu 安装skopeo

# Ubuntu 20.10 and newer
sudo apt-get -y update
sudo apt-get -y install skopeo


# Ubuntu 20.04
. /etc/os-release
echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_${VERSION_ID}/ /" | sudo tee /etc/apt/sources.list.d/devel:kubic:libcontainers:stable.list
curl -L https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_${VERSION_ID}/Release.key | sudo apt-key add -
sudo apt-get update
sudo apt-get -y upgrade
sudo apt-get -y install skopeo

1.3 二进制下载地址

curl -fL "https://pixiupkg-generic.pkg.coding.net/pixiu/k8stoolsdefault/skopeo?version=latest" -o skopeo

2. skopeo 使用

2.1 拉取镜像

skopeo copy docker://<源镜像> dir:<目标目录>

# 案例
skopeo copy docker://nginx:latest dir:/tmp/nginx


skopeo 拉取镜像并打成 tar包

# 案例
skopeo copy docker://nginx:latest docker-archive:/tmp/nginx.tar
  • 拉取 名为 nginx的最新镜像,并存储至 /tmp/nginx 目录中
  • 拉取名为nginx的最新镜像,并保存 为 /tmp/nginx.tar
  • --src-creds="用户名:密码"

2.2 推送镜像

skopeo copy dir:<源目录> docker://<目标镜像>

# 案例
skopeo copy dir:/tmp/nginx docker://shujiangle/nginx:latest
  • 将 /tmp/nginx 目录中的镜像推送到 远程 目录为shujiangle 的docker镜像仓库,并命名为 “nginx:latest"

2.3 转换镜像,并推送

skopeo copy docker://<源镜像> docker://<目标镜像>

# 案例
skopeo copy docker://docker.io/nginx:latest docker://quay.io/myrepo/nginx:latest
  • 将从 Docker Hub 拉取名为 "nginx" 的最新版本镜像,并将其推送到 quay.io 上名myrepo的镜像仓库

2.4 skopeo 不指定https 推送

skopeo copy --src-tls-verify=false --dest-tls-verify=false docker://docker.io/nginx:latest docker://quay.io/myrepo/nginx:latest
  • Skopeo 命令中使用 HTTP 连接而不是 HTTPS,请使用 --src-tls-verify=false 和 --dest-tls-verify=false 参数禁用 TLS 连接的验证

2.5 skopeo 推送tar包至镜像仓库

skopeo copy --dest-tls-verify=false docker-archive:/path/to/local.tar docker://<registry>/<image>:<tag>
  • /path/to/local.tar 是本地 Tar 包的路径。
  • 是目标镜像仓库的地址。
  • 是要创建的镜像名称。
  • 是要为镜像设置的标签。
  • --dest-tls-verify 参数禁用 TLS 连接的验证

3. skopeo policy 设置

cat > policy.json <<\EOF
{
    "default": [
        {
            "type": "insecureAcceptAnything"
        }
    ],
    "transports":
        {
            "docker-daemon":
                {
                    "": [{"type":"insecureAcceptAnything"}]
                }
        }
}
EOF
  • skopeo 中使用的时候,需要设置 --policy=policy.json

4. 批量推送镜像到镜像仓库脚本

#!/bin/bash

# 设置镜像仓库地址和凭据(如果需要认证)
registry="192.168.17.28:58001"
username="admin"
password="admin123"

# 获取当前时间
current_time=$(date +"%T")

# 获取push镜像名
imagename=$()

for i in $(ls *tar|sort -h)
do
    basename=$(basename "$i" .tar)
    # 获取镜像名
    imagename=${basename%%_*}

    # 获取镜像版本
    imagetag=${basename#*_}
    
    echo -e "\e[34m当前时间: $current_time\e[0m   正在推送 $registry/k8simage/$imagename:$imagetag 镜像............."
    skopeo copy --policy=policy.json --src-tls-verify=false --dest-tls-verify=false  --dest-creds="$username:$password" docker-archive:"$i"  "docker://$registry/k8simage/$imagename:$imagetag"

   if [ $? -eq 0 ]; then
    echo -e "\e[33m成功推送 $registry/k8simage/$imagename:$imagetag 镜像\e[0m"
  else
    echo -e "\e[31m推送 $registry/k8simage/$imagename:$imagetag 到镜像仓库失败\e[0m"
   fi
done