【Spring Cloud一】微服务基本知识
系列文章目录
微服务基本知识
- 系列文章目录
- 前言
- 一、系统架构的演变
- 1.1单体架构
- 1.2分层架构
- 1.3分布式架构
- 1.4微服务架构
- 1.5分布式、SOA、微服务的异同点
- 二、CAP原则
- 三、RESTful
- RESTful的核心概念:
- 四、共识算法
前言
在实际项目开发过程中,目前负责开发的系统整体的架构采用的是微服务架构。对于微服务架构的认识只是停留在应用层面上,对于微服务的全貌并不是很清晰。最近想要对微服务的认知上更近一步,所以就重新梳理了一下微服务的基础知识。
一、系统架构的演变
1.1单体架构
什么是单体架构:
将一个完成的应用程序作为一个单一的、整体的单元来构建和部署。所有的功能和模块都集中在一个代码库中。共享同一个数据库,相应的也部署在同一个服务器上——单体架构。

单体架构出现的原因:
早期的Java应用程序一般采用单体架构,这是因为在用用程序刚刚开始开发的时候,规模小,并且单体架构简单易于部署。
单体架构的优缺点:
优点:开发简单、易于部署、单一数据库事物
缺点:随着业务增长会面临扩展性和维护性等问题。
1.2分层架构
什么是分层架构:
分层架构将应用程序划分为多个层次(表现层、应用层、数据访问层),每个层次负责不同的功能,用于实现代码的复用和职责的分离。


分层架构出现的原因:
为了解决单体架构的扩展性和维护性问题,演变为采用分层架构。分层架构将应用程序划分为多个层次(表现层、应用层、数据访问层),每个层次负责不同的功能,用于实现代码的复用和职责的分离。
分层架构的优缺点:
优点:代码复用、职责清晰、易于维护。
缺点:复杂性(在一些复杂的业务场景下,层与层之间的交互可能变得复杂)。大型系统中可能导致模块之间的耦合。
1.3分布式架构
什么是分布式架构:
分布式架构是一种设计模式,是将大型应用拆分成多个独立的子系统或服务,并将这些子系统部署在不同的服务器上。通过网络进行通信和协作。

分布式架构出现的原因:
随着互联网的发展和业务的增长,单体架构和分层架构在面对大规模用户和高并发访问时已经不够灵活和高效。因此,Java应用程序逐渐演变为分布式架构,将应用程序拆分成多个独立的服务。
分布式架构的目标:
提高系统的高性能、可伸缩性;高可用性和容错性,来提高系统的整体性能。
分布式架构的优缺点:
优点:横向扩展、高可用性、灵活部署
缺点:系统复杂、通信开销、分布式事务难以处理。
1.4微服务架构
在说微服务架构的时候先了解一下SOA(Service-Oriented Architecture)
SOA是一种软件架构风格,核心思想是将应用程序的功能划分为一组相对独立的服务,这些服务可以通过网络进行通信,并可以按需组成更大的应用系统。
SOA的目标:
强调松耦合和服务的重用,使系统更易于可扩充、可维护、可复用。SOA可以用于实现分布式系统,但并不限定于分布式系统。
了解了SOA架构之后我们再看看微服务架构。
什么是微服务架构:
微服务架构是一种特殊的SOA风格,它将应用程序划分为一组小型、独立的服务。每个服务都专注于一个特定的业务功能。
微服务架构强调将应用程序**差分成更小的、自治的、独立部署和松耦合服务。每个服务都有自己的数据库和业务逻辑。**与SOA相比微服务架构的粒度更小。

微服务架构的优缺点:
优点:
- 模块化和解耦合:将真个系统拆分为一组小型、独立的服务。每个服务都专注于一个特定的职责。
- 独立部署和伸缩性:每个服务都是独立的,可以单独部署也可以根据需求对服务进行水平扩展。
- 更好的团队协作:每个微服务都是独立的,可以由不同的团队开发和维护,提高团队的自治性和工作效率。
- 简化持续交付:由于每个服务都是独立的,可以更轻松的持续集成和交付,减少了系统的发布风险和交付时间。
缺点:
- 系统复杂性:每个服务都是独立的,需要通过网络进行通信。增加了系统的复杂性,包括网络通信、服务发现、负载均衡等方面。
- 部署和运维复杂性:微服务架构涉及多个服务的部署和运维,需要管理大量的服务。增加了部署和运维的复杂性。
- 数据一致性和分布式事物的问题:由于微服务架构中每个服务都有自己的数据存储。可能会导致数据一致性的问题。
1.5分布式、SOA、微服务的异同点
相同点:
他们都将应用程序拆分成多个组件或服务,并通过网络进行通信和协作。
都强调松耦合、可扩展、可维护、可复用。
不同点:
1.分布式架构是一种概念上的设计模式,用于解决系统的性能和可扩展问题,强调的是分担和资源的合理利用。
2.SOA是一种软件架构风格,核心思想是将应用程序划分为一组相对独立的服务,并通过标准化的协议进行通信,以实现松耦合和服务的重用。
3.微服务架构是SOA的一种实践方式,它强调将应用程序拆分为小型、独立的服务,每个服务都有自己的数据库和业务逻辑,来实现更高的自治和独立部署、松耦合。
二、CAP原则
cap是分布式系统中三个重要的属性。
一致性(Consistency):各个子系统看到的数据都是相同的。数据都是一致性。
可用性(Availability):分布式系统能够在任何时刻都能对外提供服务,保持持续的可工作状态,不因故障而中断服务。当一个子系统挂掉了,整个系统可以继续对外提供服务
分区容忍性(Partition Tolerance):
分区容忍性关注的是分布式系统在面对网络分区的情况下仍然能够正常运行,而不会因为分区而导致整个系统不可用。
由于网络或者分区等原因会导致各个子系统中的数据短暂不一致
一般来说,大多数分布式系统会优先考虑分区容忍性和可用性,因为网络分区是不可避免的,而一致性可以通过其他手段来解决
补充:zookeeper遵循CP、Eureka遵循AP
三、RESTful
RESTful(Representational State Transfer 表述性状态转移)是一种设计和构建网络应用程序的架构风格。是最初由Roy Fielding在他的博士论文中提出,并成为了HTTP协议的一种应用方式。
RESTful架构的设计目标是:使网络应用程序具有简介、可伸缩、可维护、可扩展和易于理解。
RESTful的核心概念:
- 资源(Resources):在RESTful中,所有事物都被看做为资源,例如用户、订单,并且每个资源都有一个唯一的标识符(通常是URL)用于访问资源和操作资源。
- 无状态性:RESTful架构要求每一个请求都应该包含足够的信息,使服务器能够理解和处理,不需要依赖之前的请求或者会话状态,服务器不保存客户端的状态信息,这使得系统更具伸缩性和简洁性。
可伸缩性示例:
假设有一个电子商务网站,它使用RESTful API来处理客户端的请求。由于RESTful架构是无状态的,服务器不会保存客户端的状态信息,每个请求都包含足够的信息来执行操作。这使得该网站可以轻松地水平扩展,即通过增加服务器节点来处理更多的请求负载。
如果服务器需要保存大量的客户端状态信息,例如会话信息、购物车内容等,那么在进行水平扩展时,需要确保所有服务器节点之间的状态同步,这增加了复杂性并降低了可伸缩性。而在RESTful架构下,无状态性消除了这种状态同步的需求,使得系统的扩展更加简单和高效。
简洁性示例:
考虑一个社交媒体应用程序,使用RESTful API来处理用户发布新帖子的请求。用户在每个请求中提供了必要的信息,例如帖子内容、标签等。服务器无需维护用户的会话状态,而是根据请求的信息处理每个帖子的发布。
在这种情况下,RESTful架构简化了服务器的逻辑和状态管理。服务器无需关心用户的上下文或会话状态,只需根据请求的内容处理每个帖子。这种简洁性使得服务器的代码更易于编写、测试和维护。
- 统一接口:RESTful架构使用统一的接口规范来定义资源的操作方式。这种统一性使得不同的客户端可以通过相同的接口与服务器进行通信。
RESTful API使用标准的HTTP方法(GET、POST、PUT、DELETE等)来对资源进行操作。客户端通过不同的HTTP方法来执行不同的操作,比如获取资源、创建新资源、更新资源或删除资源。

- 按需编码:服务器可以将资源在不同的表示形式(如JSON、XML等)之间进行转换,根据客户端需求返回不同的表现形式。客户端通过HTTP头部信息来指定期望的表示形式。
符合RESTful原则的架构方式就可以称为RESTful。
四、共识算法
共识算法常常被用于集群服务中的主从模式中。
什么是共识算法:让集群中的各个节点的数据保持一致性的一种策略。
Raft共识算法
相关文章:
【Spring Cloud一】微服务基本知识
系列文章目录 微服务基本知识 系列文章目录前言一、系统架构的演变1.1单体架构1.2分层架构1.3分布式架构1.4微服务架构1.5分布式、SOA、微服务的异同点 二、CAP原则三、RESTfulRESTful的核心概念: 四、共识算法 前言 在实际项目开发过程中,目前负责开发…...
swift - 如何在数组大小更改后刷新 ForEach 显示元素的数量(SwiftUI、Xcode 11 Beta 5)
我正在尝试实现一个 View ,该 View 可以在内容数组的大小发生变化时更改显示项目的数量(由 ForEach 循环创建),就像购物应用程序可能会在用户下拉刷新后更改其可用项目的数量一样 这是我到目前为止尝试过的一些代码。如果我没记错的话,这些适…...
编程导航算法村第七关 |二叉树的遍历
编程导航算法村第七关 | 二叉树的遍历 前序遍历(递归) public List<Integer> preorderTraversal(TreeNode root) {ArrayList<Integer> result new ArrayList<Integer>();preorder(root, result);return result;}public void preorde…...
【docker】docker-compose安装带ui页面的kafka集群
docker-compose 安装带kafka-ui 的kafka集群 在日常的工作当中,kafka集群作为常用的中间件,其搭建过程略显繁琐,需要配置的文件颇多,为了方便各位初学者快速体验kafka的魅力,本文采取一键式安装kafka-3.3.1࿰…...
java实现多级菜单
/** * 查询所有菜单 */ public BaseWebResponse<Object> getAllMenus() { List<SystemMenuInfo> systemMenuInfoList menuInfoMapper.getAllMenus(); List<SystemMenuInfo> menuTree buildMenuTree(systemMenuInfoList); return setResultSuccess(&q…...
HTML中元素和标签有什么区别?
聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 标签(Tag)⭐元素(Element)⭐ 写在最后 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅&a…...
android 如何分析应用的内存(十三)——perfetto
android 如何分析应用的内存(十三) 本篇文章是native内存的最后一篇文章——perfetto perfetto简介 从2018年始,android开发者峰会正式推出perfetto工具。从此perfetto成为安卓最重要的工具之一。在2018年以前,android使用syst…...
Chapter20 音乐
目录 音乐 琴键 哆来咪 振动与调式 利萨如曲线 和声与音调与和弦 音乐 在音乐理论中,一个八音度(octave)是一个频率范围相差二倍的区间。在大多数西洋乐器中,一个八音度被分为12个频率比相等的半音程(semitone&a…...
详解Nodejs中的模块化
Nodejs是一个基于Chrome V8引擎的JavaScript运行时环境,它允许开发者使用JavaScript在服务器端运行代码。在Nodejs中,模块化是一种组织和重用代码的重要方式。模块化允许我们将代码拆分成小块,使得代码结构更清晰、易于维护,并促进…...
debug思路 - maven构建报错
问题:maven面板中,进行compile、deploy操作时报错。 debug步骤: 1、鼠标右键选择“修改运行配置”。在运行命令中添加参数-X,用于产生执行调试输出。例如:compile -f -X pom.xml。 2、再次进行compile、deploy操作&…...
DSP学习笔记
间接寻址(通过放在辅助寄存器里面,可以对地址包括很多操作,1,-1,/-平移量,辅助寄存器内容的修改是在ARAU0和ARAU1中完成的。分为单操作数和双操作数,有很多模式在ARAU。单操作数间接寻址&#x…...
Java中的Apache Commons Math是什么?
Java中的Apache Commons Math是一个开源的数学库,它提供了许多常用的数学函数和算法,例如线性代数、微积分、统计、插值、拟合等。这个库对于需要处理大量数据的开发者来说非常有用,因为它可以大大简化代码并提高效率。 让我们从新手的角度来…...
规划路线(微信小程序、H5)
//地图getLocationDian(e1, e2) {console.log(e1, e2);let self this;self.xx1 [];self.xx2 [];self.points [];// self.markers[]console.log(self.markers, >marks);// self.$jsonp(url, data).then(re > {// var coors re.result.routes[0].polyline;// for (v…...
【CSS】视频文字特效
效果展示 index.html <!DOCTYPE html> <html><head><title> Document </title><link type"text/css" rel"styleSheet" href"index.css" /></head><body><div class"container"&g…...
linux-MySQL的数据目录
总结: window中的my.ini linux 中 /etc/my.cnfwindow中的D:\soft\mysql-5.7.35-winx64\data linux 中 /var/lib/mysql 1.查找与mysql有关的目录 find / -name mysql [rootVM-4-6-centos etc]# find / -name mysql /opt/mysql /etc/selinux/targeted/tmp/modul…...
AI绘图实战(十二):让AI设计LOGO/图标/标识 | Stable Diffusion成为设计师生产力工具
S:AI能取代设计师么? I :至少在设计行业,目前AI扮演的主要角色还是超级工具,要顶替?除非甲方对设计效果无所畏惧~~ 预先学习: 安装及其问题解决参考:《Windows安装Stable Diffusion …...
机器视觉系统设计:基础知识
机器视觉系统的设计 机器视觉系统集成是将各种不同的组件和子系统组合在一起并使它们充当单个统一系统的过程。 视觉系统集成包括光源,镜头,相机,相机接口和图像处理软件等等。您可能想知道如何设计和实现一个完整,成功的机器视…...
C# Blazor 学习笔记(11):路由跳转和信息传值
文章目录 前言路由跳转测试用例路由传参/路由约束想法更新:2023年8月4日 前言 Blazor对路由跳转进行了封装。 ASP.NET Core Blazor 路由和导航 NavigationManager 类 本文的主要内容就是全局的跳转 路由跳转 路由跳转就要用到NavigationManager 类。 其实最常用…...
Centos 7 安装 Python 时 zlib not available 错误解决
Centos 7 安装 Python 时 zlib not available 错误解决 报错信息, zipimport.ZipImportError: cant decompress data; zlib not available解决方法, sudo yum install -y zlib zlib-devel完结!...
python sqllite基本操作
以下是一些基本的SQLite3操作: 连接到数据库:使用sqlite3.connect()函数连接到数据库,返回一个Connection对象,我们就是通过这个对象与数据库进行交互。例如: import sqlite3 conn sqlite3.connect(example.db)创建…...
wordpress后台更新后 前端没变化的解决方法
使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…...
(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...
使用分级同态加密防御梯度泄漏
抽象 联邦学习 (FL) 支持跨分布式客户端进行协作模型训练,而无需共享原始数据,这使其成为在互联和自动驾驶汽车 (CAV) 等领域保护隐私的机器学习的一种很有前途的方法。然而,最近的研究表明&…...
【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...
Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信
文章目录 Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信前言一、网络通信基础概念二、服务端与客户端的完整流程图解三、每一步的详细讲解和代码示例1. 创建Socket(服务端和客户端都要)2. 绑定本地地址和端口&#x…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
VM虚拟机网络配置(ubuntu24桥接模式):配置静态IP
编辑-虚拟网络编辑器-更改设置 选择桥接模式,然后找到相应的网卡(可以查看自己本机的网络连接) windows连接的网络点击查看属性 编辑虚拟机设置更改网络配置,选择刚才配置的桥接模式 静态ip设置: 我用的ubuntu24桌…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...
现有的 Redis 分布式锁库(如 Redisson)提供了哪些便利?
现有的 Redis 分布式锁库(如 Redisson)相比于开发者自己基于 Redis 命令(如 SETNX, EXPIRE, DEL)手动实现分布式锁,提供了巨大的便利性和健壮性。主要体现在以下几个方面: 原子性保证 (Atomicity)ÿ…...
[ACTF2020 新生赛]Include 1(php://filter伪协议)
题目 做法 启动靶机,点进去 点进去 查看URL,有 ?fileflag.php说明存在文件包含,原理是php://filter 协议 当它与包含函数结合时,php://filter流会被当作php文件执行。 用php://filter加编码,能让PHP把文件内容…...
