热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

helmV3版本

1、引入(1)之前方式部署应用基本过程*编写yaml文件**deployment**Service**Ingress(负载均衡、

1、引入

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

* 编写yaml文件

** deployment

** Service

** Ingress (负载均衡、域名)

缺点:如果使用之前的方式部署单一应用,少数服务的应用,比较合适。比如部署微服务项目,可能有几十个项目,每个服务都有一套yaml文件,需要维护大量的yaml文件,版本管理特别不方便

2、helm介绍

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

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

(2)实现yaml高效复用

(3)使用helm应用级别的版本管理

3、helm具体介绍

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

4、Helm三个重要概念

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

(2)Chart 把yaml打包,应用描述,一系列用于描述k8s资源相关文件的集合

(3)Release 基于chart部署实体,一个chart被Helm运行后将会生成对应的一个release:将在k8s中创建出真实运行的资源对象

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

(1)v3版本删除Tiller     架构变化

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

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

6、helm架构变化

将tiller删除,在外部添加kube-config模块

1、helm安装

第一步 下载helm安装压缩文件,上传到Linux系统中

第二步 解压helm压缩文件,把解压之后helm目录复制到usr/bin目录下

2、配置helm仓库

(1)添加仓库

helm repo add 仓库名称 仓库地址

3、使用helm快速部署应用

第一步 使用命令搜索应用

helm search repo 名称 (weave)

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

helm install 安装之后的名称 搜索之后应用名称
* 查看应用之后的状态
helm list
helm status 安装之后名称

* 修改service的yaml文件,type改为NodePort

如何自己创建Chart

1、使用命令创建chart

helm create chart 名称

* Chartyaml:当前chart属性配置信息
* template: 编写yaml文件放到这个目录中
* values.yaml: yaml文件可以的使用全局变量

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

* deployment.yaml

* service.yaml

3、安装mychart

4、应用升级

helm upgrade chart 名称

 通过传递参数的方式实现yaml文件的高效复用

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

在下面的文件中定义全局变量的值

1、在values.yaml定义变量和值

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

* yaml文件中大体上有这些地方不同

** image

** tag

** label

** port

** replicas

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

二、在template的yaml文件中使用values.yaml定义变量

* 通过表达式形式使用全局变量

* {{ .Values.变量名称 }}

{{ .Release.Name }} # 取到当前版本名称

 

 


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • Spring Cloud因其强大的功能和灵活性,被誉为开发分布式系统的‘一站式’解决方案。它不仅简化了分布式系统中的常见模式实现,还被广泛应用于企业级生产环境中。本书内容详实,覆盖了从微服务基础到Spring Cloud的高级应用,适合各层次的开发者。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 本文详细介绍了MicroATX(也称Mini ATX)和MATX主板规格,探讨了它们的结构特点、应用场景及对电脑系统成本和性能的影响。同时,文章还涵盖了相关操作系统的实用技巧,如蓝牙设备图标删除、磁盘管理等。 ... [详细]
  • 作为一名专业的Web前端工程师,掌握HTML和CSS的命名规范是至关重要的。良好的命名习惯不仅有助于提高代码的可读性和维护性,还能促进团队协作。本文将详细介绍Web前端开发中常用的HTML和CSS命名规范,并提供实用的建议。 ... [详细]
  • 本文介绍如何在Grafana配置面板时,使用JSONNet获取数组中特定元素的位置,并将其应用于动态服务查询。 ... [详细]
  • 本文详细探讨了在微服务架构中,使用Feign进行远程调用时出现的请求头丢失问题,并提供了具体的解决方案。重点讨论了单线程和异步调用两种场景下的处理方法。 ... [详细]
  • 使用LVS与ldirectord实现高可用负载均衡
    本文介绍了如何通过LVS(Linux Virtual Server)结合ldirectord工具来实现服务器的健康检查及负载均衡功能。环境设置包括一个LVS节点和两个真实服务器节点,通过配置ldirectord进行健康状态监测,确保系统的高可用性。 ... [详细]
  • 深入理解Docker网络管理
    本文介绍了Docker网络管理的基本概念,包括为什么需要Docker网络管理以及Docker提供的多种网络驱动模式。同时,文章还详细解释了Docker网络相关的命令操作,帮助读者更好地理解和使用Docker网络功能。 ... [详细]
  • 一面问题:MySQLRedisKafka线程算法mysql知道哪些存储引擎,它们的区别mysql索引在什么情况下会失效mysql在项目中的优化场景&# ... [详细]
  • 本文详细介绍了 Nginx 中用于端口监听的核心配置指令,包括其基本用法和高级选项。 ... [详细]
author-avatar
会说话的鱼911
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有