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

news2024/11/17 11:23:07

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

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

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

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

服务组件化

当我们谈到组件的时候,一般是指可以独立替换、可以独立升级的功能单元。在以往的架构中,我们引入组件时,使用动态链接库或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实践涉及软件应用程序在整个开发生命周期内的持续开发、持续测试、持续集成、持续部署和持续监控。

容错性设计

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

演进式设计

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

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

更深入了解

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

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


《从零开始学微服务》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/31285.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python 快速入门

文章目录Python 快速入门1 环境配置1.1 简介1.2 Python 安装1.3 其余软件1.4 编辑器的使用2 基础语法2.1 特点2.2 代码块2.3 注释3 数据类型3.1 变量类型3.2 数据结构3.3 运算符3.3.1 逻辑运算符3.3.2 比较运算符3.3.3 算术运算符3.3.4 布尔运算符4 流程语句4.1 循环语句4.1.1 …

Android App网络通信中通过okhttp调用HTTP接口讲解及实战(包括GET、表单格式POST、JSON格式POST 附源码)

需要全部源码或运行有问题请点赞关注收藏后评论区留言~~~ 一、通过okhttp调用HTTP接口 尽管使用HttpURLConnection能够实现大多数的网络访问操作,但是操作过于繁琐,于是Andorid从9.0是使用okhttp这个框架 由于okhttp属于第三方框架 所以使用前要修改模…

我们的程序是如何跑起来的?

1.我们写的代码写完并测试以后是如何部署给用户使用的? 1. 准备所需要的服务器 2. 在服务器上安装JDK、mysql、redis、Tomcat、Nginx等环境 3. 进行mysql、redis、nginx的连接配置 4. 项目打包。前端构建打包成功后在根目录dist文件夹中;后端打成jar包&#xff0c…

基于改进海洋捕食者算法求解单目标优化问题附matlab代码(NMPA)

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。 🍎个人主页:Matlab科研工作室 🍊个人信条:格物致知。 更多Matlab仿真内容点击👇 智能优化算法 …

VLAN网络支持ipv6的交换机和虚机配置

VLAN支持ipv6的交换机和虚机配置前言一、创建VLAN网络并配置交换机1.规划并在OpenStack上创建 VLAN网络2.在交换机上配置VLAN二、Ubuntu虚机配置1.创建虚机2.在OpenStack上查看port3.登录虚机配置网卡3.1登录虚机后,发现虚机没获取到openstack上对应port的ipv6地址。…

Qt编写跨平台视频监控系统(64通道占用7%CPU/支持win_linux_mac等)

一、前言 视频监控组件经历过数十年的迭代,从最初的只简单播放个rtsp视频流,到现在支持各种音频视频文件格式(mp3、wav、mp4、asf、rm、rmvb、mkv等)、支持各种视频流格式(rtp、rtsp、rtmp、http等)、支持…

10个JavaScript常见高级知识点

今天,给大家分享的是一篇干货知识《10个JavaScript常见高级知识点》,主要针对初级前端和想要面试找工作的同学,想要学好前端,除了要掌握JavaScript的基础知识外,还需要掌握一些高级的知识点。 学会了下面这些常见的高…

鼠标经过图片在边框内放大动效

鼠标没有经过: 鼠标经过的时候,看图,应该可以看出变化吧!图有放大的效果。 样式:图片由一个盒子包着,盒子加上overflow:hidden的样式,即可以保证图片在边框内放大。 然后给图片加上动画效果就可…

JavaWeb开发之——数据库设计(20)

一 概述 数据库设计-简介数据库设计-多表关系实现数据库设计-案例 二 数据库设计-简介 2.1 软件的研发步骤 2.2 数据库设计概念 数据库设计就是根据业务系统的具体需求,结合我们所选用的DBMS(Database Management System-数据库管理系统),为这个业务系…

运动哪种耳机好用,推荐五款适合运动的耳机分享

​经常佩戴耳机的小伙伴都知晓传统的蓝牙耳机相对于有线耳机来说比较方便,但也存在着耳道一直堵塞导致细菌的滋生等因素的存在,但在近些年火热的骨传导耳机却能够将这些问题一一化解,基本可以说是百利而无一害,所以今天我就给小伙…

第一章 计算机系统体系结构

1.1 什么是计算机体系结构 本章的第一个概念是计算机系统(computer system)。 计算机系统包括读取并执行程序的 中央处理单元(CPU, 保存程序和数据的存储器以及将芯片转换为实用系统的 其他子系统。 这些子系统会使CPU与显示器、打印机、Internet等外部设备之间的…

【优化求解】整数规划求解机票超售优化赔付问题【含Matlab源码 2182期】

⛄一、问题 A航空公司每天有6班航班从上海到北京,从上午10点到晚上8点,每两小时发一班航班。某天获知,前三班机每班可以容纳100名旅客,后三班机每班可以容纳150名旅客。如果某次航班超售,A航空公司可以把某预定了该次…

【JSP/Servlet】基于WEB的通讯录系统

巩固JSP/Servlet系统开发描述步骤系统功能描述一、创建一个登录页面二、模拟数据(用数据库模拟用户名和密码还有用户的通讯录)三、创建一个JDBC工具类四、判断在登录页面输入的用户名和密码是否正确五、利用cookie实现保存六、以表格形式显示出我的通讯录…

2022最新MySQL面试题-有详细完整的答案解析

MySQL专题面试题 MySQL中有哪些存储引擎? InnoDB存储引擎 InnoDB是MySQL的默认事务型引擎,也是最重要、使用最广泛的存储引擎。它被设计用来处理大量的短期(short-lived)事务,应该优先考虑InnoDB引擎。 MylSAM存储引擎 在MySQL 5.1及之前的…

操作简单的BI数据分析软件有哪些?实际体验如何?

使用者没有IT基础,不懂代码,又需要对大量复杂的数据进行深度分析;分析效率要高;报表要直观易理解;最好能让每个浏览者都自己动手做分析。现在市面上,能够满足这些要求的BI数据分析软件有哪些?实…

一文速通MybatisPlus

目录 Mybatis-plus简介 MP特性 框架的结构 MP快速入门 配置日志输出 主键生成策略 自动填充 方式一:数据库级别 方式二:代码控制级别(常用) 乐观锁和悲观锁 测试乐观锁单线程成功的例子 乐观锁多线程失败案例 查询操作 分页查询 删除操作 删除…

C++ 手动实现单向循环链表(课后作业版)

单向循环链表&#xff0c;并实现增删查改等功能 首先定义节点类&#xff0c;类成员包含当前节点的值&#xff0c; 指向下一个节点的指针 循环链表的尾节点指向头节点 节点定义&#xff1a; //node definition template <typename T> class Node { public:T value;Nod…

Vue的生命周期快速入门

图示 流程 new Vue()实例化一个vue实例&#xff0c;然后init初始化event 和 lifecycle&#xff0c; 其实这个过程中分别调用了3个初始化函数&#xff08;initLifecycle(), initEvents(), initRender()&#xff09;&#xff0c;分别初始化了生命周期&#xff0c;事件以及定义cr…

k8s 资源管理及查看命令

关注 迪答数据 公众号获取更多 技术/数据 干货文章 文章传送门&#xff1a;数据治理之指标体系管理 管理容器的计算资源 参考文档&#xff1a; Kubernetes Managing Compute Resources for Containers(opens new window)https://kubernetes.io/docs/concepts/configuration/m…

go slice 扩容机制

前言 go语言没有ArrayList这样的封装&#xff0c;但是官方原生提供slice&#xff0c;底层就是数组存储&#xff0c;并且能自动扩容&#xff0c;相较于ArrayList的默认10&#xff0c;扩容5&#xff0c;slice的逻辑是有区别的。slice默认容量0。 demo go版本号 huahuaMac-min…