K8s Helm安装配置入门

作为k8s现在主流的一种包部署方式,尽管不用,也需要进行一些了解。因为,它确实太流行了。

这一套太极拳打下来,感觉helm这种部署,目前还不太适合于我们公司的应用场景。它更适合需要手工编程各种yaml文件,使用模板减少工作量和出错。

而我们已实现了web方式的yaml文件编辑,使用Helm意义不大,只能起到优化yaml存储的作用,但同时会使我们的配置文件深度依赖helm。

一,Helm用途

Helm把Kubernetes资源(比如deployments、services或 ingress等) 打包到一个chart中,而chart被保存到chart仓库。通过chart仓库可用来存储和分享chart。Helm使发布可配置,支持发布应用配置的版本管理,简化了Kubernetes部署应用的版本控制、打包、发布、删除、更新等操作。

做为Kubernetes的一个包管理工具,用来管理charts——预先配置好的安装包资源,有点类似于Ubuntu的APT和CentOS中的yum。

Helm具有如下功能:

l---  创建新的chart

l---  chart打包成tgz格式

l---  上传chart到chart仓库或从仓库中下载chart

l---  在Kubernetes集群中安装或卸载chart

l---  管理用Helm安装的chart的发布周期

l  Helm有三个重要概念:

l---  chart:包含了创建Kubernetes的一个应用实例的必要信息

l---  config:包含了应用发布配置信息

l---  release:是一个chart及其配置的一个运行实例

二,Helm组件

Helm基本架构如下:

Helm有以下两个组成部分:

1,Helm Client

用户命令行工具,其主要负责如下:

l---  本地chart开发

l---  仓库管理

l---  与Tiller sever交互

l---  发送预安装的chart

l---  查询release信息

l---  要求升级或卸载已存在的release

2,Tiller Server

一个部署在Kubernetes集群内部的server,其与Helm client、Kubernetes API server进行交互。Tiller server主要负责如下:

l---  监听来自Helm client的请求

l---  通过chart及其配置构建一次发布

l---  安装chart到Kubernetes集群,并跟踪随后的发布

l---  通过与Kubernetes交互升级或卸载chart

l---  简单的说,client管理charts,而server管理发布release。

三,Helm安装

1,下载helm客户端


curl
https://raw.githubusercontent.com/kubernetes/helm/master/scripts/get >
get_helm.sh

chmod
700 get_helm.sh

./get_helm.sh

下载完成之后,运行helm version命令,如下输出表示客户ok,server未就绪。

# ./helm version

2,下载tiller镜像

想办法,把gcr.io/kubernetes-helm/tiller:v2.14.2弄到本机上(github+dockerhub)

向k8s集群中应用一个helm-tiller-rbac-config.yaml


apiVersion: v1

kind:
ServiceAccount

metadata:

name: tiller

namespace: kube-system

---

apiVersion:
rbac.authorization.k8s.io/v1

kind:
ClusterRoleBinding

metadata:

name: tiller

roleRef:

apiGroup: rbac.authorization.k8s.io

kind: ClusterRole

name: cluster-admin

subjects:

- kind: ServiceAccount

name: tiller

namespace: kube-system

将这个配置文件应用到集群


kubectl
create -f rbac-config.yaml

然后用类似下面的命令调好。(为什么是类似呢?因为我调了很多次,有一次才通)


./helm
init -i gcr.io/kubernetes-helm/tiller:v2.14.2 --service-account tiller
–upgrade

./helm
init --service-account tiller --tiller-image
gcr.io/kubernetes-helm/tiller:v2.14.2 --skip-refresh

helm
init --service-account tiller

./helm
init --service-account tiller --skip-refresh

如果安装正常,helm version命令输出如下:

四,  Helm日常操作

1,查看chart


# 查看chart,即已经通过helm部署到 k8s 平台的应用

helm
list   

helm ls

2,搜索chart


helm
search

3,指定仓库搜索chart


helm
search
存储库名称
#

stable

incubator

helm
search chart
名称
#

wordpress

spark

4,查看chart详细信息


helm
inspect ali/wordpress

五,  Helm部署

下面以workpress为例子,演示如何部署一个helm项目。

1,下载chart


Helm
fetch ali/wordpress

2,安装部署chart


helm install --name
wordpress-test \

--set
"persistence.enabled=false,mariadb.persistence.enabled=false" \

ali/wordpress

3, 浏览器检测

http://XXXX:30141/

4,查看wordpress chart


helm
list

5,删除wordpress chart


helm
delete wordpress-test

六,  建立自己的Helm
Chart

1,生成默认
chart


helm
create helm-nginx

2,chart文件解释


3,chart模板文件及变量文件对应关系

deployment.yaml

values.yaml

4,chart配置文件检测


helm
install --dry-run --debug helm-nginx

5,安装自定义的chart

在chart目录内运行


helm
install .

浏览器查看效果

七,  传播及复用Helm
Chart

1,chart打包分享

在chart目录内运行


helm
package .

2,http提供chart服务

在生成了chart的压缩包的目录运行


helm
serve --address 0.0.0.0:9527

3,复用chart

在另外的机器上,访问chart的http服务,并进行下载及安装


wget http://127.0.0.1:9527/helm-nginx-0.1.0.tgz

helm
install --name nginx-test helm-nginx-0.1.0.tgz

原文地址:https://www.cnblogs.com/aguncn/p/11230567.html

时间: 2024-08-29 18:58:02

K8s Helm安装配置入门的相关文章

转载maven安装,配置,入门

转载:http://www.cnblogs.com/dcba1112/archive/2011/05/01/2033805.html 本书代码下载 大家可以从我的网站下载本书的代码:http://www.juvenxu.com/mvn-in-action/,也可以通过我的网站与我取得联系,欢迎大家与我交流任何关于本书的问题和关于Maven的问题. 咖啡与工具 本书相当一部分的内容是在苏州十全街边的Solo咖啡馆完成的,老板Yin亲手烘焙咖啡豆.并能做出据说是苏州最好的咖啡,这小桥流水畔的温馨小

k8s Helm安装Prometheus Operator

Ubuntu 18 Kubernetes集群的安装和部署 以及Helm的安装完成了k8s的集群和helm的安装,今天我们来看看Prometheus的监控怎么搞.Prometheus Operator 是 CoreOS 开发的基于 Prometheus 的 Kubernete s监控方案,也可能是目前功能最全面的开源方案.更多信息可以查看https://github.com/coreos/prometheus-operator 创建命名空间 为方便管理,创建一个单独的 Namespace moni

k8s中helm安装部署,升级和回滚(chart,helm,tiller,StorageClass)

一.Helm介绍 helm是基于kubernetes 的包管理器.它之于 kubernetes 就如 yum 之于 centos,pip 之于 python,npm 之于 javascript 那 helm 的引入对于管理集群有哪些帮助呢? 更方便地部署基础设施,如 gitlab,postgres,prometheus,grafana 等 更方便地部署自己的应用,为公司内部的项目配置 Chart,使用 helm 结合 CI,在 k8s 中部署应用一行命令般简单 1.Helm用途 Helm把Kub

GoLang入门-安装-配置

Go的三种安装方式 Go有多种安装方式,你可以选择自己喜欢的.这里我们介绍三种最常见的安装方式: Go源码安装:这是一种标准的软件安装方式.对于经常使用Unix类系统的用户,尤其对于开发者来说,从源码安装是最方便而熟悉的.Go标准包安装:Go提供了方便的安装包,支持Windows.Linux.Mac等系统.这种方式适合初学者,可根据自己的系统位数下载好相应的安装包,一路next就可以轻松安装了.第三方工具安装:目前有很多方便的第三方软件包工具,例如Ubuntu的apt-get.Mac的homeb

第四十八课 zabbix工作原理、安装、配置入门

监控系统基础及zabbix介绍 zabbix工作原理及安装配置 zabbix配置入门 zabbix配置入门 一.监控系统基础及zabbix介绍 著名的监控工具 zabbix zennos opennms cacti nagios. cacti 收集数据.展示图表 nagios 关注状态 报警机制强 zabbix 强大的监控工具能完成数据采集.存储.展示.报警功能. zabbix 有专用的agent的监控工具,他是一个分布式的监控系统. 二.zabbix的安装(zabbix-2.4为例) 1.rp

Maven01——简介、安装配置、入门程序、项目构建和依赖管理

1 Maven的简介 1.1 什么是maven 是apache下的一个开源项目,是纯java开发,并且只是用来管理java项目的 Svn eclipse   maven量级 1.2 Maven好处 同一个项目,普通的传统项目(24M)而Maven项目只需要(724KB) 分析:maven项目为什么这么小?没有jar. 需要jar吗?肯定需要.没有存在于maven项目里面,jar存在于哪? 1.3 依赖管理 1.4 项目一键构建 编码  编译  测试(junit)  运行  打包  部署 一个 t

04.风哥Oracle数据库实战入门-Oracle安装配置视频教程

04.风哥Oracle数据库实战入门-Oracle安装配置视频教程链接:https://pan.baidu.com/s/1UDhT_A_e62sZshQ5n2toYQ 提取码:pqca 请分享链接到5个QQ IT交流群后,加入以下QQ群找群主获取更多免费视频. 更多视频教程,请加入QQ群(只加一个即可):189070296336282998 更多视频课程请点击:http://www.itpux.com/oracle.html 原文地址:http://blog.51cto.com/oracle18

Git客户端的安装与配置入门

GitLab与Git客户端的安装与配置入门,每次配置完一段时间,就忘记配置过程了,为了自己和同学们以后有所参照,特记录了本次下载和配置,其实Git就是一个版本控制系统,类似于SVN,CVS等 下载:Windows操作系统下下载安装客户端即可,如Git-2.19.2-64-bit.exe 安装:过程可以一路默认安装完成即可 配置: 1.  选择你要下载服务器上项目和操作的本地目录空间,如G:\youxuan\workspace,该文件夹下空白处"右键"---选择Git Bash Here

国内不fq安装K8S三: 使用helm安装kubernet-dashboard

目录 3 使用helm安装kubernet-dashboard 3.1 Helm的安装 3.2 使用Helm部署Nginx Ingress 3.3 使用Helm部署dashboard 3.4 使用Helm部署metrics-server 国内不fq安装K8S一: 安装docker 国内不fq安装K8S二: 安装kubernet 国内不fq安装K8S三: 使用helm安装kubernet-dashboard 国内不fq安装K8S四: 安装过程中遇到的问题和解决方法 本文是按照"青蛙小白"