内容简介:微服务架构是一种架构概念,旨在通过将功能分解到各个离散的服务中以实现对解决方案的解耦。它的主要作用是将功能分解到离散的各个服务当中,从而降低系统的耦合性,并提供更加灵活的服务支持。说到微服务,就要说说这个老头,他是一个英国人,叫做Martin Fowler,后面移居了美国。 虽然他不是微服务概念的最早提出者,不过很多人都是通过他和James Lewis的文章了解微服务的概念。这是他2014年发布的文章
微服务架构是一种架构概念,旨在通过将功能分解到各个离散的服务中以实现对解决方案的解耦。它的主要作用是将功能分解到离散的各个服务当中,从而降低系统的耦合性,并提供更加灵活的服务支持。
2. 微服务的历史
说到微服务,就要说说这个老头,他是一个英国人,叫做Martin Fowler,后面移居了美国。 虽然他不是微服务概念的最早提出者,不过很多人都是通过他和James Lewis的文章了解微服务的概念。
这是他2014年发布的文章 martinfowler.com/articles/mi…
而微服务最早的提出是2012年,是这个家伙说的,就是上面和Martin Flower合作出了文章的James Lewis。 James Lewis是ThoughtWorks的首席顾问,也是技术顾问委员会的成员。
俺寻思这人也是个神人,为了写这篇文章,就用谷歌和维基搜了一下,谁知道他这么没有牌面,只有推特以及上面那篇文章找到一个头像及简介。
3. 传统架构与微服务架构的区别
开发模式
在传统的开发模式中,我们将所有功能打在一个 WAR 包内,基于三层架构和 MVC 来对应用进行解耦,并部署在一个 JavaEE 容器中。我们可以方便的对其进行集中式管理,与微服务架构相比,因为所有功能都在本地,所以功能间没有通信的问题。
单体架构
微服务架构
我们可以看出,微服务架构通过将复杂单体应用进行细粒度的拆分,可以分别部署成不同的服务。再将功能模块解耦后,不仅可以降低单独服务器的压力,因为都是独立拆分出来的服务,也能实现独立部署独立开发。
这样的好处显而易见,拆分后的服务交给不同团队独立维护,进行分布式管理,彼此间不需要太多的顾忌,这样能让我们实现更方便的代码维护工作,同时开发时放心使用新的技术,而不必担心因为一个服务的故障使整个应用无法使用。
4. 微服务的实践
客户端如何访问这些服务
每个服务之间如何通信
同步调用
- REST(JAX-RS,Spring Boot)
- RPC(Thrift, Dubbo)
异步消息调用
- Kafka
- Notify
- MessageQueue
如何实现?
基于客户端的服务注册与发现
优点是架构简单,扩展灵活,只对服务注册器依赖。缺点是客户端要维护所有调用服务的地址,有技术难度,一般大公司都有成熟的内部框架支持,比如 Dubbo
基于服务端的服务注册与发现
优点是简单,所有服务对于前台调用方透明,一般在小公司在云服务上部署的应用采用的比较多。
这是一个Spring Cloud Netflix 的 demo
以上所述就是小编给大家介绍的《微服务的概念》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 微服务基本概念和核心组件(200709)
- 微服务那些高大上的概念
- 火爆开发概念之——微服务实践篇
- Spring Cloud构建微服务架构:消息驱动的微服务(核心概念)【Dalston版】
- 原 荐 一, 跨语言微服务框架 - Istio 简绍和概念
- Vue.js 高级概念:Mixins,自定义指令,过滤器,过渡,状态管理和服务端渲染
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
PHP+MySQL八大动态Web应用实战
Jono Bacom / 吴连河、李剑 / 电子工业出版社 / 2008-6 / 68.00元
本书详细介绍了利用PHP+MySQL开发常见类型Web应用程序的完整设计和编码技术,并对整体设计与关键代码给予了细致、深入的剖析。其内容注重实践,提供了翔实完整的实战代码;思路独树一帜,突破过多描述语言细节的窠臼;行文风趣幽默,轻松调侃中将项目的完整设计过程分析得一清二楚。书中的示例项目完整而实用,读者甚至无需任何改动即可在实际中加以运用。. 本书适合对PHP/MySQL有初步了解但缺乏完整......一起来看看 《PHP+MySQL八大动态Web应用实战》 这本书的介绍吧!