【云原生】Helm应用商店

【云原生】Helm应用商店

一、简介

一个应用:(比如博客程序,wordpress+mysql),自己得写很多东西

  • Deployment.yaml
  • Service.yaml
  • PVC.yaml
  • Ingress.yaml
  • ...

二、安装Helm

https://helm.sh/zh/docs/v3/intro/install

每个Helm 版本都提供了各种操作系统的二进制版本,这些版本可以手动下载和安装。

  1. 下载合适K8s的版本 :wget https://get.helm.sh/helm-v3.5.4-linux-amd64.tar.gz
  2. 解压(tar -zxvf helm-v3.5.4-linux-amd64.tar.gz)
  3. 在解压目录中找到helm程序,移动到需要的目录中(mv linux-amd64/helm /usr/local/bin/helm)
  4. 给权限:chmod +x /usr/local/bin/helm

三、入门使用

1、三大概念

  • Chart 代表着 Helm 包。它包含在 Kubernetes 集群内部运行应用程序,工具或服务所需的所有资源定义。你可以把它看作是 Homebrew formula,Apt dpkg,或 Yum RPM 在Kubernetes 中的等价物。【charts:图表; 发布charts】

  • Repository(仓库) 是用来存放和共享 charts 的地方。它就像 Perl 的 CPAN 档案库网络 或是 Fedora 的 软件包仓库,只不过它是供 Kubernetes 包所使用的。

  • Release 是运行在 Kubernetes 集群中的 chart 的实例。一个 chart 通常可以在同一个集群中安装多次。每一次安装都会创建一个新的 release 。以 MySQL chart为例,如果你想在你的集群中运行两个数据库,你可以安装该chart两次。每一个数据库都会拥有它自己的 releaserelease name

在了解了上述这些概念以后,我们就可以这样来解释 Helm:

Helm 安装 charts 到 Kubernetes 集群中,每次安装都会创建一个新的 release 。你可以在 Helm 的 chart repositories 中寻找新的 chart。

2、charts 结构

3、自定义变量值

4、推送helm chart

sh 复制代码
helm registry login --insecure 192.168.86.5
helm chart save /root/mariadb 192.168.86.5/chart/mariadb:test
helm chart push 192.168.86.5/chart/mariadb:test
helm registry logout 192.168.86.5

四、Helm使用总结

1、拉仓库

2、下安装包

3、解压;cp values.yaml myself.yaml;修改myself.yaml

4、helm install helm -f values.yaml -f myself.yaml applicationName ./ -n namespace

5、helm list -A

6、uninstall


sh 复制代码
helm repo add bitnami https://helm-charts.itboon.top/bitnami 【找到的国内源】
helm repo add azure http://mirror.azure.cn/kubernetes/charts/ 
...

helm repo list
bitnami     https://helm-charts.itboon.top/bitnami  
azure     	http://mirror.azure.cn/kubernetes/charts/


helm repo update
sh 复制代码
helm search repo  mysql -l | grep 8.0.
                                              Chart 版本       App 版本
bitnami/mysql                                 	10.2.1       	8.0.36 
第二列是 Chart 版本(Chart 自身的打包版本)
第三列是 App 版本(Chart 中部署的应用程序的版本)

helm pull bitnami/mysql --version 10.2.1 # 使用 Chart 版本号拉取
ls
tar -zxvf mysql-10.2.1.tgz
...
[root@k8s-master mysql]# pwd
/home/lpruoyu/helm/mysql
[root@k8s-master mysql]# ls
Chart.lock  charts  Chart.yaml  README.md  templates  values.schema.json  values.yaml

# 用 helm install -f values.yaml my-mysql ./ 这种方式安装,修改values.yaml即可自定义【pv供应商的nfs路径最好搞个新的】
相关推荐
小猿姐6 小时前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
阿里云云原生1 天前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
java_cj2 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
互联网推荐官2 天前
上海软件定制开发公司推荐:从PaaS工程化路径看D-coding的技术取舍
云原生·云计算·paas·软件开发·开发经验·上海
sbjdhjd2 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
java_cj2 天前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
步步为营DotNet2 天前
基于.NET Aspire 实现云原生应用的高效监控与可观测性
云原生·.net·wpf
牛奶咖啡132 天前
KVM虚拟化与企业应用实践——给远端主机创建虚拟机
云原生·qemu·kvm·给远端主机创建虚拟机·创建uefi模式的虚拟机·安装openeulersp2·vnc与虚拟机环境搭建
java_cj3 天前
从kubectl学Visitor模式:如何优雅处理多态数据结构的遍历
云原生·golang·k8s·访问者模式
就改了3 天前
微服务异步场景链路断裂完整解决方案
微服务·云原生·架构