SpringCloud 微服务全栈体系(一)

news2025/1/16 7:45:28

第一章 认识微服务

  • 随着互联网行业的发展,对服务的要求也越来越高,服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢?

一、单体架构

  • 单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署。

在这里插入图片描述

  • 单体架构的优缺点如下:

    • 优点:

      • 架构简单
      • 部署成本低
    • 缺点:

      • 耦合度高(维护困难、升级困难

二、分布式架构

  • 分布式架构:根据业务功能对系统做拆分,每个业务功能模块作为独立项目开发,称为一个服务。

在这里插入图片描述

  • 分布式架构的优缺点:

    • 优点:

      • 降低服务耦合
      • 有利于服务升级和拓展
    • 缺点:

      • 服务调用关系错综复杂
  • 分布式架构虽然降低了服务耦合,但是服务拆分时也有很多问题需要思考:

    • 服务拆分的粒度如何界定?
    • 服务之间如何调用?
    • 服务的调用关系如何管理?
  • 人们需要制定一套行之有效的标准来约束分布式架构。

三、微服务

  • 微服务的架构特征:

    • 单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责
    • 自治:团队独立、技术独立、数据独立,独立部署和交付
    • 面向服务:服务提供统一标准的接口,与语言和技术无关
    • 隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题

在这里插入图片描述

  • 微服务的上述特性其实是在给分布式架构制定一个标准,进一步降低服务之间的耦合度,提供服务的独立性和灵活性。做到高内聚,低耦合。

  • 因此,可以认为微服务是一种经过良好架构设计的分布式架构方案

  • 但方案该怎么落地?选用什么样的技术栈?全球的互联网公司都在积极尝试自己的微服务落地方案。

  • 其中在 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.sqlcloud-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);
    }

    @Bean
    public 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 既可以是服务提供者,也可以是服务消费者。

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

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

相关文章

MySQL数据库简单安装

MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管…

大河弯弯:CSS 文档流与三大元素显示模式

文章目录 参考环境文档流概念三大显示模式 内联元素概念常见的内联元素宽高由内容决定 块级元素概念常见的块级元素宽度受容器影响,高度受内容影响 内联块级元素概念常见的内联块级元素折中方案 设置元素的显示模式display 属性内联元素与块级元素的切换为什么要通过…

大托,如何站上天心南部的价值高地?

作者 | 魏启扬 陈宇航 来源 | 洞见新研社 陈飞 摄 “商贾云集于四方,市井数盈于万户”,长沙南城古往今来生生不息的热辣与烟火,每隔一段时间,都会有璀璨的迸发。 才在“加长版”黄金周释放了“不夜南城”的魅力,第…

YOLO目标检测——红细胞数据集【(含对应voc、coco和yolo三种格式标签】

实际项目应用:红细胞的自动检测和计数数据集说明:YOLO目标检测数据集,真实场景的高质量图片数据,数据场景丰富。使用lableimg标注软件标注,标注框质量高,含voc(xml)、coco(json)和yolo(txt)三种格式标签&am…

C++类和对象(四) (构造函数 析构函数)

1 类的6个默认成员函数 如果一个类中什么成员都没有,简称为空类。 空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。 默认成员函数:用户没有显式实现,编译器会生…

SolidWorks2021 安装教程(亲测可用)

1.安装教程:(断网进行,否则安装了后还是无法用) 1.运行sw2021_network_serials_licensing 2. 注册表编辑器确定 3.成功添加到注册表中 4.复制SolidWorks_Flexnet_Server文件夹 5.运行SolidWorks_Flexnet_Server下的lserver_insta…

一个适合练手的接口测试实战项目——慕慕生鲜

前言 最近很多粉丝找小月要接口测试项目练练手,看看实力!今天,它来了 慕慕生鲜,完整版,文末有福利! 干货来咯,收藏好! 1. 接口测试需求分析 常见接口文档提供的两种方式 ①wor…

代码随想录算法训练营第23期day26|39. 组合总和、40.组合总和II、131.分割回文串

目录 一、(leetcode 39)组合总和 二、(leetcode 40)组合总和II 三、(leetcode 131)分割回文串 一、(leetcode 39)组合总和 力扣题目链接 状态:基本回溯AC&#xff0c…

Docker(2)

Docker网络 原生网络 [rootserver1 harbor]# docker network ls默认使用桥接模式,桥接到docker0上 [rootserver1 ~]# docker run -d --name demo nginx [rootserver1 ~]# yum install -y bridge-utils [rootserver1 ~]# brctl showhost模式,容器和宿…

【vue3】Transition过渡组件

Transition 自带的内部组件xxx-enter-from 开始进入过渡 0%xxx-enter-active 过渡过程xxx-enter-to 过渡完成 100%xxx-leave-from 开始退出 0%xxx-leave-active 退出过程xxx-leave-to 退出完成 100% xxx是组件属性name的值&#xff0c;自定义的。我使用的是fade-box <templa…

JavaSE编程题目练习(三)

博客昵称&#xff1a;架构师Cool 最喜欢的座右铭&#xff1a;一以贯之的努力&#xff0c;不得懈怠的人生。 作者简介&#xff1a;一名Coder&#xff0c;欢迎关注小弟&#xff01; 博主小留言&#xff1a;哈喽&#xff01;各位CSDN的uu们&#xff0c;我是你的小弟Cool&#xff0…

基于 Qt UDP通信局域网通信

前言 该例程经过实际验证可以正常使用,只简单的使用UDP中的单播模式(一对一), 所用测试系统在同一局域网,其中: QT版本:5.12 PC端UDP模式:单播 UDP通信目标:基于STM32F4+LWIP协议的以太网接口 调试助手: 虚拟串口+串口助手+UDP和TCP调试助手[编程人员必备]一、UDP通…

RIP,EIGRP,OSPF区别

1. 动态路由协议的作用是什么&#xff1f; 2. 路由协议都有哪些种类&#xff1f; 3. 如何判断路由协议的优劣&#xff1f; -- RIP&#xff0c;EIGRP&#xff0c;OSPF - 动态路由协议 -- 路由协议 - 路由器上的软件 -- 帮助路由器彼此之间同步路由表 -- 相互的传递…

MC 我的世界 模拟城市模拟大都市 模组下载及整合包导入详解

如何导入整合包 如果是从curseforge下载的整合包不需要解压的&#xff0c;直接按照下方步骤整就行了&#xff0c;把启动器和整合包复制到没有中文的路径下 双击启动exe文件&#xff0c;如果弹窗要更新啥的点确定即可&#xff0c;启动好了先登录账户&#xff0c;有正式版的登录…

攻防世界web篇-view_source

因为题目说了不能使用右键查看源代码 所以我直接F12来查看&#xff0c;但是F12只能查看不能复制flag 之后尝试view-source:http://61.147.171.105:57537/ 这里右键不受限制&#xff0c;可以直接粘贴复制

驱动开发day2(编程实现LED三盏小灯亮灭)

头文件&#xff08;head.h&#xff09;&#xff1a; #ifndef __HEAD_H__ #define __HEAD_H__ #define PHY_LED1_MODER 0x50006000 #define PHY_LED2_MODER 0x50007000 #define PHY_LED3_MODER 0x50006000 #define PHY_LED1_ODR 0x50006014 #define PHY_LED2_ODR 0x50007014 #d…

揭示肠道菌群在儿童营养生长不良中的关键作用

营养不良的微生物 Malnourished Microbes 儿童营养不良是全球主要的健康负担&#xff0c;营养干预措施只能部分解决这一问题。儿童营养不良的慢性和急性形式均以多种生物系统紊乱为特征&#xff0c;包括新陈代谢、免疫和内分泌系统。 越来越多的证据支持肠道微生物组在调节这些…

踩坑记 BSS段的初始化

title: 踩坑记 BSS段的初始化 category_bar: true categories: blog tags:embedded date: 2023-10-20 19:23:05 前言 接手一个项目&#xff0c;调试全靠串口日志&#xff0c;测试同事测试产品的时候无法拿到日志&#xff0c;刚好产品RAM够大&#xff0c;且刚好有SD卡。所以就…

“传统”开发与AI开发的区别与联系(更新了GPT3.5的反馈)

1、传统开发的算法和软件整体&#xff0c;也可以看成是一个“大模型”&#xff0c;其中有不同层次的处理&#xff0c;最终能够完成从输入到输出的计算&#xff0c;不过&#xff0c;其中的计算都是人工定义的&#xff0c;一般依赖于研究成果的应用。研究成果在实际中的应用处理。…

伦敦银延时一定存在吗?

伦敦银市场是一个几乎24小时都在不停波动的市场&#xff0c;参与其中的人以短线交易为主&#xff0c;他们所追逐是行情短线波动所带来的收益&#xff0c;如果交易平台所提供的交易环境有问题&#xff0c;反复地出现延时、卡盘等的问题&#xff0c;恐怕会令投资的效果大打折扣&a…