微服务Spring Cloud与Kubernetes比较

Spring Cloud或Kubernetes都宣称它们是开发运行微服务的最好环境,哪个更好?答案是两个都是,但他们拥有各自不同的特征方式。背景故事最近,Lukyanchikov发表了一篇使用Spring Cloud和Docker建立微服务架构的文章。 它给出了如何使用Spring Cloud创建一个简单的基于微服务的系统所需的全面概述。 为构建一个可扩展到数十或数百个服务的伸缩弹性的微服务系统,必须借助具有宽泛的构建时间和运行能力的工具集进行集中管理和管理。 Spring Cloud包括实现功能性服务(如统计服务,帐户服务和通知服务)和支持基础设施服务(如日志分析,配置服务器,服务发现,授权服务)。 这些服务涵盖了系统的运行时各个方面,但不涉及打包,持续集成,扩展,高可用性和自我修复,这在MSA(微服务架构)世界中也非常重要。 假设大多数Java开发人员熟悉Spring Cloud,在本文中,我们将绘制一个平行图,通过解决这些额外的问题,了解Kubernetes与Spring Cloud的关系。有关MSA的好处是,它有一种架构风格很好理解的好处,微服务可实现强大的模块边界,具有独立的部署和技术多样性。 但代价是开发分布式系统成本和显著运营开销 。一个关键的成功因素是使用各种工具解决这些问题,微服务关注点微服务关注方面有:配置管理、服务发现与负载平衡、弹性和失败冗余、API管理、安全服务、中央集中日志、集中测量、分布式跟踪、调度部署和自动扩展self Healing等几个方面。根据这些观点,得出Spring Cloud和Kubernetes两个平台映射:1.配置管理:配置服务器、Consul和Netflix Archaius(Spring Cloud);Kubernetes ConfigMap&Secrets ;2.服务发现: Netflix Eureka,Hashicorp Consul(Spring Cloud);Kubernetes Service&Ingress Resource;3.负载平衡:Netflix Ribbon(Spring Cloud);Kubernetes Service4.API网关:Netflix Zuul(SpringCloud);Kubernetes Service&Ingress Resource5.安全服务:SpringCloud Security6.中央集中日志:ELK Stack(LogStash);EFKstack(Fluentd)。7.集中测量:Netflix Spectator& Atlas;Heapster、Prometheus、Grafana。8.分布式跟踪:SpringCloud Sleuth,Zipkin;OpenTracing、Zipkin9.弹性和失败冗余:Netflix Hystrix、Turbine&Ribbon;Kubernetes Health Check&resource isolation10.自动扩展self Healing:Spring Cloud无;Kubernetes Health Check、SelfHealing、Autoscaling11.打包 部署和调度部署:Spring Boot;Docker/Rkt、Kubernetes Scheduler&Deployment12.任务工作管理:Spring Batch;Kubernetes Jobs&Scheduled Jobs13.单个应用:Spring Cloud Cluster ;Kubernetes PodsSpring Cloud有一套丰富的集成良好的Java库,作为应用程序栈一部分解决所有运行时问题。 因此,微服务本身通过库和运行时作为代理来执行客户端服务发现,负载平衡,配置更新,度量跟踪等。诸如单例集群服务和批处理作业的模式也在JVM中进行管理。Kubernetes是多语言的,不仅针对Java平台,并以通用的方式为所有语言解决分布式计算的挑战。 它提供应用程序栈外部的配置管理,服务发现,负载平衡,跟踪,度量,单例,平台调度作业等平台级别功能。 该应用系统不需要任何库或代理程序用于客户端逻辑,它可以用任何语言编写。在某些方面,这两个平台都依赖类似的第三方工具。例如,ELK和EFK堆栈,跟踪库等一些库,如Hystrix和Spring Boot,在这两种环境中同样有用。有些情况下这两个平台是互补的,并且可以结合在一起,创造一个更加强大的解决方案,例如,Spring Boot提供了用于构建单个JAR应用程序包的Maven插件。结合Docker和Kubernetes的声明性部署和调度功能,使微服务运行变得轻而易举。 类似地,Spring Cloud具有应用程序库,用于使用Hystrix(断路器)和Ribbon(用于负载平衡)创建弹性的,容错的微服务。 但是单单这是不够的,当它与Kubernetes的健康检查,进程重新启动和自动扩展功能相结合时,微服务成为一个真正的抗脆弱的系统。长处和短处由于两个平台不具有直接的可比性特征,下面是逐项总结其优点和缺点。Spring Cloud为开发人员提供了快速构建分布式系统中的一些常见模式的工具,例如配置管理,服务发现,断路器,路由等。它是为Java开发人员使用,构建在Netflix OSS库之上的。优势1.Spring Platform提供的统一编程模型和Spring Boot的快速应用程序创建能力为开发人员提供了巨大的微服务开发体验。 例如,使用很少的注释,您可以创建一个配置服务器,并且几乎没有更多的注释,您可以获得客户端库来配置您的服务。2.有丰富的库选择,覆盖大多数运行时关注。由于所有库都是用Java编写的,它提供了多种功能,更好的控制和精细调整选项。3.不同的Spring Cloud库彼此完全集成。例如,Feign客户端还将使用Hystrix用于断路器,并且Ribbon用于负载平衡请求。 一切都是注释驱动的,使其易于为Java开发人员开发。弱点1.Spring Cloud的一个主要优点是它的缺点 - 它仅限于Java。MSA的强大动力是在需要时交换各种技术栈,库,甚至语言的能力。 只是使用Spring Cloud是不可能的。 如果您想要使用Spring Cloud / Netflix OSS基础架构服务(如配置管理,服务发现或负载平衡),那么解决方案就不那么优雅。 在Netflix的 Prana项目通过基于HTTP暴露Java客户端实现了sidecar模式,使其可能让非JVM语言运行在NetflixOSS生态系统中,但它不是很优雅。2.Java开发人员关心Java应用程序并需要处理太多与开发无关的事情。每个微服务需要运行各种客户端以进行配置检索,服务发现和负载平衡。虽然很容易设置,但这并不会降低对环境的构建时间和运行时依赖性。例如,开发人员可以使用@EnableConfigServer创建一个配置服务器,但这只是开心的假象。 每当开发人员想要运行单个微服务时,他们需要启动并运行Config Server。对于受控环境,开发人员必须考虑使Config Server高度可用,并且由于它可以由Git或Svn支持,因此它们需要一个共享文件系统。 类似地,对于服务发现,开发人员需要首先启动Eureka服务器。 为了创建一个受控的环境,他们需要在每个AZ上使用多个实例实现集群。像开发人员一样,除了实现所有功能服务之外,Java开发人员还必须构建和管理一个非平凡的微服务平台。3.Spring Cloud在微服务发展过程只有很短历程,开发人员还需要考虑自动化部署,调度,资源管理,过程隔离,自我修复,构建管道等,以获得完整的微服务体验。 对于这点,我认为这是不公平的比较,应该比较 Spring Cloud + Cloud Foundry (or Docker Swarm) 和Kubernetes。但这也意味着对于一个完整的端到端微服务体验,Spring Cloud必须补充一个像Kubernetes本身这样的应用程序平台。Kubernetes是一个用于自动化部署,扩展和管理容器化应用程序的开源系统。 它是多种语言并且提供用于供应,运行,扩展和管理分布式系统的操作系统。优势1.Kubernetes是一个多语言和语言不可知的容器管理平台,能够运行云本地和传统的容器化应用程序。其提供的服务(如配置管理,服务发现,负载平衡,测量指标收集和日志聚合)可供各种语言使用。 这允许在一个组织中有一个平台,可以被多个团队(包括使用Spring的Java开发人员)使用,并提供多种用途:应​​用程序开发,测试环境,构建环境(运行源代码控制系统,构建服务器,工件存储库)等。2.与Spring Cloud相比,Kubernetes解决了更广泛的MSA问题。 除了提供运行时服务,Kubernetes也可以让你规定的环境中,设置资源限制,RBAC,管理应用程序生命周期,启用自动缩放和自我修复(几乎表现得像一个抗脆弱平台)。3.Kubernetes技术基于Google 15年的研发经验和管理容器的经验。此外,有近1000个提交者,它是Github上最活跃的开源社区之一。弱点1. Kubernetes是多语言的,因此它的服务是通用的,并不针对不同的平台(如Spring Cloud for JVM)进行优化。 例如,配置作为环境变量或安装的文件系统传递到应用程序。 它没有Spring Cloud Config提供的奇特的配置更新功能。2.Kubernetes不是一个以开发人员为中心的平台。 它旨在由DevOps的IT人员使用。因此,Java开发人员需要学习一些新的概念,并开放学习解决问题的新方法。手动安装高度可用的Kubernetes集群有一个显著操作的开销。3.Kubernetes仍然是一个相对较新的平台(2岁),它仍然积极发展和成长。因此,每个版本都添加了很多新功能,可能很难跟上。 好消息是,这已经被考虑到,API将是可扩展和向后兼容的。最好的两个世界正如你所看到的,这两个平台在某些领域有优势,在其他领域有待改进。 Spring Cloud是一个快速开始的开发者友好平台,而Kubernetes是DevOps友好的,具有更陡峭的学习曲线,但涵盖了更广泛的微服务关注点。这两个框架涉及不同范围的MSA关注,他们以一种根本不同的方式去实现。 Spring Cloud方法试图解决JVM中的每个MSA挑战,而Kubernetes方法试图通过在平台层面解决为开发人员解决问题。 Spring Cloud在JVM内部非常强大,Kubernetes在管理这些JVM方面功能强大。结合他们,并从两个项目的最好的部分受益。有了这样的组合,Spring提供了应用程序打包,而Docker和Kubernetes提供了部署和调度。 Spring通过Hystrix线程池提供应用程序防火墙,Kubernetes通过资源,进程和命名空间隔离提供防火墙。Spring为每个微服务提供健康端点,Kubernetes执行健康检查和流量路由到健康的服务。 Spring负责外部化和更新配置,Kubernetes将配置分发到每个微服务。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,651评论 18 139
  • 软件是有生命的,你做出来的架构决定了这个软件它这一生是坎坷还是幸福。 本文不是讲解如何使用Spring Cloud...
    Bobby0322阅读 22,648评论 3 166
  • 爱情啊,爱情, 为何你如此神秘。 就像伊甸园里的果子, 吸引着人们向你靠近! 爱情啊,爱情, 为何你如此甜蜜? 又...
    lc0727阅读 237评论 0 0
  • 鸢尾花的诱惑 的确,一开始我两手托着下巴,胳膊肘支在窗台上半爬在哪,专心看着那盆开放的鸢尾花。当时,也只是...
    沂荷芝兰阅读 357评论 1 2
  • 好的婚姻长什么样儿? 有人说:“好的婚姻是就当没结过婚但也不想离婚。” 有人说:“好的婚姻是就是平淡生活中的相敬如...
    麦柒柒阅读 573评论 2 7