写点什么

微服务技术栈 2.0

  • 2017-03-14
  • 本文字数:1884 字

    阅读完需:约 6 分钟

当下市场瞬息万变,新技术不断涌现,而微服务持续火热。如果说 2014 年是微服务的元年,那么 2015 年和 2016 年则是微服务走下神坛的时刻,越来越多的开发者、架构师们探讨着如何落地,如何解决各种实际问题,而很多技术栈和工具也纷纷涌现。

Netflix 和一些互联网公司作为早期微服务的采用者在这些领域做了很多的投资、尝试和贡献(如开源工具和相关论文)。然“微服务不是免费的午餐”。企业也并不都是 Netflix,微服务的复杂性以及带来的各种成本还是让很多企业望而却步,挡在了门外。

而如今,随着越来越多的企业和社区加入到这一行列,经过早期采用者的沉淀和后续加入者的共同创造,在微服务的多个已知问题领域出现了新的一波解决方案和技术栈,给其注入了新的希望。最近,Christian Posta 发表了题为“令人兴奋的微服务技术栈2.0”的文章阐述了这一趋势。他指出,这些技术栈的出现可以帮助解决原来很多已有的或者在一些问题域中难易跨越的问题,甚至可以更优雅的解决。

Christian 提到的第一个例子是 Kubernetes。他指出:

Google 和 Red Hat 都是第三次在构建一个有应用程序级原语的平台时使用 Kubernetes,这个平台用来运行在容器上构建的原生云应用程序。过去 Google 或开源社区也曾有过不同的尝试,但 Kubernetes 大大简化了像服务发现、规模化、部署等任务。似乎社区里其他人也同意 Kubernetes 是 GitHub 上最热门的项目,现在已经有 1000 多个提交者,很是疯狂。如果 Kubernetes 出现在 5 年前,你不会看到这么多“微服务”框架来解决这些问题。

Christian 提到的另一个例子是熔断。微服务架构是由多个独立的服务组成,如果任何一个服务出现故障,就会导致其它依赖的服务像多米诺骨牌一样出现连带故障,最终导致整个系统的瘫痪。这就使得在微服务这样的架构中,保障服务及服务之间的稳定性是非常重要的问题之一。而熔断器模式则是解决这个问题的一个模式。

熔断器模式指,在某个服务发生故障时,熔断器的故障监控向调用放返回一个及时的错误响应,而不是长时间的等待。这样就不会使得线程因调用故障被长时间占用,从而避免了故障在整个系统中的蔓延。

在熔断器技术的发展中,Christian 谈到:

“现在任何人都可以写一个熔断器(和许多有)。 Netflix 甚至发布了他们的熔断器(Hystrix 库)。应用程序可以使用 hystrix 库来实现相关功能。然而其对于熔断、服务发现、跟踪,指标以及其它系列问题的缺点时,它强依赖于开发人员获取正确的类库,并真正的将这些事情作对。这是非常困难的。我们需要一种新的方式来解决这个问题。”

Christian 认为“我们真正想要的并不是更多的类库或框架让我们的应用程序变得更复杂,而是希望每个开发人员可以正确的在项目之间使用或应用它们,甚至更重要的是与编程语言无关。维护类库不同的实现会让人抓狂。”他指出在该领域也出现了一些“更优雅的”方式,如 IMHO 和来自 Lyft 的 Envoy project。

IMHO 将这些问题放在客户端代理,这个代理部署为应用程序的“跨斗”。而 Envoy 是一个非常小的 C++ 客户端代理,用于处理诸如熔断、批量堆栈、服务发现、度量收集、跟踪等问题。这意味着单个 Envoy 代理将与每个应用程序(1-1)一起部署。应用程序可以利用此功能,而无须考虑编程语言的约束。该应用程序基本上通过“localhost”与其他服务通信,Envoy 完成服务的所有代理工作。它知道如何找到后端服务,完成自适应路由、重试、跟踪、调节等任务。开发人员可以保持整洁的应用程序代码,并免费获得所有的这些便利。

Christian 谈到的最后一个例子是构建微服务的方式。他认为:

用 REST 构建微服务是绝对的事实。搭建一个服务,使用 REST 端点提供服务,并将其用在服务之间的所有交互和集成。而 REST 也存在一些在规模化上已知的问题,如追踪服务的破坏性变更,理解服务之间的类型安全,以及与二进制 RPC 风格的服务(至少 HTTP 1.x)相比带来的过大开销等。今天它正在演进为一些更优雅的方式,如非阻塞通信框架(即 RxJava、Vert.x)、异步通信模式等,甚至像 RPC(如 gRPC)也变得更加的优雅。

最后,笔者认为技术并不依赖于特定的技术栈或工具,然如果没有有效的技术栈和工具,好的想法也可能夭折。就如 Christian 所说,微服务领域不断的发展,这些新的技术栈和解决思路可以让一些已知的问题得到解决,并优雅的得到解决,他为之兴奋,也值得我们关注。随着越来越多的企业、社区、个人参与其中,微服务必将在更多的领域落地生根,开花结果。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2017-03-14 19:005475

评论

发布
暂无评论
发现更多内容

面向深蓝!西北工业大学团队借助昇腾AI,打造海面落水目标智能机载搜寻系统

极客天地

【深入浅出Sentinel原理及实战】「基础实战专题」零基础探索分析Sentinel控制台开发指南(3)

码界西柚

sentinel sentinel集群限流 1月日更

互联网一线研发管理之殇

葱小白

互联网 管理 前端

《SBOM: 提高软件供应链透明度的关键》重磅白皮书来袭

安势信息

SCA SBOM 清源CleanSource SCA 安势信息 开源软件供应链安全

前端工程师leetcode算法面试必备-二叉树的构造和遍历

js2030code

JavaScript LeetCode

Polaris 和 dubbogo 全面对接,让微服务更简单

阿里巴巴云原生

阿里云 云原生 dubbogo

阿里云专有云重磅亮相中国信通院2022混合云技术发展论坛

云布道师

阿里云 混合云

数字先锋| 公开!青海师大“接轨社会人才”培养秘籍!

天翼云开发者社区

云计算 大数据 云平台

手把手带你开发starter,点对点带你讲解原理

京东科技开发者

spring 开发 服务器 系统 企业号 1 月 PK 榜

2022 倒带 - NutUI

京东科技开发者

小程序 开源 开发 技术栈 企业号 1 月 PK 榜

音视频开发进阶|第七讲:分辨率与帧率·上篇

ZEGO即构

鲸品堂:2023你好

鲸品堂

技术人

从开源安全看汽车安全新挑战

安势信息

开源安全 汽车安全 SBOM 开源漏洞 清源CleanSource SCA

如何看待PyTorch 2.0?

OneFlow

人工智能 深度学习 PyTorch

袋鼠云产品功能更新报告03期丨产品体验全面优化,请查收!

袋鼠云数栈

大数据

技术分享| 如何使用Prometheus实现系统进程监控

anyRTC开发者

Prometheus 服务器 运维开发 数据监控 系统进程监控

前端工程师leetcode算法面试必备-二叉树深度广度遍历

js2030code

JavaScript LeetCode

使用QuTrunk+AWS ParallelCluster3进行并行计算

启科量子开发者官方号

量子计算

专注软件供应链安全,「安势信息」完成数千万元级别Pre-A轮融资

安势信息

开源安全 开源软件供应链 安势信息 Pre-A轮融资 开源软件供应链安全

“新范式”——2022创业邦100未来独角兽峰会暨创业邦年会圆满落幕

创业邦

直播|PostgreSQL 技术内幕(五)Greenplum-Interconnect模块

酷克数据HashData

postgresql

用javascript分类刷leetcode24.其他类型题(图文视频讲解)

js2030code

JavaScript LeetCode

重磅发布!《天翼云白皮书》+天翼云紫金DPU来了!

天翼云开发者社区

CDN 系统

《迷你世界》亿级玩家都在用的游戏场景推荐系统长啥样?

华为云开发者联盟

数据库 后端 华为云 企业号 1 月 PK 榜

构建api gateway - 序与目录

八苦-瞿昙

Gateway API Gateway build api gateway

深度解读天翼云紫金DPU,软硬协同造就极致性能!

天翼云开发者社区

2022 年,这 20+22 位共建者闪耀 StarRocks 社区

StarRocks

数据库 开源

开源共创,StarRocks 祝您 2023 年前 “兔” 无量!

StarRocks

数据库 开源

什么是A/B实验,为什么要开A/B实验?

字节跳动数据平台

大数据 AB testing实战

邮箱中的Qt线程设计

统信软件

邮箱 邮箱系统

微服务技术栈2.0_语言 & 开发_禚娴静_InfoQ精选文章