SpringCloud 微服务全栈体系(一)
第一章 认识微服务
- 随着互联网行业的发展,对服务的要求也越来越高,服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢?
一、单体架构
- 单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署。

-
单体架构的优缺点如下:
-
优点:
- 架构简单
- 部署成本低
-
缺点:
- 耦合度高(维护困难、升级困难)
-
二、分布式架构
- 分布式架构:根据业务功能对系统做拆分,每个业务功能模块作为独立项目开发,称为一个服务。

-
分布式架构的优缺点:
-
优点:
- 降低服务耦合
- 有利于服务升级和拓展
-
缺点:
- 服务调用关系错综复杂
-
-
分布式架构虽然降低了服务耦合,但是服务拆分时也有很多问题需要思考:
- 服务拆分的粒度如何界定?
- 服务之间如何调用?
- 服务的调用关系如何管理?
-
人们需要制定一套行之有效的标准来约束分布式架构。
三、微服务
-
微服务的架构特征:
- 单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责
- 自治:团队独立、技术独立、数据独立,独立部署和交付
- 面向服务:服务提供统一标准的接口,与语言和技术无关
- 隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题

-
微服务的上述特性其实是在给分布式架构制定一个标准,进一步降低服务之间的耦合度,提供服务的独立性和灵活性。做到高内聚,低耦合。
-
因此,可以认为微服务是一种经过良好架构设计的分布式架构方案 。
-
但方案该怎么落地?选用什么样的技术栈?全球的互联网公司都在积极尝试自己的微服务落地方案。
-
其中在 Java 领域最引人注目的就是 SpringCloud 提供的方案了。
四、SpringCloud
- SpringCloud 是目前国内外使用最广泛的微服务框架。
- 官网地址:https://spring.io/projects/spring-cloud。
- SpringCloud 集成了各种微服务功能组件,并基于 SpringBoot 实现了这些组件的自动装配,从而提供了良好的开箱即用体验。
- 其中常见的组件包括:

- 另外,SpringCloud 底层是依赖于 SpringBoot 的,并且有版本的兼容关系,如下:

- 版本:Hoxton.SR10,对应的 SpringBoot 版本是 2.3.x 版本。
五、总结
-
单体架构:简单方便,高度耦合,扩展性差,适合小型项目。例如:学生管理系统
-
分布式架构:松耦合,扩展性好,但架构复杂,难度大。适合大型互联网项目,例如:京东、淘宝
-
微服务:一种良好的分布式架构方案
① 优点:拆分粒度更小、服务更独立、耦合度更低
② 缺点:架构非常复杂,运维、监控、部署难度提高
-
SpringCloud 是微服务架构的一站式解决方案,集成了各种优秀微服务功能组件
第二章 服务拆分和远程调用
- 任何分布式架构都离不开服务的拆分,微服务也是一样。
一、服务拆分原则
-
微服务拆分时的几个原则:
- 不同微服务,不要重复开发相同业务
- 微服务数据独立,不要访问其它微服务的数据库
- 微服务可以将自己的业务暴露为接口,供其它微服务调用

二、服务拆分示例
- 以微服务 cloud-demo 为例,其结构如下:

-
cloud-demo:父工程,管理依赖
- order-service:订单微服务,负责订单相关业务
- user-service:用户微服务,负责用户相关业务
-
要求:
- 订单微服务和用户微服务都必须有各自的数据库,相互独立
- 订单服务和用户服务都对外暴露 Restful 的接口
- 订单服务如果需要查询用户信息,只能调用用户服务的 Restful 接口,不能查询用户数据库
1. 导入 Sql 语句
- 将
cloud-order.sql和cloud-user.sql导入到 mysql 中:
(见专栏 -> 全栈资料包 -> 资源包/02_cloud)

- cloud-user 表中初始数据如下:

- cloud-order 表中初始数据如下:

- cloud-order 表中持有 cloud-user 表中的 id 字段。
2. 导入 demo 工程
- 用 IDEA 导入 Demo:
(见专栏 -> 全栈资料包 -> 资源包/02_cloud)

- 项目结构如下:

- 导入后,会在 IDEA 右下角出现弹窗:

- 点击弹窗,然后按下图选择:

- 会出现这样的菜单:

- 配置下项目使用的 JDK:

三、实现远程调用案例
- 在 order-service 服务中,有一个根据 id 查询订单的接口:

- 根据 id 查询订单,返回值是 Order 对象,如图:

-
其中的 user 为 null
-
在 user-service 中有一个根据 id 查询用户的接口:

查询的结果如图:

1. 案例需求
- 修改 order-service 中的根据 id 查询订单业务,要求在查询订单的同时,根据订单中包含的 userId 查询出用户信息,一起返回。

-
因此,我们需要在 order-service 中 向 user-service 发起一个 http 的请求,调用 http://localhost:8081/user/{userId}这个接口。
-
大概的步骤是这样的:
- 注册一个 RestTemplate 的实例到 Spring 容器
- 修改 order-service 服务中的 OrderService 类中的 queryOrderById 方法,根据 Order 对象中的 userId 查询 User
- 将查询的 User 填充到 Order 对象,一起返回
2. 注册 RestTemplate
- 首先,我们在 order-service 服务中的 OrderApplication 启动类中,注册 RestTemplate 实例:
package com.alex.order;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;@MapperScan("com.alex.order.mapper")
@SpringBootApplication
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}@Beanpublic RestTemplate restTemplate() {return new RestTemplate();}
}
3. 实现远程调用
- 修改 order-service 服务中的 com.alex.order.service 包下的 OrderService 类中的 queryOrderById 方法:

四、提供者与消费者
-
在服务调用关系中,会有两个不同的角色:
-
服务提供者:一次业务中,被其它微服务调用的服务。(提供接口给其它微服务)
-
服务消费者:一次业务中,调用其它微服务的服务。(调用其它微服务提供的接口)
-

-
但是,服务提供者与服务消费者的角色并不是绝对的,而是相对于业务而言。
-
如果服务 A 调用了服务 B,而服务 B 又调用了服务 C,服务 B 的角色是什么?
- 对于 A 调用 B 的业务而言:A 是服务消费者,B 是服务提供者
- 对于 B 调用 C 的业务而言:B 是服务消费者,C 是服务提供者
-
因此,服务 B 既可以是服务提供者,也可以是服务消费者。
相关文章:
SpringCloud 微服务全栈体系(一)
第一章 认识微服务 随着互联网行业的发展,对服务的要求也越来越高,服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢? 一、单体架构 单体架构:将业务的所有功能集中在一个项目中开发ÿ…...
Echarts自定义柱状图
目录 效果图 echarts官网找相似图 将柱状图引入html页面中 自定义柱状图 将不需要的属性删除 编辑 修改图形大小 grid 不显示x轴 编辑 不显示y轴线和相关刻度 编辑 y轴文字的颜色设置为自己想要的颜色 修改第一组柱子相关样式(条状) …...
LuatOS-SOC接口文档(air780E)-- ioqueue - io序列操作
ioqueue.init(hwtimer_id,cmd_cnt,repeat_cnt) 初始化一个io操作队列 参数 传入值类型 解释 int 硬件定时器id,默认用0,根据实际MCU确定,air105为0~5,与pwm共用,同一个通道号不能同时为pwm和ioqueue int 一个完…...
探讨Socks5代理技术的原理及其在不同领域的应用
Socks5代理:实现网络连接的智能之选 作为一种网络代理协议,Socks5代理技术通过转发网络数据包,实现了客户端和服务器之间的代理传输。其独特的特性在跨界电商、爬虫数据分析、企业出海和游戏体验等领域发挥着关键作用,为用户提供…...
sql注入的基本手法
目的 通过sqk注入获取数据内容 掌握sql注入基本手法 我们这里使用 1.联合注入 就是利用union select 语句 两条语句 同时执行 实现跨库跨表查询 条件 两条select语句查询结果具有相同列数 对应列数数据类型相同 简单的步骤 1.目标分析 ?id…...
8.1 C++ 标准输入输出流
C/C语言是一种通用的编程语言,具有高效、灵活和可移植等特点。C语言主要用于系统编程,如操作系统、编译器、数据库等;C语言是C语言的扩展,增加了面向对象编程的特性,适用于大型软件系统、图形用户界面、嵌入式系统等。…...
hive往es映射表写数据报错
hive是基于Hadoop的一个数据仓库工具,用来进行数据提取、转化、加载,这是一种可以存储、查询和分析存储在Hadoop中的大规模数据的机制。hive数据仓库工具能将结构化的数据文件映射为一张数据库表,并提供SQL查询功能,能将SQL语句转…...
2023年【广东省安全员A证第四批(主要负责人)】考试试卷及广东省安全员A证第四批(主要负责人)模拟考试
题库来源:安全生产模拟考试一点通公众号小程序 广东省安全员A证第四批(主要负责人)考试试卷根据新广东省安全员A证第四批(主要负责人)考试大纲要求,安全生产模拟考试一点通将广东省安全员A证第四批&#x…...
YOLOv5算法改进(15)— 如何去更换Neck网络(包括代码+添加步骤+网络结构图)
前言:Hello大家好,我是小哥谈。在学习完了如何去更换主干网络之后,接着就让我们通过案例的方式去学习下如何去更换Neck网络。本篇文章的特色就是比较浅显易懂,附加了很多的网络结构图,通过结构图的形式向大家娓娓道来,希望大家学习之后能够有所收获!🌈 前期回顾: YO…...
用Nginx搭建一个具备缓存功能的反向代理服务
在同一台服务器上,使用nginx提供服务,然后使用openresty提供反向代理服务。 参考《Ubuntu 20.04使用源码安装nginx 1.14.0》安装nginx。 参考《用Nginx搭建一个可用的静态资源Web服务器》搭建静态资源Web服务器,但是/nginx/conf/nginx.conf里…...
YOLOv5改进实战 | 更换主干网络Backbone(三)之轻量化模型Shufflenetv2
前言 轻量化网络设计是一种针对移动设备等资源受限环境的深度学习模型设计方法。下面是一些常见的轻量化网络设计方法: 网络剪枝:移除神经网络中冗余的连接和参数,以达到模型压缩和加速的目的。分组卷积:将卷积操作分解为若干个较小的卷积操作,并将它们分别作用于输入的不…...
【Markdown】 Markdown 操作备忘录
To Do List 显示目前todo list 的状态 getLogger() 单例类, 通过引入模块,获取单例日志对象 结果可视化调研 模型结果保存及测试 - [ ] getLogger() 单例类, 通过引入模块,获取单例日志对象 - [ ] 结果可视化调研 - [x] 模型结果…...
【自动化测试】基于Selenium + Python的web自动化框架
一、什么是Selenium? Selenium是一个基于浏览器的自动化工具,她提供了一种跨平台、跨浏览器的端到端的web自动化解决方案。Selenium主要包括三部分:Selenium IDE、Selenium WebDriver 和Selenium Grid: 1、Selenium IDE&…...
zookeeper连接客户端操作数据时报错Socket is not connected
文章目录 一、报错信息二、问题描述三、原因分析:四、解决方案: 一、报错信息 DEBUG org.apache.zookeeper.ClientCnxnSocketNIO - Ignoring exception during shutdown input java.net.SocketException: Socket is not connectedat sun.nio.ch.Net.tra…...
mysql select语句中from 之后跟查询语句
概念:将from后面的查询语句放在FROM的后面,则查询到的结果,就会被当成一个“表”; 这里有一个特别要注意的地方,放在FROM后面的子查询,必须要加别名。 select dui.id,dui.party_service_id mes_id, dui.party_id,dui.…...
Yolov8小目标检测(26):多尺度空洞注意力(MSDA) | 中科院一区顶刊 DilateFormer 2023.9
💡💡💡本文独家改进:多尺度空洞注意力(MSDA)采用多头的设计,在不同的头部使用不同的空洞率执行滑动窗口膨胀注意力(SWDA),全网独家首发,创新力度十足,适合科研 多尺度空洞注意力(MSDA) | 亲测在红外弱小目标检测涨点,map@0.5 从0.755提升至0.784 💡�…...
NLP:从头开始的文本矢量化方法
一、说明 NLP 项目使用文本,但机器学习算法不能使用文本,除非将其转换为数字表示。这种表示通常称为向量,它可以应用于文本的任何合理单位:单个标记、n-gram、句子、段落,甚至整个文档。 在整个语料库的统计 NLP 中&am…...
Kotlin 中 apply、let、also、run的区别
apply apply 函数接收一个目标并回来该目标自身。它答应您在目标上履行一些操作,同时仍然回来原始目标。 fun <T> T.apply(block: T.() -> Unit): TT 是目标的类型,block 是一个 lambda 表达式,能够在该目标上履行一些操作。在这个…...
Android JKS MD5 SHA1 公钥生成 私钥生成 APP备案 内容获取
1 查看 jks keytool -list -v -keystore /Users/lipengfei/Desktop/android/androidproject.jks密钥库类型: jks 密钥库提供方: SUN您的密钥库包含 1 个条目别名: ddgj 创建日期: 2018-11-16 条目类型: PrivateKeyEntry 证书链长度: 1 证书[1]: 所有者: CNcn, OUcn, Ocn, Lcn,…...
常用linux的命令(持续更新)
1.防火墙相关 centos7 防火墙 查状态:systemctl status firewalld.service 关闭:systemctl disable firewalld.service 重启生效 关闭:systemctl stop firewalld.service 马上生效 systemctl stop firewalld 临时关闭防火墙 systemctl disabl…...
QKeyMapper终极指南:3分钟掌握Windows游戏手柄与键盘映射神器
QKeyMapper终极指南:3分钟掌握Windows游戏手柄与键盘映射神器 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper,Qt开发Win10&Win11可用,不修改注册表、不需重新启动系统,可立即生效和停止。支持游戏手柄映射到键鼠&…...
华为交换机VRRP配置避坑指南:优先级、Track联动与虚拟IP设置的那些细节
华为交换机VRRP实战精要:优先级策略、Track联动机制与虚拟IP配置全解析 在现网架构中,VRRP协议如同网络流量的"隐形守护者",默默确保着业务连续性。当核心交换机突发故障时,毫秒级的切换能力往往决定着业务系统的生死存…...
Windows屏幕标注神器ppInk:技术架构深度解析与实战应用指南
Windows屏幕标注神器ppInk:技术架构深度解析与实战应用指南 【免费下载链接】ppInk Fork from Gink 项目地址: https://gitcode.com/gh_mirrors/pp/ppInk 你是否曾在线上会议中手忙脚乱地寻找标注工具?是否因为复杂的标注软件而放弃了屏幕演示的精…...
电力仿真避坑指南:110kV短距离输电,用集中参数模型真的够准吗?——基于Simulink的误差实测
110kV短距离输电仿真:集中参数模型的精度边界与工程决策 在电力系统设计与运行分析中,输电线路模型的精确选择常常让工程师陷入两难——是追求计算效率采用简化模型,还是为确保精度接受复杂计算?这个看似基础的问题,实…...
Jenkins + Gerrit 自动化流水线实战:从代码提交到Verified标签的全链路配置
Jenkins Gerrit 自动化质量门禁实战:构建代码准入的全链路闭环 在DevOps实践中,代码质量门禁的自动化程度直接影响团队交付效率。当开发者将代码推送到Gerrit进行评审时,如何通过Jenkins自动执行验证流程,并根据结果动态更新Gerr…...
保姆级教程:在Windows/Linux终端里设置PYTORCH_CUDA_ALLOC_CONF环境变量,彻底告别Pytorch显存碎片
彻底解决Pytorch显存碎片化:PYTORCH_CUDA_ALLOC_CONF环境变量设置全指南 当你正在训练一个深度学习模型,突然看到那个令人心碎的报错——"CUDA out of memory",而明明你的GPU显存看起来还有不少剩余空间。这种情况往往是由显存碎片…...
DLSS Swapper终极指南:免费工具轻松管理游戏DLSS版本,提升性能体验!
DLSS Swapper终极指南:免费工具轻松管理游戏DLSS版本,提升性能体验! 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper 你想在游戏中获得更好的DLSS性能吗?DLSS Swapper是一…...
雪女-斗罗大陆-造相Z-Turbo部署排错:解决403 Forbidden等网络访问问题
雪女-斗罗大陆-造相Z-Turbo部署排错:解决403 Forbidden等网络访问问题 最近在星图GPU平台上部署雪女-斗罗大陆-造相Z-Turbo模型时,不少朋友遇到了一个挺让人头疼的问题:调用接口时,服务器直接返回一个冷冰冰的“403 Forbidden”错…...
Windows11家庭版安装Docker Desktop Installer报错
错误内容:For security reasons C:\ProgramData\DockerDesktop must be owned by an elevated account1. 打开文件资源管理器,并导航至C:\ProgramData。* 注意:如果您未看到“ProgramData*”,请点击“查看”选项卡并勾选“隐藏项目…...
Vivado里AXI DMA传输总卡住?手把手教你用AXI SmartConnect打通PL到PS的数据流
Vivado中AXI DMA传输卡死的深度诊断与SmartConnect优化实战 当你在Vivado项目中精心设计的AXI DMA数据流突然陷入沉默,所有信号指示灯都像被冻住一般,这种时刻往往令人抓狂。上周我就遇到了这样一个案例:客户在Zynq UltraScale MPSoC平台上构…...
