百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

一分钟带你了解 k8s #云原生

bigegpt 2024-08-14 14:49 2 浏览

一分钟带你了解K8S。

大家好,我是CJ。在脉脉上看到一个帖子,里面有两张有趣的图,其中一张是关于K8S的,但是对于一些新手来说可能不太容易理解。

简单来说,如果我们不使用K8S中的组件,虽然也可以运行应用程序,但无法达到最佳状态。有人说K8S是Go语言中的Spring Cloud,是Go语言的开卷之作,我觉得很有意思。所以今天我想借此机会,向大家介绍一下K8S,尤其是对新手朋友。

在介绍K8S之前,我们需要回顾一下传统的应用程序开发。例如,使用Java或Python开发应用程序时,需要将其打包并部署到服务器上。然而,这存在一些问题。首先,应用程序之间无法进行资源隔离。其次,环境也无法统一。例如,生产环境可能需要更多的环境变量或不同的网络配置,这可能会导致问题无法及时解决。

因此,Docker的出现解决了以上问题。Docker不仅可以实现资源隔离,还可以实现环境统一。在这里,我想先跳过Docker,因为今天的主题不是Docker。在大量使用Docker时,也会出现一些问题。例如,需要编写脚本和工具来维护容器之间的关系。例如,需要在容器a启动之前先启动容器b,或者容器之间的调用关系。网络需要相互开放,这些都需要运维人员进行额外的工作。

以Spring Cloud为例,我们可能需要使用SpringCloud task force来保护网关,需要使用EurMaker服务发现注册中心,还需要其他外部配置和trace。这些都需要单独部署和维护,这可能会增加运维人员的工作量。在这个过程中,需要额外部署和维护不同的基础设施。

因此,有没有什么解决方案可以解决这个问题呢?直到K8S的出现。K8S的出现可以将我们之前依赖的组件全部下沉到K8S中,帮助我们处理问题。例如,K8S Ingress可以代替SpringCloud网关。K8S service可以提供服务注册和发现功能。

然后,我们可以使用Istio来进行微服务之间的RPC调用,它集成了许多功能,如负载均衡、限流和熔断。因此,我们可以用Kubernetes的组件或周边生态来替换传统的Spring Cloud开发。这样,我们的运维人员只需要维护Kubernetes集群,而不需要部署其他组件。在跨语言的研发团队中,效率会大大提高。

接下来,我将介绍一些常用的开发组件,如Ingress服务、KVA和Photoshop,用于维护多个Pod。

我们的业务研发只需要专注于提供容器,将它们组成相同功能和职责的容器,组成一个统一的Solar。然后,我们可以使用电网或StatefulSet来暴露和代理这些容器。接下来,我们可以使用Ingress或服务来进行访问。整个过程中,我们的业务研发只需要关心如何编写一个简单的镜像,其中只需要包含核心功能,而不必担心容器之间的资源调用。

配置文件也可以由Kubernetes的configmap提供,一次性任务也可以由Job中的信任文件或secret提供。因此,对于我们的研发或运维人员来说,只需要专注于Kubernetes平台进行研发。我们不需要再了解与语言绑定相关的框架,这样可以大大降低运维成本和研发成本。

当然,Kubernetes中有许多组件。今天,我只是抛砖引玉。在后续的视频中,我会继续更新,讲解具体组件的使用。希望大家继续关注。连接!

相关推荐

为3D手游打造, Visual Studio Unity扩展下载

IT之家(www.ithome.com):为3D手游打造,VisualStudioUnity扩展下载7月30日消息,微软正式发布升级版VisualStudioToolsforUnity扩...

由ArcMap属性字段自增引出字段计算器使用Python的技巧

1.前言前些日子有人问我ArcMap中要让某个字段的值实现自增有什么方法?我首先想到像SQLServer中对于数值型字段可以设置自增。所以我打开ArcCatalog查看发现只提供默认值,没办法只能看...

微软首次回答 HoloLens 相关问题,终于爆料了

fengo2015/04/2115:11注:本文作者张静是NVIDIAGPU架构师,微信公众号“黑客与画家”(HackerAndPainter),知乎专栏地址。欢迎各位童鞋与他交流探讨。...

C#指针的应用(c#指针类型)

C#在有限的范围内支持指针。C#的指针只不过是一个持有另一类型内存地址的变量。但是在C#中,指针只能被声明为持有值类型和数组的内存地址。与引用类型不同,指针类型不被默认的垃圾收集机制所跟踪。出于同...

C# 堆栈(Stack)(c# 堆栈中定位调用messagebox 的地方)

C#集合在C#中,堆栈(Stack)是一种后进先出(LIFO,LastInFirstOut)的数据结构。堆栈(Stack)适用于存储和按顺序处理数据,其中最新添加的元素会最先被移除。堆...

欢迎回来:Fortran意外重回流行编程语言20强榜单

TIOBE指数是用来确定一种编程语言受欢迎程度的指标之一。它并不表明哪种编程语言是最好的,也不表明哪种编程语言写的代码行数最多,而是利用在谷歌、维基百科、必应、亚马逊、YouTube等各种引擎和网站上...

C#+NET MAUI实现跨平台/终端(linux,win,ios等)解决方案

简介.NETMulti-platformAppUI(.NETMAUI)是一个跨平台的框架,用于使用C#和XAML创建移动和桌面应用程序。使用.NETMAUI,您可以用一套代码库开发可以在A...

C#代码安全红线:SQL注入防护终极方案,让你的系统固若金汤

在数字化时代,应用系统的安全性至关重要。而SQL注入攻击,长期盘踞在OWASP(OpenWebApplicationSecurityProject)漏洞榜单的前列,成为众多基于数据库的应用系统...

C# (一)状态机模式(状态机代码实现)

最近空闲,炒炒隔夜饭,以前这些模式在自己项目种应用过不少,但一直没有像别人那样写一个系列,最近年纪大了,很多东西都忘记了,特别AI的兴起,更少写代码了,反正没什么事情,自己在重写一遍吧。创建型模式(5...

C# 中 Predicate 详解(c#中的replace)

Predicate泛型委托:表示定义一组条件并确定指定对象是否符合这些条件的方法。此委托由Array和List类的几种方法使用,用于在集合中搜索元素。Predicate<T>...

C#中$的用法?(c#中&&什么意思)

文章来自AI问答。在C#中,$符号用于字符串插值(StringInterpolation)。字符串插值是C#6.0引入的一种特性,它允许你在字符串中直接嵌入表达式,而不需要使用string.For...

C#并行编程:Parallel类(c# 并行处理)

在Parallel类中提供了三个静态方法作为结构化并行的基本形式:Parallel.Invoke方法:并行执行一组委托。Parallel.For方法:执行与C#for循环等价的并行方法。Parall...

颠覆认知!用Span重构foreach循环竟让数据处理快如闪电

在C#编程的世界里,数据处理效率始终是开发者们关注的焦点。随着项目规模的扩大和数据量的激增,哪怕是细微的性能提升,都可能对整个应用的响应速度和用户体验产生深远影响。近年来,C#引入的Span<T...

Unity3D手游开发实践《腾讯桌球》客户端开发经验总结

本次分享总结,起源于腾讯桌球项目,但是不仅仅限于项目本身。虽然基于Unity3D,很多东西同样适用于Cocos。本文从以下10大点进行阐述:1.架构设计2.原生插件/平台交互3.版本与补丁4.用脚本,...

.NET 7 AOT 的使用以及 .NET 与 Go 互相调用

目录背景C#部分环境要求创建一个控制台项目体验AOT编译C#调用库函数减少体积C#导出函数C#调用C#生成的AOTGolang部分安装GCCGolang导出函数.NETC#...