Helm - Kubernetes服务编排的利器

Helm介绍

  在Kubernetes中部署容器云应用(容器或微服务编排)是一项有挑战性的工作,Helm就是为了简化在Kubernetes中安装部署容器云应用的一个客户端工具。通过Helm能够帮助开发者定义、安装和升级Kubernetes中的容器云应用。同时,也可以通过Helm进行容器云应用的分享。

  Helm的整体架构如下图(图片来源-Kubernetes中文社区)所示:

  640?wx_fmt=jpeg

  Helm架构由Helm客户端、Tiller服务器端和Chart仓库所组成;Tiller部署在Kubernetes中,Helm客户端从Chart仓库中获取Chart安装包,并将其安装部署到Kubernetes集群中。 

 

Helm是管理Kubernetes包的工具,Helm能提供以下能力:

  • 创建新的charts

  • 将charts打包成tgz文件

  • 与chart仓库交互

  • 安装和卸载Kubernetes的应用

  • 管理使用Helm安装的charts的生命周期

 

在Helm中,有三个需要了解的重要概念:

  • chart:是创建Kubernetes应用实例的信息集合

  • config:创建发布对象的chart的配置信息

  • release:chart的运行实例,包含特定的config

 

安装Helm

注:有些文件或镜像在国内可能无法下载,可以通过此地址获取:https://pan.baidu.com/s/1yVUCz7wGYie8hkzQaNc3eg

1. 在Master中下载安装Helm的客户端,可根据需要下载对应的版本,这里使用的版本是2.8.2。

curl -LO https://storage.googleapis.com/kubernetes-helm/helm-v2.8.2-linux-amd64.tar.gz

tar xzf helm-v2.8.2-linux-amd64.tar.gz

mv linux-amd64/helm /usr/local/bin

 

helm version查看信息:

640?wx_fmt=png

服务端Tiller还未安装,因此无法获取信息。

注:如果helm-v2.8.2-linux-amd64.tar.gz无法下载,可以从上面的链接中获取。

 

 2. 安装Tiller。

helm init

640?wx_fmt=png

注:如果初始化失败,可以把上面的链接中的.helm目录拷贝到master的root目录下。tiller的镜像文件也可以从目录获取。

如果出现了“Error:Get https://10.96.0.1:443/version:dial tcp 10.96.0.1:443:i/o timeout.”的问题,可以参考我的回答来解决:

https://github.com/kubernetes/helm/issues/3347#issuecomment-385468128

 

使用helm version查看Helm版本,如下表示客户端、服务端都安装完成:

640?wx_fmt=png

 

Kubernetes 1.6+版本加入了RBAC的机制,因此需要添加Role Binding:

kubectl create clusterrolebinding add-on-cluster-admin --clusterrole=cluster-admin --serviceaccount=kube-system:default

640?wx_fmt=png

 

准备Java微服务

1. 打包jar

mvn package

640?wx_fmt=png

 

2. 准备Dockerfile

FROM java:8u111-jre
RUN mkdir /app
COPY . /app
WORKDIR /app
CMD ["java","-Xmx4g","-Djava.security.egd=file:/dev/./urandom","-jar","hello-1.0.0.jar"]

 

3. 拷贝打包好的jar包以及Dockerfile到node虚拟机

640?wx_fmt=png

 

4. 打包docker镜像

docker build -t hello:1.0.0 .

640?wx_fmt=jpeg

 

准备.Net Core微服务

1. 发布项目

dotnet publish -c Release

640?wx_fmt=jpeg

 

2. 准备Dockerfile

FROM microsoft/aspnetcore:2.0COPY . /app
WORKDIR /appEXPOSE 5000/tcp
ENV ASPNETCORE_URLS http://*:5000ENTRYPOINT ["dotnet", "HelloTest.dll"]

3. 拷贝打包好的程序包以及Dockerfile到node虚拟机

640?wx_fmt=png

 

4. 打包docker镜像

docker build -t hello-test:1.0.0 .

 640?wx_fmt=png

 

使用Helm部署蓝图(Chart)

这里演示如何通过helm完成上面两个微服务的部署。

 

1. 创建chart

helm create hello-test

640?wx_fmt=png

 

2. 在templates目录中放入相应的部署脚本

640?wx_fmt=png

 

3. 打包chart

helm package hello-test

640?wx_fmt=png

 

4. 检查chart

helm lint hello-test

640?wx_fmt=png

缺少chart的图标,但不影响,可以忽略。

 

5. 调试chart

helm install ./hello-test-0.1.0.tgz --debug --dry-run

640?wx_fmt=png

 

调试模式不会真的部署,通过helm list来查看:

640?wx_fmt=png

 

6. 通过chart部署release

helm install --name hello-test ./hello-test-0.1.0.tgz

640?wx_fmt=png

 

helm ls

640?wx_fmt=png

 

kubectl get po

640?wx_fmt=png

 

查看结果

java服务: 

640?wx_fmt=png

.Net Core服务(调用java服务):

640?wx_fmt=png

 

7. 删除release

helm delete hello-test

640?wx_fmt=png

 

kubectl get po

640?wx_fmt=png

 

helm ls -a

640?wx_fmt=png

hello-test还在,但状态是DELETED,表示可以重用。如果想彻底删除,可以通过helm delete hello-test --purge来删除

640?wx_fmt=png

 

使用.Net Core来进行部署

使用的组件是:https://github.com/qmfrederik/helm/。

 

1. 核心代码:

640?wx_fmt=png

注:这里需要获取Kubernetes的admin.config的证书,该证书在master节点上:/etc/kubernetes/admin.conf。

 

2. 参考上述准备.Net Core微服务的步骤,完成helm-client的镜像打包及部署。

注:需要把admin.conf拷贝到镜像中:

640?wx_fmt=png

 

3. 准备yaml文件helm-client.yaml并完成部署

640?wx_fmt=png

640?wx_fmt=png

 

4. 检查效果

安装:

640?wx_fmt=png

640?wx_fmt=png

 

删除:

640?wx_fmt=png

640?wx_fmt=png

 

源码地址

https://github.com/ErikXu/HelmTutorial

原文地址https://www.cnblogs.com/Erik_Xu/p/8893725.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320796.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【DP】优美三角剖分

优美三角剖分 题目大意: 有一个图形,通过组合可以变成新的图形,现在要求第n个图形 原题: 题目描述 小X同学为了搞好和小C同学的关系,特意寻找了一些优美的图像作为礼物。 这是一些由无穷无尽三角形组成的极为优美…

Loj#114-k大异或和【线性基】

正题 题目链接:https://loj.ac/problem/114 题目大意 nnn个数,求所有非空子集的kkk小异或和。 解题思路 我们考虑处理一下线性基,我们知道对于did_idi​是一定在第iii位为111。 对于一个i>ji>ji>j且did_idi​的第jjj位为111时,我…

.NET Core微服务之基于MassTransit实现数据最终一致性(Part 1)

一、预备知识:数据一致性关于数据一致性的文章,园子里已经有很多了,如果你还不了解,那么可以通过以下的几篇文章去快速地了解了解,有个感性认识即可。(1)左正,《保证分布式系统数据一…

2017-2018 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2017)

D.Distinctive Character 看到样例,第一个反应贪心。先写了个按这一位1和0的数目多少,确定0还是1的东西。感觉不够真,又写了个尽量加到相似的比较小的串上的贪心。在和前边的那个组合一下,换了换顺序。。。好吧就过了13组样例。。…

【二分】买礼物的艰辛

买礼物的艰辛 题目大意: 有n个物品的价格,还有m个人,m个人中的每个人都要购买一定的连续物品,问买下n个物品,花钱最大的人最少花多少钱 原题: 题目描述 小X同学给小C同学选了N件礼物,决定顺…

P4449-于神之怒加强版【莫比乌斯反演】

正题 题目链接:https://www.luogu.com.cn/problem/P4449 题目大意 TTT组询问给出n,mn,mn,m求∑i1n∑j1mgcd(i,j)k\sum_{i1}^n\sum_{j1}^mgcd(i,j)^ki1∑n​j1∑m​gcd(i,j)k 解题思路 ∑i1n∑j1mgcd(i,j)k\sum_{i1}^n\sum_{j1}^mgcd(i,j)^ki1∑n​j1∑m​gcd(i,j)k ∑d1ndk∑i…

Asp.NetCoreWebApi图片上传接口(二)集成IdentityServer4授权访问(附源码)

写在前面本文地址:http://www.cnblogs.com/yilezhu/p/9315644.html作者:yilezhu上一篇关于Asp.Net Core Web Api图片上传的文章使用的是mongoDB进行图片的存储,文章发布后,张队就来了一句,说没有使用GridFS。的确博主只…

Codeforces40E[Number Table]

Codeforces40E[Number Table] 解法一,如果有一维很小,可以考虑状压dp之类的,显然非常不优秀。 解法二,如果n*m较小,可以考虑,设出每个位置是否为-1,解xor线性方程组。再bitset优化一下之类的。然…

【DP】天平问题

天平问题 解题思路: 有n个砝码,问可以称出多少种重量,可以在左边或者右边放,也可以不放 原题: 题目描述 小C为了试验小X,便为物竞的小X出了一道物理相关的题:现在给出n个质量的砝码&#x…

.NET Core开发日志——从ASP.NET Core Module到KestrelServer

ASP.NET Core程序现在变得如同控制台(Console)程序一般,同样通过Main方法启动整个应用。而Main方法要做的事情很简单,创建一个WebHostBuilder类,调用其Build方法生成一个WebHost类,最后启动之。实现代码一目了然:要想探…

BZOJ5358: [Lydsy1805月赛]口算训练

题解:判断d是否整除,可以转化为求这段区间内d的因子的指数是否均大于d中的指数。容易想到把每个数字都分解为素因子形式,对每个素数出现的次数求个前缀和即可。然而,这样时间空间都不行。注意到对于一个数x,小于sqrt(x…

jzoj6800-NOIP2020.9.19模拟spongebob【枚举】

正题 题目链接:https://gmoj.net/senior/#contest/show/3222/0 题目大意 nnn个ai,bia_i,b_iai​,bi​,求一个xxx使得最小化∑i1n∣aixbi∣\sum_{i1}^n|a_ixb_i|i1∑n​∣ai​xbi​∣ 解题思路 每个∣aixbi∣|a_ixb_i|∣ai​xbi​∣可以视为一个分两段的函数&#…

【bfs】极其简单的最短路问题

极其简单的最短路问题 题目大意: 求最短路,权值只有1或2 原题: 题目描述 小C终于被小X感动了,于是决定与他看电影,然而小X距离电影院非常远,现在假设每条道路需要花费小X的时间为1,由于有数…

GraphQL 的前世今生

GraphQL是什么GraphQL是一种新的API标准,它提供了一种更高效、强大和灵活的数据提供方式。它是由Facebook开发和开源,目前由来自世界各地的大公司和个人维护。GraphQL本质上是一种基于api的查询语言,现在大多数应用程序都需要从服务器中获取数…

jzoj6801-NOIP2020.9.19模拟patrick【树状数组】

正题 题目大意 nnn个连续的数,第iii个为hih_ihi​。有操作 给出一个HHH,询问大于等于HHH的数能组成多少个联通块修改一个位置的数。 解题思路 考虑计算连通块尾的数量,我们可以发现一个位置作为联通块尾部当且仅当hi≥Hh_i\geq Hhi​≥H且h…

Codeforces Round #485 (Div. 2)

Codeforces986B [Petr and Permutations] 看到两个随机的swap次数,很容易想到跟奇偶性有关。然后就凉了。赛后思考了一下,这个思路应该没问题,那就需要考虑swap的奇偶性与排列的关系。因此,我们考虑如何把两个不相邻数的swap&…

初一模拟赛总结(5.18)

成绩: rankrankranknamenamenamescorescorescoreT1T1T1T2T2T2T3T3T3T4T4T4111lyflyflyf210210210505050606060303030707070111hkyhkyhky210210210100100100404040000707070333wjjwjjwjj190190190100100100000000909090444fyfyfy170170170100100100000000707070555tj…

Codeforces Round #486 (Div. 3)

E. Divisibility by 25 能被25整除的充要条件就是末两位是00,25,50,75。如果没有过程中不出现前导0这一限制,显然对每种情况,贪心取尽量低位即可。本题的关键就在于如何满足这个条件,首先有个”显然”的方法…

C#:如何将坏的代码重新编译为好的代码

自己的前言说明:本文原作者:Radoslaw Sadowski,原文链接为:C# BAD PRACTICES: Learn how to make a good code by bad example。本系列还有其他文章,后续将慢慢翻译。引言:我的名字叫Radoslaw Sadowski&…

P6855-「EZEC-4.5」走方格【dp】

正题 题目链接:https://www.luogu.com.cn/problem/P6855 题目大意 n∗mn*mn∗m的网格,每个格子有一个数,可以选择一个位置变为000。要求最小化最大权值和路径。 解题思路 考虑枚举哪个位置变为000,一个位置变为000后我们将路径分为两种路径…