docker安装 搭建私库 删除私库镜像 打印私库镜像 的shell脚本[通俗易懂]

docker安装 搭建私库 删除私库镜像 打印私库镜像 的shell脚本[通俗易懂]#!/bin/bash#本脚本可以打印私有镜像库中所有的镜像#私有镜像库地址HUB_URL=hub.dy.com:5000#取得所有私有镜像库的所有镜像IMAGESLIST=$(curl-shttp://${HUB_URL}/v2/_catalog)#echo${IMAGESLIST}#删除后2个字符IMAGESLIST=${IMAGESLIST::-2}#删除…

大家好,又见面了,我是你们的朋友全栈君。

1.安装docker shell脚本

#!/bin/bash

hub_docker="hub.dy.com"

yum install -y epel-release docker

sed -i "s#--selinux-enabled --log-driver=journald#--selinux-enabled=false --insecure-registry $hub_docker:5000 --log-driver=json-file --storage-driver=overlay2#g"  /etc/sysconfig/docker

# 开机自启
/usr/bin/systemctl daemon-reload
/usr/bin/systemctl enable docker
/usr/bin/systemctl start docker

2.私服的搭建 shell脚本

#!/bin/bash

docker pull registry

[ -d /home/registry ] || mkdir -p /home/registry
cat <<EOF >/home/registry/config.yml
version: 0.1
log:
  fields:
    service: registry
storage:
  delete:
    enabled: true
  cache:
    blobdescriptor: inmemory
  filesystem:
    rootdirectory: /var/lib/registry
http:
  addr: :5000
  headers:
    X-Content-Type-Options: [nosniff]
health:
  storagedriver:
    enabled: true
    interval: 10s
    threshold: 3
EOF

docker run -itd -v /home/registry/:/var/lib/registry/ -v /home/registry/config.yml:/etc/docker/registry/config.yml -p 5000:5000 --restart=always --privileged=true --name registry registry

3.删除私库里面的镜像 shell脚本

#!/bin/bash

docker_name="$1"
docker_tag="$2"
docker_hub_url="hub.dy.com:5000"
docker_registry_container_id=`docker ps |grep registry |awk '{print $1}'`

if [ "$docker_tag" = "" ]; then
	docker_tag="latest"
fi

#获取image的sha256
function get_docker_sha256(){
	docker pull $docker_hub_url/$docker_name:$docker_tag > /dev/null 2>&1    #先下载下来 获取sha256
	sha256=`docker inspect $docker_hub_url/$docker_name:$docker_tag | grep RepoDigests -A 5 | grep $docker_hub_url| grep sha256|awk -F '@' '{print $2}'|awk -F'"' '{print $1}'`
	#docker rmi  $docker_hub_url/$docker_name:$docker_tag		#然后删除本地镜像  是否删除
	echo $sha256
}

#删除镜像索引
function delete_images_index(){
    sha256=`get_docker_sha256`
	echo $sha256
	curl -I -X DELETE http://$docker_hub_url/v2/$docker_name/manifests/$sha256
}

#删除镜像数据
function delete_images_data(){
	docker exec -it $docker_registry_container_id registry garbage-collect /etc/docker/registry/config.yml 
}

function main()
{
	delete_images_index
	delete_images_data
	systemctl restart docker	#重启docker  否则再次push 已经删除的镜像会出错
}

main

4.打印私库里面的所有镜像 shell脚本

#!/bin/bash

#本脚本可以打印私有镜像库中所有的镜像
#私有镜像库地址
HUB_URL=hub.dy.com:5000
#取得所有私有镜像库的所有镜像
IMAGESLIST=$(curl -s http://${HUB_URL}/v2/_catalog)
#echo ${IMAGESLIST}
#删除后2个字符
IMAGESLIST=${IMAGESLIST::-2}
#删除前面17个字符
IMAGESLIST=${IMAGESLIST:17}
#echo ${IMAGESLIST}
#要将$a分割开,先存储旧的分隔符
OLD_IFS="$IFS"
#设置分隔符
IFS="," 
#如下会自动分隔
arr=($IMAGESLIST)

#遍历数组
for IMAGENAME in ${arr[@]}
do
	#去掉引号
	IMAGENAME=${IMAGENAME:1}
	IMAGENAME=${IMAGENAME::-1}
	#echo $IMAGENAME
	S1=$(curl -s http://${HUB_URL}/v2/${IMAGENAME}/tags/list)
	
	#取得[]中间的版本列表
	S1=${S1#*[}
	S1=${S1%]*} 
	#echo $S1
	
	arr1=($S1)
	#遍历数组
	for VAR in ${arr1[@]}
	do
		#去掉引号
		VAR=${VAR:1}
		VAR=${VAR::-1}
		echo $HUB_URL/$IMAGENAME:$VAR
	done
done

#恢复原来的分隔符
IFS="$OLD_IFS"
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161293.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • docker打开2375监听端口「建议收藏」

    docker打开2375监听端口「建议收藏」由于在使用caliper时,需要用到Docker的监听端口,所以此步骤如下:1、修改/usr/lib/systemd/system/docker.service,在[service]的ExecStart,添加-Htcp://0.0.0.0:2375ExecStart=/usr/bin/dockerd-Htcp://0.0.0.0:2375-Hfd://–containerd=/run/containerd/containerd.sock2、刷新配置文件,重启docker

    2022年5月26日
    245
  • 〖Docker指南②〗Docker常用命令汇总

    〖Docker指南②〗Docker常用命令汇总Docker常用命令汇总最新版|帮助命令|镜像命令|容器命令

    2026年1月19日
    7
  • docker部署web项目_docker到底怎么用

    docker部署web项目_docker到底怎么用前言前面我们运行的容器并没有一些什么特别的用处。接下来让我们尝试使用docker构建一个web应用程序。我们将在docker容器中运行一个PythonFlask应用来运行一个web

    2022年7月28日
    9
  • kafka集群搭建-docker版本[通俗易懂]

    kafka集群搭建-docker版本[通俗易懂]提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档kafka集群搭建文章目录kafka集群搭建前言一、kafka是什么?二、集群1.集群2.负载均衡3.扩容4.ZookeeperLeader选举kafka架构集群搭建下载安装zookeeper前言kafka是个高吞吐的消息中间件,为啥快啊?1顺序读写20拷贝3批量提交和批量ACK4分片和副本消息队列高可用就得用集群。提示:以下是本篇文章正文内容,下面案例可供参考一、kafka是什么?kafka理论参

    2022年5月2日
    86
  • docker下载安装教程_安卓安装docker

    docker下载安装教程_安卓安装docker前言Docker提供轻量的虚拟化,你能够从Docker获得一个额外抽象层,你能够在单台机器上运行多个Docker微容器,而每个微容器里都有一个微服务或独立应用,例如你可以将Tomcat运行在一个D

    2022年7月30日
    14
  • docker学习记录

    docker学习记录

    2022年2月9日
    49

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号