Kubernetes14:Helm为了部署像微服务这种的大型项目
创始人
2024-05-31 13:16:13
0

Kubernetes14:Helm介绍(为了部署像微服务这种的大型项目)

1、Helm的引入

(1)之前方式部署应用基本过程

编写yaml文件
  • 1、deployment
kubectl create deployment nginx --image=nginx --dry=run -o yaml > nginx.yaml
  • 2、Service
kubectl expose deployment nginx --port=80 --target-port=80 --type=NodePort
  • 3、Ingress
如果使用之前方式部署单一应用,少数服务的应用,比较合适
部署微服务项目,可能有几十个服务,每个服务都有一套yaml文件,需要维护大量的yaml文件,版本管理特别不方便

2、使用helm可以解决哪些问题?

(1)使用helm可以把这些yaml文件作为一个整体管理

(2)实现yaml高效复用

(3)实现应用级别的版本管理

3、Helm介绍

Helm是一个Kubernetes的包管理工具,就像Linux下的包管理器,如yum/apt等,可以很方便的将之前打包好的yaml文件部署到kubernetes上。

Helm有3个重要概念:

(1)helm:一个命令行客户端工具,主要用于Kubernetes应用chart的创建、打包、发 布和管理。
(2)Chart:应用描述,一系列用于描述k8s资源相关文件的集合。
(3)Release:基于Chart的部署实体,一个chart被Helm运行后将会生成对应的一个 release;将在k8s中创建出真实运行的资源对象。

4、He1m三个重要概念

(1)helm 是一个命令行客户端工具

(2)chart 把yaml打包,是yaml集合

(3)Release 基于chart部署实体,应角级别的版本管理

5、he1m在2019年发布V3版本,和之前版本相比有变化

(1)V3 版本删除Tiller

(2)release 可以在不同命名空间重用

(3)将chart推送到docker镜像仓库中

6、helm架构变化

请添加图片描述
请添加图片描述

安装和配置仓库

1、helm安装

官网下载:
helm.sh请添加图片描述

第一步 下载helm安装压缩文件,上传到1iunx系统中
第二步 解压helm压缩文件,把解压之后helm目录复制到 usr/bin目录下

请添加图片描述

2、配置helm仓库

(1)添加仓库

helm repo add 仓库名 仓库地址请添加图片描述

helm repo add stable http://mirror.azure.cn/kubernetes/charts
helm repo add allyun https://kubernetes.oss-cn-hangzhou.allyuncs.com/charts
helm repo list

可以加两个仓库,但没必要
请添加图片描述

(2)更新仓库

helm repo update

请添加图片描述

(3)删除仓库

helm repo remove aliyun

3、使用helm快速部署应用

第一步、使用命令搜索应用

helm search repo 名称(weave)
请添加图片描述

第二步、 根据搜索内容,选择安装

helm install 安装之后名称 搜索之后应用名称
请添加图片描述

查看安装之后状态

helm list
请添加图片描述

helm status 安装之后名称

请添加图片描述

已经创建好了pods和svc

请添加图片描述

但是没有对外暴露端口
修改service的yaml文件,type改为NodePort

kubectl edit svc ui-weave-scope
修改 请添加图片描述

请添加图片描述

kubectl get svc

请添加图片描述

如何自己创建Chart

1、使用命令创建chart


helm create mychart

请添加图片描述

进入文件夹

请添加图片描述
请添加图片描述

2、在templates.文件夹创建两个yaml文件

先试用 rm -rf * 命令删除该文件中所以的示例文件

deployment.yaml

kubectl create deployment web1 --image=nginx --dry-run -o yaml > deployment.yaml

service.yaml

kubectl create deployment web1 --image=nginx为了获取下边的yaml文件需要先将web1真实的创建出来,获取到service.yaml之后再删除(非通用方法)

kubectl expose deployment web1 --port=80 --target-port=80 --type=NodePort --dry-run -o yaml > service.yaml

kubectl delete deployment web1

请添加图片描述

3、安装mychart

helm install web1 mychart/
请添加图片描述

4、应用升级-----helm upgrade chart名称

helm upgrade webl mychart/
请添加图片描述

实现yaml高效复用

通过传递参数, 动态渲染模板,yam1内容 动态传入参数生成

请添加图片描述

在chart有values.Iyaml文件, 定义yaml文件全局变量

1、在value.yaml文件中定义变量和值

2、在具体的yaml文件,获取定义变量值

特点:yaml文件大体有几个地方不同的

Image
tag
label
port
replicas

第一步、在values.yaml定义变量和值

请添加图片描述

第二步、在templates的yaml文件使用values.yaml定义变量

请添加图片描述

deplyoment.yaml

请添加图片描述

service.yaml

请添加图片描述

helm install --dry-run web2 mychart/
helm install web2 mychart/

请添加图片描述

相关内容

热门资讯

122.(leaflet篇)l... 听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
Vue使用pdf-lib为文件... 之前也写过两篇预览pdf的,但是没有加水印,这是链接:Vu...
PyQt5数据库开发1 4.1... 文章目录 前言 步骤/方法 1 使用windows身份登录 2 启用混合登录模式 3 允许远程连接服...
Android studio ... 解决 Android studio 出现“The emulator process for AVD ...
Linux基础命令大全(上) ♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维...
再谈解决“因为文件包含病毒或潜... 前面出了一篇博文专门来解决“因为文件包含病毒或潜在的垃圾软件”的问题,其中第二种方法有...
南京邮电大学通达学院2023c... 题目展示 一.问题描述 实验题目1 定义一个学生类,其中包括如下内容: (1)私有数据成员 ①年龄 ...
PageObject 六大原则 PageObject六大原则: 1.封装服务的方法 2.不要暴露页面的细节 3.通过r...
【Linux网络编程】01:S... Socket多进程 OVERVIEWSocket多进程1.Server2.Client3.bug&...
数据结构刷题(二十五):122... 1.122. 买卖股票的最佳时机 II思路:贪心。把利润分解为每天为单位的维度,然后收...
浏览器事件循环 事件循环 浏览器的进程模型 何为进程? 程序运行需要有它自己专属的内存空间࿰...
8个免费图片/照片压缩工具帮您... 继续查看一些最好的图像压缩工具,以提升用户体验和存储空间以及网站使用支持。 无数图像压...
计算机二级Python备考(2... 目录  一、选择题 1.在Python语言中: 2.知识点 二、基本操作题 1. j...
端电压 相电压 线电压 记得刚接触矢量控制的时候,拿到板子,就赶紧去测各种波形,结...
如何使用Python检测和识别... 车牌检测与识别技术用途广泛,可以用于道路系统、无票停车场、车辆门禁等。这项技术结合了计...
带环链表详解 目录 一、什么是环形链表 二、判断是否为环形链表 2.1 具体题目 2.2 具体思路 2.3 思路的...
【C语言进阶:刨根究底字符串函... 本节重点内容: 深入理解strcpy函数的使用学会strcpy函数的模拟实现⚡strc...
Django web开发(一)... 文章目录前端开发1.快速开发网站2.标签2.1 编码2.2 title2.3 标题2.4 div和s...