当前位置: 首页 > news >正文

k8s:安装 Helm 私有仓库ChartMuseum、helm-push插件并上传、安装Zookeeper

        ChartMuseum 是 Kubernetes 生态中用于存储、管理和发布 Helm Charts 的开源系统,主要用于扩展 Helm 包管理器的功能
核心功能
‌集中存储‌:提供中央化仓库存储Charts,支持版本管理和权限控制。 ‌
‌跨集群部署‌:支持多集群环境下共享Charts,简化部署流程。 ‌
‌离线部署‌:适配无网络环境,可将Charts存储在本地或局域网内。 ‌
‌HTTP接口‌:通过HTTP协议提供服务,用户可通过Helm客户端上传、下载及搜索Charts。 ‌

1.docker启动ChartMuseum

docker run -d \

  --name chartmuseum \

  -p 8080:8080 \

  -v $(pwd)/charts:/charts \

  -e STORAGE=local \

  -e STORAGE_LOCAL_ROOTDIR=/charts \

  chartmuseum/chartmuseum:latest

-v $(pwd)/charts:/charts:将当前目录下的 charts/ 文件夹作为存储路径。

1.1给charts文件夹权限


chmod -R 777 /app/KubeSphere/charts 

 

2.添加私有仓库到 Helm 客户端

在你的 Helm 客户端机器上执行:

helm repo add sinopsrepo http://172.23.123.117:8080

helm repo list

3.安装 helm-push 插件

    cm-push 是一个 Helm 插件,允许你将本地 .tgz 格式的 Helm Chart 包上传到 ChartMuseum 或兼容的 Helm 仓库服务器(如 Harbor、Nexus、Jfrog Artifactory 等)

下载地址

 

https://github.com/chartmuseum/helm-push/releases/download/v0.10.4/helm-push_0.10.4_linux_amd64.tar.gz

3.1解压 

#tar -zxvf helm-push_0.10.4_linux_amd64.tar.gz

 

3.2查看 Helm Home(插件安装路径)

HELM_PLUGINS_DIR=$(helm env | grep HELM_PLUGINS | cut -d '=' -f2 | tr -d '"')

[root@master bin]# echo $HELM_PLUGINS_DIR

 

 

3.3创建插件目录

mkdir -p "$HELM_PLUGINS_DIR/helm-push"

把下载好的 helm-push 放在"$HELM_PLUGINS_DIR/helm-push" 并解压
#tar -zxvf helm-push_0.10.4_linux_amd64.tar.gz
解压后包括/bin/helm-cm-push及plugin.yaml

3.4赋予可执行权限

chmod +x "$HELM_PLUGINS_DIR/helm-push/bin/helm-cm-push"

3.5验证插件

helm plugin list

4.上传zookeeper到 Chart


helm cm-push zookeeper-13.8.4.tgz  sinopsrepo 

​​​​​​​5.查看私有仓库的组件

helm repo update(如果不执行该行代码,会导致最新上传的chart看不到)

helm search repo sinopsrepo

 

6.私有仓库安装 Helm Chart

helm repo update

 helm install zookeeper  sinopsrepo/zookeeper --version 13.8.4


7卸载


helm uninstall my-zookeeper

8.参数详解

⚙️ 通用设置

参数环境变量含义
--access-token stringHELM_REPO_ACCESS_TOKEN使用 Token 认证时提供访问令牌(例如 GitHub Personal Access Token)。
-a, --app-version string-覆盖 Chart 中的 appVersion 字段。
--auth-header stringHELM_REPO_AUTH_HEADER自定义认证请求头字段名称。
--ca-file stringHELM_REPO_CA_FILE指定 CA 证书文件路径,用于验证 HTTPS 服务器。
--cert-file stringHELM_REPO_CERT_FILE客户端 SSL 证书文件路径(用于双向 TLS)。
--check-helm-version-输出当前使用的 Helm 主版本号(2 或 3)。
--context-path stringHELM_REPO_CONTEXT_PATHChartMuseum 的上下文路径(如 /charts)。
--debug-开启调试模式,显示更详细的日志信息。
-d, --dependency-update-打包前更新依赖项(从 requirements.yaml 到 charts/ 目录)。
-f, --force-即使远程仓库已存在相同版本也强制推送。
-h, --help-显示帮助信息。

🏠 Helm 配置目录

参数默认值含义
--home string/root/.helm设置 Helm 的配置根目录(可覆盖环境变量 $HELM_HOME)。

🛡️ Tiller 设置(Helm 2 特有)

Helm 3 已移除 Tiller,以下参数主要用于兼容旧 Helm 2 行为。

参数默认值含义
--host string-Tiller 地址(若使用 Helm 2)。
--tiller-namespace stringkube-systemTiller 所在命名空间。
--tiller-connection-timeout int300 秒连接 Tiller 的超时时间。

🔐 HTTPS 和认证相关

参数环境变量含义
--insecureHELM_REPO_INSECURE忽略 HTTPS 证书校验(适用于自签名证书)。
--key-file stringHELM_REPO_KEY_FILE客户端 SSL 密钥文件路径(用于双向 TLS)。
--keyring string-GPG 公钥环路径(默认:~/.gnupg/pubring.gpg)。
-p, --password stringHELM_REPO_PASSWORDHTTP Basic Auth 密码。
-u, --username stringHELM_REPO_USERNAMEHTTP Basic Auth 用户名。

🕒 超时控制

参数默认值含义
-t, --timeout int30 秒等待 ChartMuseum 响应的最大时间(秒)。

📦 Chart 元数据覆盖

参数含义
-v, --version string覆盖 Chart 的版本号(version 字段)。
http://www.xdnf.cn/news/1099513.html

相关文章:

  • 快速分页wpf
  • 解锁localtime:使用技巧与避坑指南
  • 深度学习中的常见损失函数详解及PyTorch实现
  • 初学者对编译和链接的学习笔记(含预编译详解)
  • c++-内部类
  • 网络安全初级
  • python正则表达式(小白五分钟从入门到精通)
  • 技术学习_检索增强生成(RAG)
  • 客户频繁问询项目进度,如何提高响应效率
  • STM32中DMA(直接存储器访问)详解
  • 基于 SpringBoot + Vue 的 IT 技术交流和分享平台的设计与实现
  • Git保姆级入门实战:从安装配置到常用命令与常见错误解决
  • 机器学习 YOLOv5手绘电路图识别 手绘电路图自动转换为仿真软件(如LT Spice)可用的原理图,避免人工重绘
  • upload-labs靶场通关详解:第21关 数组绕过
  • H5微应用四端调试工具—网页版:深入解析与使用指南
  • Java 枚举详解:从基础到实战,掌握类型安全与优雅设计
  • 青岛门卫事件后:高温晕厥救援技术突破
  • Transformer:自注意力驱动的神经网络革命引擎
  • PLC框架-1.3.2 报文750控制汇川伺服的转矩上下限
  • 位运算算法题
  • arm架构,arm内核,处理器之间的关系
  • STM32F103之ModBus\RS232\RS422\RS485
  • 记录今天学习Comfyui的感受
  • 【运维架构】云计算运维架构师与基础设施,技术路线,Linux证书(标准化/定制化/CNCF,公有云/混合云/私有云)
  • pharokka phold--快速噬菌体注释工具
  • 1.1.1数据类型与变量——AI教你学Django
  • 一文讲清楚React Hooks
  • Spring for Apache Pulsar->Reactive Support->Quick Tour
  • 【C++】——类和对象(上)
  • C语言<数据结构-链表>