立即领取|华润集团、宁德核电、东风岚图等 20+ 标杆企业数字化人才培养实践案例 了解详情
写点什么

不同类型的微服务?

  • 2016-04-25
  • 本文字数:1792 字

    阅读完需:约 6 分钟

最近,有许多微服务领域的讨论,但是这些讨论大多都是关于如何从头开始构建微服务应用的,Mark Little 认为,微服务的初衷在于改造已有的应用,提高其敏捷性,他讨论了在这种场景下,实现微服务的最佳实践。

Mark Little 博士是 Red Hat 中间件部门的工程副总裁,他领导着 JBoss 的技术方向和研究 / 开发工作。在此之前,他曾经担任过 SOA 技术开发的主管,并负责标准的制订。

在 Mark Little 最新的一篇博客文章中,他回顾了自己从事微服务相关的一些经历和对微服务的认识,他依然愿意在这个领域不断思考,并与其团队成员进行交流,从而推动行业思想的发展。

在这个过程中,有些困扰他的问题变得逐渐清晰。长期以来,人们思考的可能是微服务与SOA、分布式系统以及DevOps 的关系,而且也有很多的项目和产品来帮助开发基于(微)服务的架构。但是,除Red Hat 以外,大多数关于微服务的文章都是从头开始构建的。这其实也反映了大多数开发工作的关注点:从头(Greenfield)开发,重新对系统进行架构,然后完全重建。

不过,微服务最初并不是这样的,如果读一下最初的文献的话,尤其是来自Netflix 的文章,就会发现微服务的理念(或者Adrian Cockcroft 最初所说的“Adrian Cockcroft”)是与已有系统息息相关的,它致力于将它们重构为组件(服务),这些组件能够独立地部署、版本化和发布。这里的理念在于为已有的系统(brownfield)构建微服务。Mark Little 虽然一开始就知道这些背景,但是一直以来他始终认为这种方式与从头开始构建所使用的过程、工具以及方式都是完全相同的。直到最近,他才意识到中间的差别。

有些团队会基于已有的系统进行改造,实现微服务,这是很有价值的。大多数人所面临的都是已有的应用,就像Netflix 那样,因此这种方式更具有实用性。它不需要我们好高骛远,每次只需进步一点点即可,这方面是作者以前所没有太多关注的。为了支持这些微服务,也需要对基础设施进行一些很重要的简化。

在一个样例中,他们所面临的是单体应用中的已有组件。因为团队是基于Java EE 的,所以具体的表现形式就是多个WAR(Web Archive)或JAR(Java Archive),这些文件会放到一个EAR(Enterprise Archive)中,但是这个例子本身与编程语言和框架是无关的。在这个例子中,目标是将单个组件拆分为微服务,这样当某个WAR 中的内容发生变化的时候就不需重新创建整个EAR 包了。

如果从完全重建的角度来看,这其实没有实质性的不同。不过,在分布式场景方面,我们可以采取一些变化,至少可以进行简化,这里不需要命名服务(或类似的机制)来定位各种各样的服务所在的位置,同时也不需要SLA。实际上,因为我们知道服务的API,并且这里的目标在于提升开发过程的敏捷性,所以,可以将API 硬编码到“客户端”中(应用的其他部分)。从事后来看,很多地方都是可以硬编码的。可以借助地址绑定或底层的网络,如REST/HTTP 使用URL 来表示服务的名称/ 地址,当然,这样的话需要DNS 实现绑定。

到目前为止,这是可行的,到一定程度之后,就会引入传统分布式系统的复杂性了,不过,我们还没到那一步。团队的关注点在于:“作为开发人员,我该从哪里开始拥抱微服务呢,在不开发、不安装过多基础设施的前提下,该如何取得成功呢?”。Mark Little 认为这种方式的简化/ 硬编码/ 依赖基础设施能够在一定程度上提供帮助。

当提到微服务时,我们经常读到的内容就是中心化的日志、事件驱动方式、协作(orchestration)以及部署技术,但是,当面临预先定义的组件/ 服务时,如果我们想借助微服务来提升敏捷性的话,这些技术其实并没有那么重要。借助硬编码以及一些自动化的方式,完全就能实现。

这是一种新型的微服务吗?事实上并非如此,这是一种不断演化的方式,其实与之前的CORBA 和Java EE 应用并无分别,我们会通过硬编码、接口的方式进行手动编码,随着分布式应用复杂性的不断增长,开发人员需要基础设施和工具的更多帮助。所以,这种方式毫无疑问也是微服务,因为它的目标依然是让团队更加灵活、具有独立的生命周期,只不过它更加聚焦于某一点,或者说更加实用。

在将已有的系统往微服务架构改造的过程中,Mark Little 所述的这些观点,应该会对我们提供一些借鉴和帮助。


感谢陈兴璐对本文的审校。

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

2016-04-25 19:002116

评论

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

快抛弃你错误的坚持

石君

生活随想 28天写作

从美国《拜杜法案》到中国供应链体系形成的内在逻辑

JiangX

供应链 28天写作 制造

重学JS | 异步编程 Generator()

梁龙先森

面试 大前端 编程语言 28天写作

低代码开发平台的技术路线

Sam678678

架构师训练营第二周作业 - 命题作业

阿德儿

研发管理101军规#003 实战规模化敏捷:从8人到百人的敏捷之路

爱吃小舅的鱼

程序人生 Scrum 敏捷开发

林昊获中国计算机学会杰出工程师奖,阿里中间件再获高度肯定,“三位一体”推动技术普惠

阿里巴巴云原生

阿里巴巴 阿里云 开发者 云原生 中间件

2020DevOps状态报告——变更管理

禅道项目管理

DevOps 运维 开发 趋势 自动化测试

工业传感器:工业互联网的第一道门

工业互联网

electron实战练习-三个文件实现一个命令行终端

OBKoro1

node.js Electron electron实战 命令行终端 electron学习

WebRTC ICE 状态与提名处理

阿里云视频云

阿里云 WebRTC 通信 流媒体开发 流媒体传输

备战2O2I新年资料

ios 面试

顶级!13位专家力荐Spring5为企业级开发提供一站式方案

996小迁

Java spring 编程 架构 面试

如何对AD和Exchange进行安全加固满足护网需要?

嘉为蓝鲸

安全 asm AD 邮件系统 权限

mysql字符串字段索引优化

瞌睡的李先生

MySQL 索引

新思科技静态应用安全测试解决方案获得Forrester Wave认可

InfoQ_434670063458

新思科技 Forrester Wave 静态应用安全测试

Java 程序经验小结:用私有构造器或者枚举类型强化Singleton属性

后台技术汇

28天写作

安卓开发在线!字节跳动Android研发岗这些知识点内部泄露出来了,已拿到offer

欢喜学安卓

android 程序员 面试 移动开发

高频量化交易机器人系统开发|高频量化交易机器人APP软件开发

系统开发

软件测试--selenium安装使用

测试人生路

软件测试

细节决定成败!致Android高级工程师的一封信,实战解析

欢喜学安卓

android 程序员 面试 移动开发

普通人必须掌握的五个必学理财知识

v16629866266

最近线上发生的两个坑爹锅

艾小仙

后端

GrowingIO Design 组件库搭建之开发工具

GrowingIO技术专栏

设计 大前端

新鲜出炉!阿里内部开源SpringCloud Alibaba全解(全彩版)全网首发

Java架构追梦

Java 学习 架构 面试 SpringCloud Alibaba

阿里中间件团队技术官手撸笔记,全新演绎“Kafka部署实战”,已开源

Java架构之路

Java 程序员 架构 面试 编程语言

我以为自己够牛逼了,直到看到了Alibaba专家的面试笔记,我学习了三个月,却入职京东,税前36K

Java架构之路

Java 程序员 架构 面试 编程语言

跨越全场景统一架构三大挑战,MindSpore亮出“四招”

华为云开发者联盟

深度学习 联邦学习 mindspore 算子 ai框架

阿里P8内部架构核心学习知识笔记在各大互联网上流传,限时开放下载

Java架构之路

Java 程序员 架构 面试 编程语言

快速入门案例实战:电商网站商品管理(一)

escray

elasticsearch elastic 28天写作 死磕Elasticsearch 60天通过Elastic认证考试

盘点2020 | 人生是一场马拉松-OBKoro1的2020年年终总结

OBKoro1

2020 大前端 年终总结 OBKoro1

不同类型的微服务?_语言 & 开发_张卫滨_InfoQ精选文章