什么是分布式微服务?
- 前言
- 什么是微服务
- 举例说明
- 什么是分布式
- 图解分布式与微服务
- 单体架构及部署
- 微服务架构
- 分布式
- 影响
- 分布式微服务架构
- 什么是分布式微服务架构
- 面临的问题
前言
本文旨在讲清楚什么是分布式微服务架构
,通过解释微服务架构和分布式架构
,来理解分布式微服务架构
,并且揭示了其相较于单体架构
的优点,以及该架构面临的问题
。
在介绍分布式微服务之前,我们先从名字分析,这个名词包含了两部分,第一部分:分布式
,第二部分:微服务
。如果搞清楚了这两个,那么基本上就弄明白了。
什么是微服务
微服务
是一种架构
风格,用于构建分布式系统
(关于什么是分布式,这个后文会提到)。
它将一个大型应用程序
拆分为一组小型的、自治的服务
,每个服务都运行在独立的进程中,并通过网络进行通信
。每个微服务专注于解决特定的业务问题
,并可以独立地进行开发、部署和扩展。
关于什么是架构风格:
架构风格是指软件系统中构件(可以理解系统的构成部分)的组织方式和连接方式,
反映了领域中众多系统所共有的结构和语义特性(比如看一个生物是不是牛,那就去它身上找牛的特征 符合特征的就是牛 不符合的就不是),
并指导如何将各个构件有效地组织成一个完整的系统(也就是搭建系统)
比如最常见的单体架构风格,就是把所有的功能都塞到一个应用里面,然后打包以及部署
举例说明
举个例子,假设我们有一个在线电影平台的网站。
在传统的单体架构
中,所有的功能,例如用户管理、电影管理、支付管理
等,都被打包在一个单一的应用程序中
。
这个应用程序负责处理用户的注册和登录、浏览电影、下订单和支付
等操作。
现在,我们可以使用微服务架构
来构建这个电影平台。我们可以将不同的功能模块拆分为独立的微服务
,例如上面提到的功能可以划分为用户服务、电影服务、订单服务和支付服务
。
在这里我要插一句,上述是按功能来划分服务,但在实际开发中,不一定是按功能拆分。
拆分的方式有很多,可以从功能维度,就是上面的这种,
也可以从别的维度拆分,如业务域维度或者数据维度等等。
用户服务负责处理用户的注册和登录功能
,它有自己的数据库来存储用户信息。当用户进行注册时,用户服务会验证用户信息,并将用户信息存储在自己的数据库中。
电影服务负责管理电影的信息
,例如电影的标题、演员、评分等。它也有自己的数据库来存储电影信息。当用户浏览电影时,电影服务会提供电影列表和详细信息。
订单服务负责处理用户下订单的功能
。当用户下订单时,订单服务会验证订单信息并将订单存储在自己的数据库中。
支付服务负责处理支付过程
。当用户确认支付时,支付服务会与支付网关进行通信并完成支付操作。
这样,不同的功能模块被拆分为独立的微服务,它们可以独立开发、部署和扩展
。每个微服务都有自己的责任范围,可以根据需要独立进行扩展或升级。微服务之间通过网络进行通信
,使用轻量级的通信协议,如HTTP或消息队列。
什么是分布式
在我们日常在网站搭建的上下文中,提到的分布式通常指的是分布式系统架构
。
在这种架构下,一个网站的功能被拆分为多个独立的服务,这些服务分布在不同的计算机节点上
,并通过网络进行通信和协作
(注意这一句,这些服务分布在不同的计算机节点上
)。
每个服务负责特定的功能或模块
,它们可以独立地
进行开发、部署和扩展。这种分布式架构可以提高网站的性能、可靠性和可扩展性。
图解分布式与微服务
下面的图简单揭示了将一个单体架构的系统,转变为上述微服务和分布式架构的过程
。
单体架构及部署
微服务架构
首先使用微服务架构会将功能拆分为一个个的微服务
注意这里,拆分后的每个服务都是一个小的、独立的应用程序
,可以单独测试、部署以及扩展
。
分布式
然后将这些微服务部署到服务器上,这就是分布式
上述是每个服务都部署到一个不同的服务器
上,但在实际开发中要按照服务器的规格来部署
,有的可能可以部署两个或者三个,有的可能只能部署一个。
值得注意的是,同样的服务可能部署多个
,可能有时候用户支付比较频繁,一个服务不够用,那么我就可以再部署一个支付服务上去
,以提供更加稳定、快速的响应,比如以下这样:
影响
别看我们上面又是将单体应用的功能拆分成微服务,又是分开部署的
,但要说对用户的有什么负面影响的话,我的回答是基本没有
,从用户使用体验
来说,和之前的单体架构没有什么区别的。
要说有的话那就是他们会觉得响应越来越快,越来越稳定。
如果你也这么觉得的话,我觉得那真是泰裤辣!
其实将单体应用拆分为微服务并进行分布式部署
对用户基本是百利无一害
,要硬说有的话,那一害,害的是程序猿
。
单体架构改为微服务和分布式架构
以后,大概会造成以下影响:
-
性能改善
:通过微服务架构和分布式部署,可以提高系统的性能和响应
能力。每个微服务可以独立扩展和优化,从而提供更快速的响应时间和更高的并发处理能力。 -
可用性增强
:微服务架构的分布式部署可以提高系统的可用性。如果其中一个微服务出现故障,其他微服务仍然可以继续工作,避免整个应用停止运行
。这意味着用户可以继续使用其他可用的功能而不会完全失去服务。 -
更好的扩展性
:微服务架构允许根据需求独立扩展每个微服务
(参考之前提到的支付服务)。这意味着当用户量增加时,可以根据需要增加相关微服务的实例数,以应对高负载。这样可以确保系统在用户增长期间仍然保持稳定的性能和可用性。 -
独立功能开发和部署
:微服务架构允许不同的团队独立开发和部署各个微服务
。这样可以加快新功能的上线速度,并允许更灵活的迭代和持续交付。用户可以更快地获得新功能和改进,而无需等待整个应用程序的发布。 -
潜在的复杂性增加
:微服务架构和分布式部署可能引入一定的复杂性。由于需要管理多个微服务和它们之间的通信,涉及到一些额外的技术和工具
。这可能导致对开发、部署和运维的一些挑战,需要适当的管理和资源投入。
简单总结一下就是:
从系统
的角度出发,微服务架构和分布式部署可以带来更好的性能、可用性和扩展性
。
而用户
可以获得更快的响应时间,更稳定的服务,并且更快地获得新功能
。
但对于开发者
说,需要注意潜在的复杂性和管理挑战
,并确保适当的监控和故障处理机制以保证用户体验的一致性
。
分布式微服务架构
相对于分布式架构和微服务架构,可能大家对这个词更加熟悉:分布式微服务架构
什么是分布式微服务架构
将上面的两种架构方式合到一起就变成了:分布式微服务架构
。
在分布式微服务架构中,一个大型的应用程序将会被拆分为多个小而自治的服务单元
,每个服务单元独立运行在分布式环境中
,并通过轻量级的通信协议进行相互通信。每个服务单元都专注于完成特定的业务功能,并可以独立地进行开发、部署、扩展和维护。
分布式微服务架构有助于解决传统单体应用程序
的复杂性和可扩展性问题,提供更灵活、可靠和可维护的系统架构
。它适用于大型、复杂的应用程序
和需要快速迭代的敏捷开发环境。通过拆分应用程序为多个服务单元,分布式微服务使得团队可以更快地交付业务价值,并更好地应对不断变化的业务需求。
面临的问题
分布式微服务架构虽然相较于传统的单体应用具有很多的优点,但是其在提出之际面临的问题也不少,大概是以下几个方面,以下描述中微服务简称为服务
:
-
各服务间通信和调用
:
在一个分布式系统中,服务之间需要进行通信和调用来完成业务功能
。
我该如何确保通信的可靠性、安全性,以及如何避免服务之间的耦合
? -
服务注册与发现
:
在一个分布式系统中,有大量的微服务实例需要管理和发现
。
我该如何有效地注册和发现这些服务实例,以便其他服务可以动态地与它们进行通信
? -
负载均衡
:
在有多个服务实例
的情况下(比如之前图中存在的多个支付服务
},
我该如何合理地分配负载
? -
服务容错和故障恢复
:
服务可能会遇到故障、网络延迟或异常
等问题。
我该如何处理服务故障和不可用情况,实现服务的容错和故障恢复
? -
数据一致性和事务管理
:
在分布式系统中,由于服务之间的数据交互和操作
,并发情况下可能出现数据一致性
的问题。
我该如何处理分布式环境下的数据一致性,确保事务的原子性、一致性、隔离性和持久性
?。 -
分布式系统的监控和调试
:
在分布式系统中,需要对各个服务的运行状态、性能指标和日志进行监控和调试,以及及时发现和解决问题
。
我该如何实现对分布式系统的监控、日志聚合、异常跟踪和性能分析
? -
部署和扩展
:
在分布式微服务架构中,如何有效地部署和扩展
服务,以适应不断变化的需求和负载。比如我今天突然要加两到三个支付服务
,那我该怎么做?
也就是我该如何自动化部署服务、实现弹性扩展和平滑升级,同时保持系统的高可用性和稳定性
?
这些问题能不能解决?又如何解决?本文后续主角Spring Cloud Alibaba
将会给出答案。