部署Chart应用并使用.net core读取Kubernetes中的configMap

上一篇文章讲了 k8s使用helm打包chart并上传到腾讯云TencentHub,今天就讲一下使用Helm部署应用并使用configMap代替asp.net core 中的appsettings.json文件。

把Chart上传到TencentHub之后,我们就可以通过腾讯云的容器服务,直接部署Helm应用了。

部署Helm应用

640?wx_fmt=png

点击新建然后选择TencentHub,私有仓库,就可以看到自己上传的Chart了。填写一下应用名称,拉到最下方点击完成即可创建应用。

640?wx_fmt=png

 注意:如果你的yaml文件写的不对,如少个空格,变量参数名称写错或者不存在,都无法创建成功。

 可以点击新建下方那个查看详情,可以看到Helm应用安装日志,安装失败会提示错误信息,自己跟据错误提示修复自己的错误。

640?wx_fmt=png

成功安装后点击应用可以查看资源信息和状态

640?wx_fmt=png

注意:Chart部署成功不代表你的服务已经成功启动了,如果你的服务本身是有问题起不来的话,这里不会有提示,需要自己去查看Pod是否已经正常启动成功。

640?wx_fmt=png

好了,应用部署完成后,我们来试试如何读取configMap。

读取configMap

上篇文章没有把config.yaml文件的内容放出来,里面内容如下 

640?wx_fmt=png

其中metadata中的name是必选项,namespace不写的话默认是default,labels用于条件过滤筛选。

data就是我们的配置内容,key-value的形式存在。

---------------------------分割线-----------------------------------------------------

.net core调用k8s需要使用KubeClient,这里我使用 https://github.com/tintoy/dotnet-kube-client 来调用k8s的接口。

直接使用nuget搜索KubeClient即可找到。

640?wx_fmt=png

KubeClient支持依赖注入。需要安装

KubeClient.Extensions.DependencyInjection


void ConfigureServices(IServiceCollection services)
{services.AddKubeClient(new KubeClientOptions{ApiEndPoint = new Uri("http://localhost:8001"),AuthStrategy = KubeAuthStrategy.BearerToken,AccessToken = "my-access-token",AllowInsecure = true // Don't validate server certificate    });
}

最简单的创建一个KubeClient方法如下:


KubeApiClient client = KubeApiClient.Create(new KubeClientOptions
{ApiEndPoint = new Uri("http://localhost:8001"),AuthStrategy = KubeAuthStrategy.BearerToken,AccessToken = "my-access-token",AllowInsecure = true // Don't validate server certificate});


这里我只是简单读取k8s中的configMap,至于用途下面再讲。

使用console控制台程序编写如下代码。

640?wx_fmt=png

640?wx_fmt=png

使用KubeApiClient获取一个configClient,然后configClient.List()获取k8s中的所有configMap,labelSelector和kubeNamespace都是默认可空参数,用于过滤筛选configMap。

这里我们通过断点可以看到,已经读取到wechat中的configMap信息,AppMode:Devlopment 就是我们config.yaml中data中的内容。

640?wx_fmt=png

 至此我们已经完成了.net core读取configMap的事情了。

asp.net core中加载configMap

使用nuget安装

KubeClient

KubeClient.Extensions.Configuration

在Startup.cs中的构造函数添加下面代码即可。

640?wx_fmt=png

使用configMap的原因

现在asp.net core一般是使用appsettings.json文件来读取项目的配置信息,这样做非常简单易容,但是在生产环境特别是微服务上面我们往往需要一个配置中心来管理应用配置。

目前充当配置中心的产品有很多,如携程的Apollo,springCloud中的SpringCloudConfig,consul也可以充当配置中心。

这些都需要额外部署多一个服务,而configMap也可以实现配置中心的功能,何乐而不为呢。至于有不同意见的读者,欢迎评论指点指点。

k8s中存储配置信息的不只configMap,一些敏感信息,我们可以使用Secret,Secret以密文的方式存储数据,避免了直接在配置文件中保存敏感信息。

Pod可以通过Volume或者环境变量的方式使用configMap和Secret。

总结一下

 由于自己也是刚接触这个不久,很多都还不没有深入理解到,就暂且说说遇到的一些问题吧......

首先最基本的,yaml格式错误,yaml很好用无需置疑,但是当配置信息以多起来的时候,yaml空格的问题就容易犯了,毕竟谁不会手误呢~~~( ͡° ͜ʖ ͡°)

一个是yaml的分号: 后面必须加上一个空格。另一个是yaml的对象层级是跟据空格划分的,虽然没有规定几个空格一层,但是要同层次的空格都是必须一致的。在yaml上面慎用TAB......(o≖◡≖)

然后呢,就是Chart模板的配置信息。

Chart模板中资源类型是通过kind区分的,然后资源的基本信息是在metadata中描述。

比如说config.yaml中,kind是ConfigMap。

metadata中包含资源的name,namespace,labels等,虽然至于name是必须项,但是最好尽量把能写的都写上。

第一次操作的时候只填写了name,然后再查询的时候怎么都查不出来(ノへ ̄、)然后才知道namespace不对......默认namespace是defalut 〒▽〒

然后,把namespace补上去了,然后再拉一次,出来了,但是是一次性拉取namespace下的所有configMap,没法过滤,然后看了下API才发现可以用label过滤(;´༎ຶД༎ຶ`)

嗯,然后又补了个labels上去了╮(╯▽╰)╭

嗯,还有其他很多细节,暂时还没去接触,这就不说了(✿◡‿◡)

最后

最后呢,期待各位大佬指点指点

原文地址:https://www.cnblogs.com/fanshaoO/p/10406325.html

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


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

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

相关文章

Vases and Flowers HDU - 4614

Vases and Flowers HDU - 4614 题意: 一排空瓶子放花,操作1:从第x个瓶子开始放花,放y朵花,每个瓶子就一朵花,如果碰到已经有花的瓶子跳过这个瓶子,看下一个,当花没了,或者瓶子不够…

洛谷P3327:[SDOI2015]约数个数和(莫比乌斯反演)

枚举倍数的一种灵活的变形:g(d)∑d∣inf(i)∑i1⌊nd⌋f(i⋅d)g(d)\sum_{d|i}^nf(i)\sum_{i1}^{\lfloor\frac{n}{d}\rfloor}f(i\cdot d)g(d)∑d∣in​f(i)∑i1⌊dn​⌋​f(i⋅d) 很显然,但有时能发挥大作用。 其实本质还是要理解西格玛究竟是在算什么 解析…

EFCore Lazy Loading + Inheritance = 干净的数据表 (一)

前言α角 与 β角关于α角 与 β角的介绍,请见上文 如何用EFCore Lazy Loading实现Entity Split。本篇会继续有关于β角的彩蛋在等着大家去发掘。/斜眼笑其他本篇的程序,可以在 https://github.com/kentliu2007/EFCoreDemo/tree/master/InheritanceWithE…

专题突破之反悔贪心——建筑抢修,Cow Coupons G, Voting (Hard Version),Cardboard Box

文章目录[JSOI2007]建筑抢修[USACO12FEB]Cow Coupons GCF1251E2 Voting (Hard Version)CF436E Cardboard Box[JSOI2007]建筑抢修 luogu4053 将建筑按照结束时间从小到大排序 然后记录一下已经修理的建筑总共的花费时间 如果花费时间加上现在这个建筑的修建时间超过了这个建…

Max Sum Plus Plus HDU - 1024

Max Sum Plus Plus HDU - 1024 题意: 给你n个数,选m个子段,各个子段连续且不相交,长度可以为1,设maxn为各个子区间的和,求最大的maxn。 题解: 设dp[i][j]表示前j个数分成i段的最大值 对于第…

模板:杜教筛(莫比乌斯反演、数论)

所谓杜教筛,就是dms教给我们的筛 (逃) 前言 与其说算法,不如说是技巧。 可以在低于线性的时间复杂度(准确的说是 O(n23)O(n^{\frac{2}{3}})O(n32​))内完成对积性函数的前缀和计算。 解析 考虑求函数 f…

程序员过关斩将--快速迁移10亿级数据

菜菜呀,咱们业务BJKJ有个表数据需要做迁移程序员主力 Y总现在有多少数据?菜菜大约21亿吧,2017年以前的数据没有业务意义了,给你半天时间把这个事搞定,绩效给你A程序员主力 Y总有绩效奖金吗?菜菜钱的事你去问…

[2021-09-09 T2] 就差⼀点——冒泡排序和反序表之间不为人知的秘密

就差一点解题报告descriptionsolutioncodedescription 题目描述 冒泡排序是⼀个简单的排序算法,其时间复杂度为O(n2)O(n^2)O(n2) 有⼀个大小为nnn的排列p1,...,pnp_1,...,p_np1​,...,pn​,⼩明想对这个排列进⾏冒泡排序,于是写了下⾯这份…

CodeForces - 76E Points

CodeForces - 76E Points 题意&#xff1a; 给你n个点的坐标&#xff0c;求所有一对点之间的距离的平方和 n<100000 题解&#xff1a; 直接暴力n2肯定不行&#xff0c;我们把这个的式子列出来&#xff1a; 代码&#xff1a; #include<bits/stdc.h> #define deb…

模板:Miller-RabinPollard-Rho(数论)

所谓 pollard-rho&#xff0c;就是泼辣的肉 &#xff08;逃&#xff09; 前言 许多题解都把这两个算法放在了一起。 那我也这样办吧&#xff01; miller-rabin可以在优秀的时间复杂度内完成对一个数的素性检测。 而pollard-rho则是立足于Miler-rabin之上&#xff0c;可以在 …

Asp.NetCore轻松学-部署到 Linux 进行托管

前言上一篇文章介绍了如何将开发好的 Asp.Net Core 应用程序部署到 IIS&#xff0c;且学习了进程内托管和进程外托管的区别&#xff1b;接下来就要说说应用 Asp.Net Core 的特性&#xff08;跨平台&#xff09;&#xff0c;将 .NetCore 部署到 Linux 中&#xff0c;主流的 Linu…

DevC++ 用C语言的多线程 实现简单的客户端和服务器

知识来源一&#xff1a; 使用Dev-C实现简单的客户端和服务器-CSDN博客 此先生的博客使用的是win32 SDK来创建多线程&#xff0c;然后鄙人对这个版本的多线程细节不明。于是又重新用C语言的线程替代win32API,以此继续学习服务器代码。 知识来源二&#xff1a;DevC 多线程创建…

[2021-09-09 T3] 序列/luogu P3943 星空(异或差分+bfs最短路+状压dp)

序列descriptionsolutioncodedescription 题目描述 长度为nnn的序列&#xff0c;初始全为000&#xff0c;每次可以选择⼀个数ai(1≤i≤l)a_i(1\le i\le l)ai​(1≤i≤l)&#xff0c;然后选择连续aia_iai​个元素异或上111 求最少的次数&#xff0c;使得对于所有i(1≤i≤k)i(…

HDU - 4608 I-number

题意&#xff1a; 给你一个x&#xff0c;让你构造一个y&#xff0c;y的要求&#xff1a; y>xy的各项之和为10的倍数在满足前两个的前提下&#xff0c;y尽可能小 题解&#xff1a; 模拟&#xff0c;尽可能的模拟&#xff0c;用字符串模拟 先将各位相加得到sum&#xff0c…

从初创公司的角度来看微服务

在开展微服务的过程中&#xff0c;了解要考虑哪些因素可能是非常有挑战性的事情。没有可以直接使用的金科玉律。每个过程都是不同的&#xff0c;因为每个组织面临的都是不同的环境。在本文中&#xff0c;我将从初创公司的角度分享我们学习到的经验和面临的挑战&#xff0c;以及…

洛谷P2056:[ZJOI2007]捉迷藏(点分树、STL)

解析 见到动态维护最远点对&#xff0c;不难想到利用 set 维护最大值和次大值&#xff0c;每个点维护两个 set 的杂技做法。 但是问题是…T了啊。 咋办嘞。 一个在本题至关重要的 trick&#xff1a;利用两个堆来支持访问最大值和删除 具体也很好理解&#xff1a;当删除的时候…

[NOI2018] 归程(线段树维护并查集的可持久化/kruskal重构树,倍增+dijkstra最短路)

[NOI2018] 归程descriptionsolution1code1solution2codedescription 题目描述 本题的故事发生在魔力之都&#xff0c;在这里我们将为你介绍一些必要的设定 魔力之都可以抽象成一个nnn个节点、mmm条边的无向连通图&#xff08;节点的编号从111至nnn&#xff09;我们依次用 l,…

CodeForces - 616D Longest k-Good Segment

CodeForces - 616D Longest k-Good Segment 题意&#xff1a; 有包含n个数的序列a&#xff0c;求能找到最长的区间包含不超过k个不同的元素。 题解&#xff1a; 尺取法&#xff0c;先固定L&#xff0c;然后移动R&#xff0c;R每次移动&#xff0c;当超过k后&#xff0c;L再…

MySQL 集群方案介绍

mysql集群方案这里介绍2种&#xff0c;PXC 和 Replication。大型互联网程序用户群体庞大&#xff0c;所以架构设计单节点数据库已经无法满足需求。大家也深有体会&#xff0c;有一万人在学校网站查成绩或是选课的时候网站时常是访问不了或者相应特别特别慢。这种情况就凸显出来…

模板:回文自动机(PAM)

所谓回文自动机&#xff0c;就是关于回文的自动机。 &#xff08;逃&#xff09; 前言 小清新自动机。 经历过SAM的大风大浪&#xff0c;这个相比而言好理解多了&#xff0c;感觉也许应该先学这个再学SAM… 解析 和trie、AC自动机、SAM等类似的&#xff0c;PAM的每个结点表…