微服务指南走北(一):微服务是什么

微服务“Microservices”已经成为软件架构最流行的热词之一。网络上看到很多关于微服务的文章,但是感觉很多离我们还很遥远,并且没有找到多少真正在企业场景中应用的实例。此处省略一万字~~~~于是想要将自己最近一段时间使用微服务以及通过看大师们的文章的所思所想梳理出来,分享出来,以供大家参考(热切欢迎大家拍砖,头破血流最好)。

一、什么是微服务

  1. 记得刚看到微服务的时候,注意点在微字上,然后才是服务,初步理解为:将整块儿的服务拆分成多个类似工具类的微小web服务,供其他服务调用,每个服务应该是极其微小的,就像各个零件一样,各司其职,拼装成一个伟大的服务群

  2. 由于自己是技术出身,对理论并不是很重视,于是基于初期的理解,就向着“微服务”(这里要打引号,不然会被拍板砖)迈进。先是实现了微服务的多种搭建方式,听说有springboot的、有jersey+jetty的、有Python的、有NodeJS的等等。进而了解到,微服务主要是以restful风格架构以提供服务(还有Thrift),rest的实现是HTTP的“请求-响应”,而rest是基于资源的API风格,进而可以理解微服务是多个能够表现对一个资源及对此资源执行的操作集成的服务。既然是对一个资源的使用及操作,那么每个微服务应该是独立的个体。

  3. 基于以上理解,迫不及待的使用“微服务”来实现自己手上的业务需求,就拿简单的客户信息管理系统为例:主要有客户信息管理、用户管理、组织架构管理等(这里不多举例)。根据之前的理解,客户、用户、组织架构,应该是三种不同的资源,那么应该分为三个不同的微服务。可是某一层组织架构下,会有多个用户,而某个用户又会拥有属于自己的多个客户,如此并没有办法将三个服务彻底分离(还是有关联关系),这不符合之前的理解。然而业务关系上,三者的联系必不可少,存在即合理,那么也理应是三个微服务互相协作而又相互独立的关系。如同团队成员之间的协作关系,相互独立而又相互依赖。

小结:微服务是基于Restful风格的,基于资源及资源操作一组API的集合,可以实现模块儿或者说是特定的业务范围内的一个完全独立、细粒度、自包含的一个服务。每个微服务提供一组API,供其他微服务或者应用客户端所用。


二、什么是微服务架构

既然提到微服务架构,那么单体应用架构以及SOA架构也必须拿出来聊聊。

1. 什么是单体应用:

说到单体应用,直接举例来说吧,典型的单体应用有ERP、CRM、BPM等软件。对于ERP和大型的CRM应用来说,可能一个软件就包含有数百个功能点。对于此类软件的开发、维护、部署、纠错、扩展及升级对于相关人员来说都将是大麻烦(噩梦)。

2. 什么是SOA架构

SOA是解决单体应用架构的问题的一个解决方案:SOA是面向服务的体系架构,是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来。既然每个服务是有不同的功能单元组成,那么这个服务的范围就非常广了。

SOA架构与微服务架构比较相似,以至于国外不少人范围微服务的原因是认为微服务只是对SOA的二次包装。这里不去讨论SOA与微服务的长短,这个要讨论估计要三天三夜了吧~~~

3. 什么是微服务架构

表面上看,微服务架构范式与 SOA 非常类似,这两种架构都包括一套服务。然而,微服务架构范式被看作不包含某些功能的 SOA 。这些功能包括网络服务说明( WS-* )和 Enterprise Service Bus (ESB) 的商品化和请求包。基于微服务的应用更青睐 REST 这样简单的、轻量级的协议,而不是 WS-* 。他们也极力避免在微服务中使用 ESBs 及类似功能。微服务架构范式也拒绝 SOA 的其它部分,比如 canonical schema 的概念(摘自“Chris Richardson 微服务系列”)。


三、微服务架构的好处与不足

微服务架构的好处

  1. 可以解决复杂性的问题,在功能不变的情况下,分解为多个相互协作的微服务,通过rest API定义边界,这样极大易于开发、理解和维护。

  2. 微服务架构是的每个服务可以由专门的开发团队或者个人开发者进行开发,开发者可以自由选择技术,不必受制于规定的技术和框架,只要API服务协议好交互方式即可(如restful)。这样即使重新技术过时的微服务模块儿或者重写以前的代码,也不是很困难。

  3. 微服务架构模式使得每个微服务独立部署,且每个服务独立扩展,开发者不再需要协调其它服务部署对本服务的影响。微服务架构模式使得持续化部署成为可能。

微服务架构的不足

  1. "微服务"强调了服务大小,所以很多人的关注点主要在“微”字上,尽管小服务更容易被采用,但是微服务只是结果,而不是最终目的。微服务的目的是有效拆分应用,实现敏捷开发和部署。

  2. 微服务应用是分布式系统,必然会带来固有的复杂性,开发者需要协议消息传递规则的选择并完成进程间通讯。相对于单体应用,微服务下这种技术显得更加复杂一些。

  3. 关于微服务的数据库架构,由于同一事务更新多个业务很普遍,这种事务操作对于单体应用来说很容易解决,因为只有一个数据库,而在微服务架构中,由于每个微服务使用不同的数据库,使用分布式事务并不一定是好的选择。并且现在高扩展性的NoSQL数据库和消息传递中间件并不支持这样的需求。从而对开发者提出了更高的要求和挑战。

  4. 由于微服务架构的分布式特点,测试一个基于微服务架构的应用也是很复杂的任务。测试单个微服务的一套REST API 相对简单,但是往往要启动与之相关的所有服务。所以,采用了微服务架构带来的并不仅仅是敏捷开发和部署,还会带来一定的复杂性。

  5. 微服务架构模式下,应用的改变将会波及多个服务。比如,假设你在完成一个需求,需要修改服务A、B、C,而A依赖B,B依赖C。在单体应用中,你只需要改变相关模块,整合变化,部署就好了。对比之下,微服务架构模式就需要考虑相关改变对不同服务的影响。比如,你需要更新服务C,然后是B,最后才是A。幸运的是,许多改变一般只影响一个服务,而需要协调多服务的改变很少。

  6. 部署一个微服务应用也很复杂,一个单体应用只需要在复杂均衡器后面部署各自的服务器就好了。每个应用实例是需要配置诸如数据库和消息中间件等基础服务。相比之下,一个微服务应用一般由大批服务构成。根据 Adrian Cockcroft 的分享,Hailo 由 160 个不同服务构成,而NetFlix则超过600个服务。每个服务都有多个实例,这就形成大量需要配置、部署、扩展和监控的部分。除此之外,你还需要完成一个服务发现机制,以用来发现与它通讯服务的地址(包括服务器地址和端口)。传统的解决问题办法并不能解决这么复杂的问题。最终,成功部署一个微服务应用需要开发者有足够的控制部署方法,并高度自动化。(摘自“Chris Richardson 微服务系列”)

  7. 根据上一点的描述,在微服务架构的应用中,往往有很多个微服务实例,并且每个服务都有多个实例,那么服务的自动化部署必然与服务发现机制同样要解决。


参考文章

微服务实战:从架构到部署

创建微服务?请先回答这10个问题

by 刘迎光@萤火虫工作室
OpenBI交流群:495266201
MicroService 微服务交流群:217722918
mail: liuyg#liuyingguang.cn
博主首页(==防止爬虫==):http://blog.liuyingguang.cn

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

推荐阅读更多精彩内容