微服务的概念

栏目: 后端 · 发布时间: 6年前

内容简介:微服务架构是一种架构概念,旨在通过将功能分解到各个离散的服务中以实现对解决方案的解耦。它的主要作用是将功能分解到离散的各个服务当中,从而降低系统的耦合性,并提供更加灵活的服务支持。说到微服务,就要说说这个老头,他是一个英国人,叫做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


以上所述就是小编给大家介绍的《微服务的概念》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

移动风暴

移动风暴

[美]弗雷德·沃格尔斯坦 / 朱邦芊 / 中信出版社 / 2014-1-1 / 39

也许,除了伟大的乔布斯,每一位奋力改变世界的硅谷英雄,都值得我们肃然起敬。苹果与谷歌十年博弈,关于这场移动平台战争的报道早已铺天盖地,而这是第一次,我们能听到幕后工程师的真实声音。两大科技巨人用智能手机和平板电脑颠覆了电脑产业。它们位处变革的中心,凭借各自的经营哲学、魅力领袖和商业敏感度,把竞争变成了残酷对决。商业记者沃格尔斯坦报道这场对抗已逾十载,在《移动风暴》中,他带领我们来到一间间办公室和会......一起来看看 《移动风暴》 这本书的介绍吧!

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具