使用nexus配置内部helm存储库
注意事项
从 3.71.0 版本开始,Helm chart 只能上传到根仓库,不能上传到仓库里的子目录或子仓库。


点击左上角 Settings

点击 Repositories

点击 Create repository

选择 helm(hosted)

配置仓库相关信息
相关配置项说明
- Name : 仓库名称,唯一标识,例如
my-helm,后续helm repo add时会用到该仓库路径 - Online : 仓库是否启用
- 勾选 : 仓库可访问、可上传下载
- 不勾选 : 仓库离线,不接受请求
- Blob store : 存储位置,指定该仓库存储文件所在的 blob 存储,一般使用
default即可,除非你有多存储策略 - Strict Content Type Validation : 严格内容类型校验
- 勾选:只允许符合 Helm 包 MIME 类型的文件上传
- 不勾选:允许任何文件上传
- Deployment policy : 部署策略(是否允许覆盖上传)
Allow redeploy: 允许覆盖上传同版本 chartDisable redeploy: 不允许覆盖(推荐)Read-only: 只读
- Proprietary Components : 标记为私有组件,需要 Sonatype Nexus 防火墙
- Cleanup Policies : 清理策略,符合任何已应用策略的组件都将被删除


添加仓库
helm repo add nexus-helm \
https://nexus.pptfz.cn/repository/nexus-helm \
--username admin \
--password 'kdlkblk!1'
安装 Helm Push plugin
helm plugin install https://github.com/chartmuseum/helm-push
生 成chart
helm create demo1
打包chart
helm package demo1
推送chart
说明
推送语法为 helm push <chart_name_and_version>.tgz oci://<harbor_address>/<project>
helm push oci-chart-example-0.1.0.tgz oci://harbor.pptfz.cn/oci-charts
curl -u admin:admin \
--upload-file kong-3.0.0.tgz \
http://nexus.ops.com/repository/my-helm/kong-3.0.0.tgz
拉取chart
说明
拉取语法为 helm pull oci://<harbor_address>/<project>/<chart_name> --version <version>
::;
helm pull oci://harbor.pptfz.cn/oci-charts/demo1 --version 0.1.0

