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

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

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

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

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

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

服务组件化

当我们谈到组件的时候,一般是指可以独立替换、可以独立升级的功能单元。在以往的架构中,我们引入组件时,使用动态链接库或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)进行更深入的了解。

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


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

相关文章
|
16天前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
16天前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
18天前
|
JSON 监控 安全
探索微服务架构中的API网关模式
【9月更文挑战第22天】在微服务架构的海洋中,API网关如同一位智慧的守门人,不仅管理着服务的进出,还维护着整个系统的秩序。本文将带你一探究竟,看看这位守门人是如何工作的,以及它为何成为现代云原生应用不可或缺的一部分。从流量控制到安全防护,再到服务聚合,我们将一起解锁API网关的秘密。
|
28天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
46 3
|
1月前
|
监控 负载均衡 应用服务中间件
探索微服务架构下的API网关设计与实践
在数字化浪潮中,微服务架构以其灵活性和可扩展性成为企业IT架构的宠儿。本文将深入浅出地介绍微服务架构下API网关的关键作用,探讨其设计原则与实践要点,旨在帮助读者更好地理解和应用API网关,优化微服务间的通信效率和安全性,实现服务的高可用性和伸缩性。
44 3
|
1月前
|
存储 Java Maven
从零到微服务专家:用Micronaut框架轻松构建未来架构
【9月更文挑战第5天】在现代软件开发中,微服务架构因提升应用的可伸缩性和灵活性而广受欢迎。Micronaut 是一个轻量级的 Java 框架,适合构建微服务。本文介绍如何从零开始使用 Micronaut 搭建微服务架构,包括设置开发环境、创建 Maven 项目并添加 Micronaut 依赖,编写主类启动应用,以及添加控制器处理 HTTP 请求。通过示例代码展示如何实现简单的 “Hello, World!” 功能,并介绍如何通过添加更多依赖来扩展应用功能,如数据访问、验证和安全性等。Micronaut 的强大和灵活性使你能够快速构建复杂的微服务系统。
64 5
|
14天前
|
Kubernetes Go Docker
掌握微服务架构:从Go到容器化的旅程
摘要,通常简短概述文章内容,要求精炼。在本文中,我们将打破常规,采用一种故事化叙述的摘要,旨在激发读者的好奇心和探究欲: “从宁静的海滨小城出发,我们踏上了一场技术探险之旅,探索微服务架构的奥秘。我们将学习如何用Go编写微服务,以及如何通过Docker和Kubernetes将它们打包进小巧的容器中。在这场旅程中,我们将遇到挑战、收获知识,最终实现应用的快速部署与可扩展性。”
|
16天前
|
Cloud Native Java 对象存储
揭秘微服务架构之争:Spring Cloud与Netflix OSS巅峰对决,谁将称霸弹性云原生时代?
近年来,微服务架构成为企业应用的主流设计模式。本文对比了两大热门框架Spring Cloud和Netflix OSS,探讨其在构建弹性微服务方面的表现。Spring Cloud依托Spring Boot,提供全面的微服务解决方案,包括服务注册、配置管理和负载均衡等。Netflix OSS则由一系列可独立或组合使用的组件构成,如Eureka、Hystrix等。两者相比,Spring Cloud更易集成且功能完善,而Netflix OSS则需自行整合组件,但灵活性更高。实际上,两者也可结合使用以发挥各自优势。通过对两者的对比分析,希望为企业在微服务架构选型上提供参考。
36 0
|
24天前
|
缓存 负载均衡 数据管理
深入探索微服务架构的核心要素与实践策略在当今软件开发领域,微服务架构以其独特的优势和灵活性,已成为众多企业和开发者的首选。本文将深入探讨微服务架构的核心要素,包括服务拆分、通信机制、数据管理等,并结合实际案例分析其在不同场景下的应用策略,旨在为读者提供一套全面、深入的微服务架构实践指南。**
**微服务架构作为软件开发领域的热门话题,正引领着一场技术革新。本文从微服务架构的核心要素出发,详细阐述了服务拆分的原则与方法、通信机制的选择与优化、数据管理的策略与挑战等内容。同时,结合具体案例,分析了微服务架构在不同场景下的应用策略,为读者提供了实用的指导和建议。
|
2月前
|
数据库 Java 数据库连接
Hibernate 实体监听器竟如魔法精灵,在 CRUD 操作中掀起自动化风暴!
【8月更文挑战第31天】在软件开发中,效率与自动化至关重要。Hibernate 通过其强大的持久化框架提供了实体监听器这一利器,自动处理 CRUD 操作中的重复任务,如生成唯一标识符、记录更新时间和执行清理操作,从而大幅提升开发效率并减少错误。下面通过示例代码展示了如何定义监听器类,并在实体类中使用 `@EntityListeners` 注解来指定监听器,实现自动化任务。这不仅简化了开发流程,还能根据具体需求灵活应用,满足各种业务场景。
33 0