【从零开始学微服务】04.微服务架构的特点

本文涉及的产品
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 大家好,欢迎来到万猫学社,跟我一起学,你也能成为微服务专家。

大家好,欢迎来到万猫学社,跟我一起学,你也能成为微服务专家

微服务架构被技术大牛们总结出了以下九个特点:

  • 服务组件化
  • 围绕业务功能
  • 产品而不是项目
  • 强终端弱管道
  • 去中心化管理
  • 去中心化数据管理
  • 基础设施自动化
  • 容错性设计
  • 演进式设计

下面我们来逐个详细了解一下。

服务组件化

当我们谈到组件的时候,一般是指可以独立替换、可以独立升级的功能单元。在以往的架构中,我们引入组件时,使用动态链接库或jar包,甚至是一组代码。在微服务架构中,是把服务作为了组件,使用轻量级的HTTP进行远程调用。

这样做有什么好处呢?动态链接库或jar包的引入是不安全的,可以使用反射等技术手段对模块进行修改。而在微服务中服务作为组件时,不在同一个线程中,根本不能对其进行任何修改。

围绕业务功能

在以往的单体架构中,所有代码、所有逻辑、所有模块都集中在一个项目里。根据康威定理,技术团队的组织结构应该被分为:前端研发人员、后端研发人员、数据库运维人员,如下图:

微服务是倾向于围绕业务功能进行服务的划分的,所以每个服务的团队是跨职能的,可能包括所有职能的人员,如下图:

这里随便提一嘴康威定理,它是马尔文·康威(Melvin Edward Conway)在1968年4月发表论文而提出的。
马尔文·康威

其核心论点是:

Organizations which design systems are constrained to produce designs which are copies of the communication structures of these organizations.
设计系统的架构受制于产生这些设计的组织的沟通结构。

通俗的来讲:系统设计本质上反映了企业的组织机构,系统各个模块间的接口也反映了企业各个部门之间的信息流动和合作方式。

产品而不是项目

在一般情况下,项目是以交付为目的,当项目完成以后就交付给甲方或者运维团队,甚至该项目的开发团队就此解散了。

而在微服务架构中,产出的是产品。所谓的产品就是需要不断演进、不断迭代,一个团段负责产品的整个生命周期。

强终端弱管道

在SOA架构中,使用了企业服务总线(ESB)这一强管道,因为企业服务总线承担了传输协议转换、数据格式转换、服务路由、监控告警等多种功能。如下图:

在微服务中,服务之间使用轻量级的HTTP进行远程调用,也就是弱管道。而在服务自身内部需要实现一些传输协议转换、数据格式转换等功能,也就是强终端。如下图:

去中心化管理

在团队管理方面,微服务是去中心化的。负责每一个服务的团队一般都是自治的,包括开发、测试、运维和实施等各个方面,而不是传统的集中式的管理。

去中心化数据管理

这个特点和上一个特点很类似,它是在数据管理方面是去中心化的。在以往的单体架构中,使用的是一个中心数据,如下图;

在微服务架构中,每个服务链接的数据库是可以是不同的,甚至数据库的类型可以可以是不同的,如下图:

基础设施自动化

一个单体系统可以十分方便地通过这些环境被构建、测试和推送。

由于服务被拆分的粒度比较细,所以就会产生数量众多的服务,使用自动化的基础设施是非常必要的。也就是我们经常提及的CI/CD(Continuous Integration,持续集成,Continuous Delivery,持续交付)。

目前的DevOps实践涉及软件应用程序在整个开发生命周期内的持续开发、持续测试、持续集成、持续部署和持续监控。

容错性设计

在数量众多的服务之间进行远程调用,难免会因为底层硬件或网络的不可靠而造成失败。所以在服务被设计时就能够容忍错误,比如:超时、重试、失效转移、幂等性、熔断、限流等机制。

演进式设计

因为每个服务的独立开发、独立部署的,所以对服务的变更、升级、替换就变得相对容易。

要对一个大型单体应用进行微服务转型,肯定不是把这个大的单体应用直接干掉,建一个新的微服务系统出来,而是要以增量的、非破坏的方式把某项业务一步步抽离形成新的服务。

更深入了解

以上是对微服务的九个特点通俗易懂的介绍,如果你不满足于此,可以阅读Microserviceshttps://martinfowler.com/articles/microservices.html)进行更深入的了解。

最后,感谢你这么帅,还给我点赞


《从零开始学微服务》总目录

相关文章
|
29天前
|
弹性计算 API 持续交付
后端服务架构的微服务化转型
本文旨在探讨后端服务从单体架构向微服务架构转型的过程,分析微服务架构的优势和面临的挑战。文章首先介绍单体架构的局限性,然后详细阐述微服务架构的核心概念及其在现代软件开发中的应用。通过对比两种架构,指出微服务化转型的必要性和实施策略。最后,讨论了微服务架构实施过程中可能遇到的问题及解决方案。
|
2月前
|
Cloud Native Devops 云计算
云计算的未来:云原生架构与微服务的革命####
【10月更文挑战第21天】 随着企业数字化转型的加速,云原生技术正迅速成为IT行业的新宠。本文深入探讨了云原生架构的核心理念、关键技术如容器化和微服务的优势,以及如何通过这些技术实现高效、灵活且可扩展的现代应用开发。我们将揭示云原生如何重塑软件开发流程,提升业务敏捷性,并探索其对企业IT架构的深远影响。 ####
46 3
|
2月前
|
Cloud Native 安全 数据安全/隐私保护
云原生架构下的微服务治理与挑战####
随着云计算技术的飞速发展,云原生架构以其高效、灵活、可扩展的特性成为现代企业IT架构的首选。本文聚焦于云原生环境下的微服务治理问题,探讨其在促进业务敏捷性的同时所面临的挑战及应对策略。通过分析微服务拆分、服务间通信、故障隔离与恢复等关键环节,本文旨在为读者提供一个关于如何在云原生环境中有效实施微服务治理的全面视角,助力企业在数字化转型的道路上稳健前行。 ####
|
28天前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
154 69
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
27天前
|
运维 监控 持续交付
微服务架构解析:跨越传统架构的技术革命
微服务架构(Microservices Architecture)是一种软件架构风格,它将一个大型的单体应用拆分为多个小而独立的服务,每个服务都可以独立开发、部署和扩展。
166 36
微服务架构解析:跨越传统架构的技术革命
|
30天前
|
设计模式 负载均衡 监控
探索微服务架构下的API网关设计
在微服务的大潮中,API网关如同一座桥梁,连接着服务的提供者与消费者。本文将深入探讨API网关的核心功能、设计原则及实现策略,旨在为读者揭示如何构建一个高效、可靠的API网关。通过分析API网关在微服务架构中的作用和挑战,我们将了解到,一个优秀的API网关不仅要处理服务路由、负载均衡、认证授权等基础问题,还需考虑如何提升系统的可扩展性、安全性和可维护性。文章最后将提供实用的代码示例,帮助读者更好地理解和应用API网关的设计概念。
64 8
|
2月前
|
Dubbo Java 应用服务中间件
服务架构的演进:从单体到微服务的探索之旅
随着企业业务的不断拓展和复杂度的提升,对软件系统架构的要求也日益严苛。传统的架构模式在应对现代业务场景时逐渐暴露出诸多局限性,于是服务架构开启了持续演变之路。从单体架构的简易便捷,到分布式架构的模块化解耦,再到微服务架构的精细化管理,企业对技术的选择变得至关重要,尤其是 Spring Cloud 和 Dubbo 等微服务技术的对比和应用,直接影响着项目的成败。 本篇文章会从服务架构的演进开始分析,探索从单体项目到微服务项目的演变过程。然后也会对目前常见的微服务技术进行对比,找到目前市面上所常用的技术给大家进行讲解。
60 1
服务架构的演进:从单体到微服务的探索之旅
|
2月前
|
负载均衡 Java 持续交付
深入解析微服务架构中的服务发现与负载均衡
深入解析微服务架构中的服务发现与负载均衡
79 7
|
2月前
|
消息中间件 运维 Kubernetes
后端架构演进:从单体到微服务####
本文将探讨后端架构的演变过程,重点分析从传统的单体架构向现代微服务架构的转变。通过实际案例和理论解析,揭示这一转变背后的技术驱动力、挑战及最佳实践。文章还将讨论在采用微服务架构时需考虑的关键因素,包括服务划分、通信机制、数据管理以及部署策略,旨在为读者提供一个全面的架构转型视角。 ####
39 1
|
2月前
|
弹性计算 运维 开发者
后端架构优化:微服务与容器化的协同进化
在现代软件开发中,后端架构的优化是提高系统性能和可维护性的关键。本文探讨了微服务架构与容器化技术如何相辅相成,共同推动后端系统的高效运行。通过分析两者的优势和挑战,我们提出了一系列最佳实践策略,旨在帮助开发者构建更加灵活、可扩展的后端服务。