k8s学习 — (运维)第九章 Helm 包管理器

news/2025/1/1 12:04:26/

k8s学习 — (运维)第九章 Helm 包管理器

  • 学习资料
  • 1 什么是 Helm?
  • 2 Helm 架构
    • 2.1 重要概念
    • 2.2 组件
      • 2.2.1 Helm 客户端
      • 2.2.2 Helm 库
  • 3 安装 Helm
  • 4 Helm 的常用命令
  • 5 chart 详解
    • 5.1 目录结构
    • 5.2 Redis chart 实践
      • 5.2.1 修改 helm 源
      • 5.2.2 搜索 redis chart
      • 5.2.3 修改配置安装
      • 5.2.4 查看安装情况
      • 5.2.5 升级与回滚
      • 5.2.6 helm 卸载 redis

学习资料

学习视频:完整版Kubernetes(K8S)全套入门+微服务实战项目,带你一站式深入掌握K8S核心能力

学习资料:k8s配套资料

1 什么是 Helm?

Kubernetes 包管理器:Helm 是查找、分享和使用软件构件 Kubernetes 的最优方式。

Helm 管理名为 chart 的 Kubernetes 包的工具。Helm 可以做以下的事情:

  • 从头开始创建新的 chart
  • 将 chart 打包成归档(tgz)文件
  • 与存储 chart 的仓库进行交互
  • 在现有的 Kubernetes 集群中安装和卸载 chart
  • 管理与 Helm 一起安装的 chart 的发布周期

对于Helm,有三个重要的概念:

  1. chart 创建Kubernetes应用程序所必需的一组信息。
  2. config 包含了可以合并到打包的chart中的配置信息,用于创建一个可发布的对象。
  3. release 是一个与特定配置相结合的chart的运行实例。

2 Helm 架构

2.1 重要概念

chart:chart 创建 Kubernetes 应用程序所必需的一组信息。
config:config 包含了可以合并到打包的 chart 中的配置信息,用于创建一个可发布的对象。
release:release 是一个与特定配置相结合的 chart 的运行实例。

2.2 组件

2.2.1 Helm 客户端

Helm 客户端 是终端用户的命令行客户端。负责以下内容:

  • 本地 chart 开发
  • 管理仓库
  • 管理发布
  • 与 Helm 库建立接口
    • 发送安装的 chart
    • 发送升级或卸载现有发布的请求

2.2.2 Helm 库

Helm 库 提供执行所有 Helm 操作的逻辑。与 Kubernetes API 服务交互并提供以下功能:

  • 结合 chart 和配置来构建版本
  • 将 chart 安装到 Kubernetes 中,并提供后续发布对象
  • 与 Kubernetes 交互升级和卸载 chart

独立的 Helm 库封装了 Helm 逻辑以便不同的客户端可以使用它。

3 安装 Helm

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

  1. 下载二进制文件:https://get.helm.sh/helm-v3.2.3-linux-amd64.tar.gz
  2. 解压(tar -zxvf helm-v3.10.2-linux-amd64.tar.gz)
  3. 将解压目录下的 helm 程序移动到 usr/local/bin/helm
  4. 添加阿里云 helm 仓库

4 Helm 的常用命令

  1. helm repo:列出、增加、更新、删除 chart 仓库。
  2. helm search:使用关键词搜索 chart。
  3. helm pull:拉取远程仓库中的 chart 到本地。
  4. helm create:在本地创建新的 chart。
  5. helm dependency:管理 chart 依赖。
  6. helm install:安装 chart。
  7. helm list:列出所有 release。
  8. helm lint:检查 chart 配置是否有误。
  9. helm package:打包本地 chart。
  10. helm rollback:回滚 release 到历史版本。
  11. helm uninstall:卸载 release。
  12. helm upgrade:升级 release。

5 chart 详解

5.1 目录结构

mychart
├── Chart.yaml
├── charts # 该目录保存其他依赖的 chart(子 chart)
├── templates # chart 配置模板,用于渲染最终的 Kubernetes YAML 文件
│   ├── NOTES.txt # 用户运行 helm install 时候的提示信息
│   ├── _helpers.tpl # 用于创建模板时的帮助类
│   ├── deployment.yaml # Kubernetes deployment 配置
│   ├── ingress.yaml # Kubernetes ingress 配置
│   ├── service.yaml # Kubernetes service 配置
│   ├── serviceaccount.yaml # Kubernetes serviceaccount 配置
│   └── tests
│       └── test-connection.yaml
└── values.yaml # 定义 chart 模板中的自定义配置的默认值,可以在执行 helm install 或 helm update 的时候覆盖

5.2 Redis chart 实践

5.2.1 修改 helm 源

# 查看默认仓库
helm repo list# 添加仓库
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo add aliyun https://apphub.aliyuncs.com/stable
helm repo add azure http://mirror.azure.cn/kubernetes/charts

5.2.2 搜索 redis chart

# 搜索 redis chart
helm search repo redis# 查看安装说明
helm show readme bitnami/redis

5.2.3 修改配置安装

# 先将 chart 拉到本地
helm pull bitnami/redis# 解压后,修改 values.yaml 中的参数
tar -xvf redis-17.4.3.tgz# 修改 storageClass 为 managed-nfs-storage
# 设置 redis 密码 password
# 修改集群架构 architecture,默认是主从(replication,3个节点),可以修改为 standalone 单机模式
# 修改实例存储大小 persistence.size 为需要的大小
# 修改 service.nodePorts.redis 向外暴露端口,范围 <30000-32767># 安装操作
# 创建命名空间
kubectl create namespace redis# 安装
cd ../
helm install redis ./redis -n redis

5.2.4 查看安装情况

# 查看 helm 安装列表
helm list# 查看 redis 命名空间下所有对象信息
kubectl get all -n redis

5.2.5 升级与回滚

要想升级 chart 可以修改本地的 chart 配置并执行:
helm upgrade [RELEASE] [CHART] [flags]
helm upgrade redis ./redis
使用 helm ls 的命令查看当前运行的 chart 的 release 版本,并使用下面的命令回滚到历史版本:helm rollback <RELEASE> [REVISION] [flags]# 查看历史
helm history redis
# 回退到上一版本
helm rollback redis
# 回退到指定版本
helm rollback redis 3

5.2.6 helm 卸载 redis

helm delete redis -n redis

http://www.ppmy.cn/news/1280590.html

相关文章

【Android 13】使用Android Studio调试系统应用之Settings移植(二):构建settings app项目目录

文章目录 一、篇头二、系列文章2.1 Android 13 系列文章2.2 Android 9 系列文章2.3 Android 11 系列文章三、准备工作3.1 创建目录3.2 初始化 git 仓库四、提取settings原始代码4.1 提取目标4.2 源码路径4.2.1 settings app4.2.2 SettingsLib4.3 存放位置

各大高校科研工具链培训PPT汇总

各大高校科研工具链培训PPT汇总 RSS 北邮图书馆&#xff1a;通过RSS订阅高效获取信息、追踪研究前沿山东大学图书馆&#xff1a;如何追踪学科研究前沿苏大图书馆&#xff1a;个人知识管理软件的使用中科院图书馆&#xff1a;利用RSS与最新资讯同步 文献管理工具 中南大学图…

JAVA WEB用POI导出EXECL多个Sheet

前端方法&#xff1a;调用exportInfoPid这个方法并传入要查询的id即可&#xff0c;也可以用其他参数看个人需求 function exportInfoPid(id){window.location.href 服务地址"/exportMdsRoutePid/"id; } 后端控制层代码 Controller Scope("prototype") R…

IPC之九:使用UNIX Domain Socket进行进程间通信的实例

socket 编程是一种用于网络通信的编程方式&#xff0c;在 socket 的协议族中除了常用的 AF_INET、AF_RAW、AF_NETLINK等以外&#xff0c;还有一个专门用于 IPC 的协议族 AF_UNIX&#xff0c;IPC 是 Linux 编程中一个重要的概念&#xff0c;常用的 IPC 方式有管道、消息队列、共…

Spring Cloud Feign作为HTTP客户端调用远程HTTP服务

如果你的项目使用了SpringCloud微服务技术,那么你就可以使用Feign来作为http客户端来调用远程的http服务。当然,如果你不想使用Feign作为http客户端,也可以使用比如JDK原生的URLConnection、Apache的Http Client、Netty的异步HTTP Client或者Spring的RestTemplate。 那么,为…

ros2中gazebo安装的注意事项

Install From source&#xff08;推荐安装Fortress版本&#xff0c;好像很方便&#xff09; ROS Be sure youve installed ROS Humble (at least ROS-Base). More ROS dependencies will be installed below. Gazebo Install either Edifice, Fortress, or Garden.(没有har…

sql-labs服务器结构

双层服务器结构 一个是tomcat的jsp服务器&#xff0c;一个是apache的php服务器&#xff0c;提供服务的是php服务器&#xff0c;只是tomcat向php服务器请求数据&#xff0c;php服务器返回数据给tomcat。 此处的29-32关都是这个结构&#xff0c;不是用docker拉取的镜像要搭建一下…

Rust 生命周期

Rust 第17节 生命周期 先看一段错误代码 /* //一段错误的代码 // Rust 编译时会报错&#xff1b; */let r;{let x 5;r &x;}println!("{}",r);Rust 在编译时使用 借用检查器&#xff0c; 比较作用域来检查所有的借用是否合法&#xff1b; 很明显&#xff1b;r…