k8s--如何将chart包托管至harbor

简介: k8s--如何将chart包托管至harbor

@TOC


前言

本次通过给harbor添加插件来实现这个功能,后面还有Windows,liunx版本如何进行上传下载的方法

本次使用的为harbor2.5.3版本,是低版本
harbor高版本和低版本添加插件不一致
注意区分

应用

环境

虚拟机

Ip 主机名 cpu 内存 硬盘
192.168.10.11 master01 2cpu双核 4G 100G
192.168.10.12 worker01 2cpu双核 4G 100G
192.168.10.13 worker02 2cpu双核 4G 100G
192.168.10.18 harbor 1cpu一核心 2G 100G

若内存不足12,13可调至2G

版本 centos7.9
已部署k8s-1.27

将chart包托管至harbor

一.master节点安装helm

具体命令解释请看
链接: k8s学习--helm的详细解释及安装和常用命令

wget https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz
tar xf helm-v3.13.2-linux-amd64.tar.gz
mv linux-amd64/helm /usr/bin/
helm version
helm repo add stable http://mirror.azure.cn/kubernetes/charts/
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo update
helm repo list

二.安装harbor

1.docker-ce安装
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
 yum -y install docker-ce
 systemctl enable --now docker
2.docker-compose安装
wget https://github.com/docker/compose/releases/download/1.25.0/docker-compose-Linux-x86_64
mv docker-compose-Linux-x86_64 /usr/bin/docker-compose
chmod +x /usr/bin/docker-compose
docker-compose version
3.harbor服务器安装

需要vpn
此版本为v2.5.3

 https://github.com/goharbor/harbor/releases/download/v2.5.3/harbor-offline-installer-v2.5.3.tgz
 tar xf harbor-offline-installer-v2.5.3.tgz
 mv harbor /usr/local/harbor
 cd /usr/local/harbor
 mv harbor.yml.tmpl harbor.yml
  vim harbor.yml

需要做的事
改hostname
将https部分注释掉
image.png

docker load -i harbor.v2.5.3.tar.gz
./prepare

如果提示路由转发那就说明没有开启,开启即可

echo "net.ipv4.ip_forward=1" >> /etc/sysctl
sysctl -p
/install.sh -h

会出现说明
按照说明添加即可

./install.sh --with-chartmuseum

出现报错说明harbor版本不对
重新安装

宿主机浏览器查看
访问 192.168.10.18

默认账户

admin

默认密码

Harbor12345

登录即可
image.png

可以看到比普通Harbor多了一条Helm Chart数目
image.png

点击新建项目
image.png

创建一个名称为nginx的项目,用来测试使用
image.png

可以看到创建成功了
image.png

三.windows上传下载操作

1.上传

在桌面放一个charts包
image.png

回到页面,点击nginx
image.png

选择Helm Charts,点击上传
image.png

点击第一个选择问及那,选择桌面上的文件,上传
image.png

可以看到上传成功了
image.png

2.下载操作

点击这个chart包,再点击下载
image.png

就会自动下载了
image.png

四.linux上传下载

1. 添加helm仓库并查看
helm repo add harborhelm http://192.168.10.18/chartrepo/nginx --username admin --password Harbor12345
helm repo list

可以看到已经成功添加到库
image.png

2. 安装chart包

先搜索

helm search repo helm-nginx

可以看到搜索到了
image.png

安装chart包

helm install helm-nginx-test harborhelm/helm-nginx

查看chart包

 helm ls

image.png

3. 安装helmpush插件实现上传

在线安装helmpush

helm plugin install https://github.com/chartmuseum/helm-push

查看一下

ls /root/.local/share/helm/plugins/helm-push/bin/

image.png

将chart包push到harbor
首先先将chart包下载到本地并解压并cd到解压后的文件内

mkdir charts && cd charts
helm pull  harborhelm/helm-nginx
tar xf helm-nginx-1.1.0.tgz 
cd helm-nginx/

也可以通过其他chart包解包修改版本信息后,重新生成新版本

vim Chart.yaml

我这里更改的是版本
更改前
image.png

更改后
image.png

退出,然后制作chart包

helm package .

image.png

查看

ls

image.png

最后上传即可

helm cm-push --username admin --password Harbor12345 helm-nginx-1.1.1.tgz harborhelm

回到页面刷新查看
可以看到版本已经是2了
image.png

点击
image.png

可以看到两个版本
image.png

完成
如果对您有帮助可以关注一下

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
Kubernetes 应用服务中间件 nginx
提升K8S故障排除效率:详解Pod内抓包的高效策略!
提升K8S故障排除效率:详解Pod内抓包的高效策略!
575 0
|
6月前
|
Kubernetes Shell Windows
【Azure K8S | AKS】在AKS的节点中抓取目标POD的网络包方法分享
在AKS中遇到复杂网络问题时,可通过以下步骤进入特定POD抓取网络包进行分析:1. 使用`kubectl get pods`确认Pod所在Node;2. 通过`kubectl node-shell`登录Node;3. 使用`crictl ps`找到Pod的Container ID;4. 获取PID并使用`nsenter`进入Pod的网络空间;5. 在`/var/tmp`目录下使用`tcpdump`抓包。完成后按Ctrl+C停止抓包。
218 12
|
11月前
|
Kubernetes JavaScript 前端开发
k8s学习--chart包开发(创建chart包)
k8s学习--chart包开发(创建chart包)
574 1
|
11月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--k8s集群使用容器镜像仓库Harbor
本文介绍了在CentOS 7.9环境下部署Harbor容器镜像仓库,并将其集成到Kubernetes集群的过程。环境中包含一台Master节点和两台Node节点,均已部署好K8s集群。首先详细讲述了在Harbor节点上安装Docker和docker-compose,接着通过下载Harbor离线安装包并配置相关参数完成Harbor的部署。随后介绍了如何通过secret和serviceaccount两种方式让Kubernetes集群使用Harbor作为镜像仓库,包括创建secret、配置节点、上传镜像以及创建Pod等步骤。最后验证了Pod能否成功从Harbor拉取镜像运行。
1208 0
|
运维 Kubernetes Cloud Native
Kubernetes云原生问题之在托管Kubernetes服务中云服务商和用户的运维责任划分如何解决
Kubernetes云原生问题之在托管Kubernetes服务中云服务商和用户的运维责任划分如何解决
84 3
|
Kubernetes 容器
Kubernetes(K8S) helm chart
Kubernetes(K8S) helm chart
105 1
|
Kubernetes 算法框架/工具 Docker
k8s拉取harbor仓库镜像
k8s拉取harbor仓库镜像
887 5
|
Kubernetes 容器 Perl
在K8S中,请问harbor的secret创建能否直接创建资源清单?
在K8S中,请问harbor的secret创建能否直接创建资源清单?
|
存储 Kubernetes 数据安全/隐私保护
在K8S中,如何下载harbor的私有项目镜像?
在K8S中,如何下载harbor的私有项目镜像?
|
Kubernetes 容器 Perl
[k8s]使用私有harbor镜像源
[k8s]使用私有harbor镜像源
150 0

推荐镜像

更多