【Kubernetes】使用Helm简化k8s部署、管理

使用Helm简化Kubernetes部署、管理

Helm 是 Kubernetes 的包管理工具,能够简化应用的部署、管理和升级流程。以下是使用 Helm 的基本步骤和常见操作。

先决条件

想成功和正确地使用Helm,需要以下前置条件。

  1. 一个 Kubernetes 集群(参考macOS上优雅运行Docker容器
  2. 确定你安装版本的安全配置
  3. 安装和配置Helm。

安装Helm

macOS

sh 复制代码
brew install helm

Windows

sh 复制代码
choco install kubernetes-helm

Debian/Ubuntu

sh 复制代码
sudo apt-get install curl gpg apt-transport-https --yes
curl -fsSL https://packages.buildkite.com/helm-linux/helm-debian/gpgkey | gpg --dearmor | sudo tee /usr/share/keyrings/helm.gpg > /dev/null
echo "deb [signed-by=/usr/share/keyrings/helm.gpg] https://packages.buildkite.com/helm-linux/helm-debian/any/ any main" | sudo tee /etc/apt/sources.list.d/helm-stable-debian.list
sudo apt-get update
sudo apt-get install helm

基本概念

概念 描述 简单类比
Chart Helm 的应用包,包含模板和默认配置。 nginx.deb 安装包文件
Repository Chart 的存储仓库,用于分发和共享。 Ubuntu 的软件源(如 archive.ubuntu.com
Release 在集群中运行的 Chart 的一个实例。 系统上正在运行的 nginx 进程
Values 用于覆盖 Chart 中模板默认参数的配置。 安装软件时传入的配置参数(如安装路径)

Helm的一般操作:

  • helm search:    搜索chart
  • helm pull:     下载chart到本地目录查看
  • helm install:    上传chart到Kubernetes
  • helm list:      列出已发布的chart
  • helm uninstall: 卸载一个版本

Bitnami

Bitnami 是一家被 VMware 收购的公司,长期专注于为流行开源软件提供打包好的、跨平台的安装程序。在容器化时代之前,他们就为数百个应用提供了虚拟机镜像、云镜像和原生安装包。

Bitnami是Helm中最常用的仓库之一,提供了许多常用的Kubernetes应用程序的Helm Charts。Helm作为Kubernetes的包管理器,允许用户从Chart repository快速查找和安装软件包。此外,用户可以通过Helm命令获取Bitnami Charts的详细信息。

Bitnami 提供了数百个经过验证的 Chart,涵盖:

数据库

sh 复制代码
helm install my-postgresql bitnami/postgresql
helm install my-redis bitnami/redis
helm install my-mongodb bitnami/mongodb

消息队列与中间件

sh 复制代码
helm install my-kafka bitnami/kafka
helm install my-rabbitmq bitnami/rabbitmq
helm install my-nginx bitnami/nginx

应用框架

sh 复制代码
helm install my-wordpress bitnami/wordpress
helm install my-joomla bitnami/joomla
helm install my-redmine bitnami/redmine

使用Helm部署一个MySQL

这里是没有使用Helm部署数据库MySQL的例子,需要手动管理

  1. 创建命名空间
  2. 创建本地存储PV和StorageClass
  3. 创建MySQL配置ConfigMap
  4. 创建MySQL密码Secret
  5. 创建MySQL StatefulSet
  6. 创建MySQL Service
  7. 部署脚本

下面就看看如何用Helm简化部署MySQL

1. 添加Bitnami仓库(若添加过,忽略)

sh 复制代码
helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo update

2. 创建自定义values文件

创建 mysql-values.yaml 文件:

sh 复制代码
image:
  registry: docker.io
  repository: mysql
  tag: 8.0.34
  pullPolicy: Always

auth:
  rootPassword: "root123!"
  database: "myapp"
  username: "appuser"
  password: "app1234!"
  replicationUser: "replicator"       # 复制专用用户
  replicationPassword: "replica-pass" # 复制用户密码

primary:
  persistence:
    enabled: true
    size: 8Gi
    storageClass: "local-path"
  
  resources:
    requests:
      memory: "512Mi"
      cpu: "250m"
    limits:
      memory: "1Gi"
      cpu: "500m"
  
secondary:
  replicaCount: 1
  persistence:
    enabled: true
    size: 8Gi
    storageClass: "local-path"
  extraEnvVars:
    - name: MYSQL_ROOT_PASSWORD
      value: "root123!"

# 禁用所有辅助功能
volumePermissions:
  enabled: false

architecture: "replication"

3. 部署MySQL

sh 复制代码
helm install my-mysql bitnami/mysql -f mysql-values.yaml -n mysql --create-namespace --version=9.14.0

验证

  1. 进入Pod
sh 复制代码
kubectl exec -ti my-mysql-primary-0 -n mysql -- /bin/sh
  1. 链接主节点/从节点
sh 复制代码
mysql -h my-mysql-primary.mysql.svc.cluster.local -uroot -p

可以看到只需要3步,就可以部署一个主从复制架构的MySQL,比手动管理是方便太多,这是因为helm封装很多细节,具体查看某个Chart可以把它拉去到本地,查看

sh 复制代码
helm pull bitnami/mysql --version=9.14.0 --untar

引用

java-developer

例子: https://github.com/WilsonPan/java-developer/k8s/helm

相关推荐
WilsonPan4 天前
【Kubernetes】部署数据库MySQL应用
系统运维
WilsonPan7 天前
【Kubernetes】入门-部署Spring应用
系统运维
谅望者9 天前
Linux文件查看命令完全指南:cat、less、head、tail、grep使用详解
linux·excel·less·shell·文件操作·命令行·系统运维
IT小哥哥呀21 天前
5 个 Windows 故障排除工具
windows·故障排除·系统运维·windows系统·电脑问题
WilsonPan1 个月前
macOS上优雅运行Docker容器
系统运维
Johny_Zhao2 个月前
达梦数据库高可用集群部署方案
linux·mysql·网络安全·docker·信息安全·kubernetes·云计算·shell·containerd·达梦数据库·yum源·系统运维·centos8
Johny_Zhao3 个月前
Conda、Anaconda、Miniconda对比分析
linux·网络安全·信息安全·kubernetes·云计算·conda·shell·containerd·anaconda·yum源·系统运维·miniconda
Johny_Zhao3 个月前
Linux防止rm误操作防护方案
linux·网络·人工智能·网络安全·信息安全·云计算·yum源·系统运维
Johny_Zhao3 个月前
基于 Docker 的 LLaMA-Factory 全流程部署指南
linux·网络·网络安全·信息安全·kubernetes·云计算·containerd·yum源·系统运维·llama-factory