内容简介:微服务架构是一种架构概念,旨在通过将功能分解到各个离散的服务中以实现对解决方案的解耦。它的主要作用是将功能分解到离散的各个服务当中,从而降低系统的耦合性,并提供更加灵活的服务支持。说到微服务,就要说说这个老头,他是一个英国人,叫做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,自定义指令,过滤器,过渡,状态管理和服务端渲染
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Release It!
Michael T. Nygard / Pragmatic Bookshelf / 2007-03-30 / USD 34.95
“Feature complete” is not the same as “production ready.” Whether it’s in Java, .NET, or Ruby on Rails, getting your application ready to ship is only half the battle. Did you design your system to......一起来看看 《Release It!》 这本书的介绍吧!