【SpringCloud】认识微服务

news2025/1/12 12:01:08

在这里插入图片描述

🐌个人主页: 🐌 叶落闲庭
💨我的专栏:💨
c语言
数据结构
javaEE
操作系统
Redis

石可破也,而不可夺坚;丹可磨也,而不可夺赤。


认识微服务

  • 一、 服务架构演变
    • 1.1 单体架构
    • 1.2 分布式架构
    • 1.3 微服务
  • 二、 微服务技术对比
  • 三、 SpringCloud
  • 四、服务拆分及远程调用
    • 4.1 服务拆分
    • 4.2 服务间调用

一、 服务架构演变

1.1 单体架构

  • 单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署
  • 优点:
    • 架构简单,部署成本低
  • 缺点:
  • 耦合度高

1.2 分布式架构

  • 分布式架构:根据业务功能对系统进行拆分,每个业务模块作为独立项目开发,称为一个服务。
  • 优点:
  • 降低耦合度,有利于服务升级拓展

分布式架构是将一个项目中的不同的需求拆分成了多个模块,每个模块都可以独立开发,互不影响,各个模块最终一起部署,降低了代码的耦合度,但如果项目的需求有很多个,就需要大量的模块,模块数量变多,最终部署的时候就会变得很复杂,再拆分的过程中也会有很多问题,由于拆分好的服务为了保证高可用,还需要集群,与单体架构相比,分布式架构中的某个模块需要另一个模块的提供的信息时不能像单体架构那样直接调用。
此外,采用分布式架构还要考虑很多问题:服务拆分粒度如何(就是指哪些功能可以单独拆分出来)、服务集群地址如何维护(每个拆分的模块都有自己的地址,在部署的时候如何获取这些地址,当地址发生变化该怎么办)、服务之间如何实现远程调用、服务的健康状态如何感知(模块1发生问题挂掉了,模块2去调用模块1也会出现问题)

1.3 微服务

  • 微服务是一种经过良好架构设计的分布式架构方案,微服务架构特征:
  • 单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责,避免重复业务开发
  • 面向服务:微服务对外暴露业务接口
  • 自治:团队独立、技术独立、数据独立、部署独立
  • 隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题

微服务的分布式架构方案将每个小的服务都拆分成单独的模块,使每个模块的功能更少,在开发时不会那么繁琐,每个模块对外都提供访问接口,可以实现对某个模块功能的调用,模块都是独立开发的,相当于一个完整的小的项目,有自己独立的数据库,有自己独立的数据,模块之间不能访问对方的数据,实现了数据解耦,避免了数据污染,模块之间进行调用时,当一个模块发生问题挂掉了,另一个模块需要调用,此时会有一个隔离性的措施,避免模块调用时出现问题

二、 微服务技术对比

  • 微服务这种方案需要技术框架来落地,全球的互联网公司都在积极尝试自己的微服务落地技术。在国内最知名的就SpringCloud和阿里巴巴的Dubbo。

不管是哪种微服务,他们都需要去做微服务的拆分,形成微服务集群,集群中的每个服务都需要遵循单一职责的原则,,并且由于要面向服务,所以每个服务都要对外暴露接口,用于服务之间的调用,不同技术去实现这些接口的方式可能会有所不同,由于这些接口之间的调用关系需要维护,并且这些调用关系错综复杂,而且量也是非常大,所以在微服务中都会有一个注册中心,用来维护微服务里面每个节点的信息,并且监控这些节点的状态,随着微服务越来越多,里面要是有一些配置需要去修改,此时会有一个配置中心,用来统一管理整个微服务群的配置,微服务部署完成后,为服务群会有一个统一的服务网关,用户访问这个网关,由网关把请求路由到微服务群,在路由过程中还可以做负载均衡。

在这里插入图片描述


微服务技术对比:

DubboSpringCloudSpringCloudAlibaba
注册中心zookeeper、redisEureka、ConsulNacos、Eureka
服务远程调用Dobbo协议Feign(http协议)Dubbo、Feign
配置中心SpringCloudConfigSpringCloudConfig、Nacos
服务网关SpringCloudGetway、ZuulSpringCloudGetway、Zuul
服务监控和保护dubbo-admin,功能弱HystrixSentinel

三、 SpringCloud

  • SpringCloud是目前国内使用最广泛的微服务框架,官网地址:https://spring.io/projects/spring-cloud
  • SpringCloud集成了各种微服务功能组件,并基于Spring Boot3实现了这些组件的自动装配,从而提供了良好的开
    箱即用体验
  • SpringCloud与SpringBoot的版本兼容关系:

在这里插入图片描述


四、服务拆分及远程调用

4.1 服务拆分

服务拆分就是一个单体架构按照功能模块进行拆分,变成多个服务
在进行微服务拆分时要注意不同的微服务,不要重复开发相同的业务,避免重复开发,要保证微服务数据的独立,不同的微服务不能访问彼此的数据库,如果一个微服务需要另一个微服务的数据,可以通过接口调用,因为每个微服务都要将自己的部分业务暴露作为接口供其它微服务调用

4.2 服务间调用

  • 注册RestTemplate
@MapperScan("order.mapper")
@SpringBootApplication
public class OrderApplication {
	public static void main(String[] args) {
		SpringApplication.run(OrderApplication.class,args);
	}
	@Bean
	public RestTemplate restTemplate() {
		return new RestTemplate();
	}
}
  • 服务远程调用RestTemplate
@Service
public class OrderService {
	@Autowired
	private RestTemplate restTemplate;

	public Order queryOrderById(Long orderId) {
		//查询订单
		Order order = orderMapper.findById(orderId);
		//查询用户
		String url = "http://localhost:8081/user/" + order.getUserId();
		User user = restTemplate.getForObject(url,User.class);
		//封装user信息
		order.setUser(user);
		//返回
		return order;
	}
}

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

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

相关文章

Qt之进程通信-QProcess(含源码+注释)

文章目录 一、QProcess进程通信示例二、QProcess通信个人理解三、源码MainWindowProcessSenderMainWindowProcessSender.hMainWindowProcessSender.cppMainWindowProcessSender.ui MainWindowProcessRecvMainWindowProcessRecv.hMainWindowProcessRecv.cppMainWindowProcessRec…

【算法——双指针】LeetCode 18 四数之和

题目描述: 解题思路:双指针 四数之和与前面三数之和思路一样,排序后,枚举 nums[a]作为第一个数,枚举 nums[b]作为第二个数,那么问题变成找到另外两个数,使得这四个数的和等于 target&#xff0c…

吃鸡玩家必备神器!一站式提升战斗力、分享干货!

大家好,我是吃鸡玩家。在这个视频中,我要分享一个让你瞬间提高战斗力的神器,同时让你享受到顶级游戏作战干货的盛宴!让我们一起来了解吧! 首先,我们推荐绝地求生作图工具。通过这款工具,你可以轻…

用这些IDEA插件,让你早下班两小时

GenerateAllSetter:一键调用一个对象的所有setter方法 RestfulTool:自动显示所有URL接口,快速检索接口 SequenceDiagram:以图形界面形式显示方法调用链,方便阅读源码、梳理代码 CamelCase:变量下划线转驼峰命名 Rainbow Brackets:帮助程序员识别代码中括…

十五、异常(5)

本章概要 异常限制构造器 异常限制 当覆盖方法的时候,只能抛出在基类方法的异常说明里列出的那些异常。这个限制很有用,因为这意味着与基类一起工作的代码,也能和导出类一起正常工作(这是面向对象的基本概念)&#…

基于SSM的校园资讯推荐系统设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

关联规则挖掘:Apriori算法的深度探讨

目录 一、简介什么是关联规则挖掘?什么是频繁项集?什么是支持度与置信度?Apriori算法的重要性应用场景 二、理论基础项和项集支持度(Support)置信度(Confidence)提升度(Lift&#xf…

SSM - Springboot - MyBatis-Plus 全栈体系(十八)

第四章 SpringMVC SpringMVC 实战:构建高效表述层框架 一、SpringMVC 简介和体验 1. 介绍 Spring Web MVC 是基于 Servlet API 构建的原始 Web 框架,从一开始就包含在 Spring Framework 中。正式名称“Spring Web MVC”来自其源模块的名称&#xff08…

OCR让点读笔如虎添翼

点读笔是一种智能学习工具,它可以通过识别文字来提供相应的语音或图像反馈。在实现文字识别功能时,点读笔通常会借助OCR(Optical Character Recognition,光学字符识别)技术。下面将详细介绍点读笔如何利用OCR技术实现文…

浅析人脸活体检测技术的两种方法

随着人脸识别技术日趋成熟,商业化应用愈加广泛,然而人脸极易用照片、视频等方式进行复制,因此对合法用户人脸的假冒是人脸识别与认证系统安全的重要威胁。目前基于动态视频人脸检测、人脸眨眼、热红外与可见光人脸关联等领先业界的人脸活体检测算法,已经取得了一定的…

Linux0.12内核源码解读(2)-Bootsect.S

作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功、源码解析、科技故事、项目实战、面试八股等更多硬核文章,首发于公众号「小牛呼噜噜」 文章目录 回顾计算机启动过程8086、80x86是什么意思?寄存器初始化CS:IPCPU是如何和ROM相连的?加载MBR到…

餐饮蛋糕鲜花便利店水果店外卖自提小程序开发

对于实体门店小微商家来说,做私域和复购永远是最划算的买卖。店里每天有新客到老客到,做好私域就可以零成本形成稳定客流而且还可以通过活动形成社交裂变和口碑效应。不做好私域和留存就是白白看着自己客户被同行一口一口吃掉。因此也就有了自提外卖小程…

制作婚礼邀请函只需三步,轻松制作走心请柬

制作自己的婚礼邀请函是一种流行的方式来传达你的婚礼信息给你的亲朋好友。在这个数字化的时代,你可以使用在线制作平台来创建自定义的婚礼邀请函。下面是一个简单的步骤指南,教你如何使用乔拓云网在线制作平台制作出超有感觉的婚礼请柬。 首先&#xff…

【Overload游戏引擎分析】从视图投影矩阵提取视锥体及overload对视锥体的封装

overoad代码中包含一段有意思的代码,可以从视图投影矩阵逆推出摄像机的视锥体,本文来分析一下原理 一、平面的方程 视锥体是用平面来表示的,所以先看看平面的数学表达。 平面方程可以由其法线N(A, B, C)和一个点Q(x0,…

【发表案例】计算机类SCIE,2区,2个月2天录用

计算机类SCIE 【期刊简介】IF:4.0-5.0,JCR2区,中科院3区 【检索情况】SCIE 在检,正刊 【征稿领域】提高安全性和隐私性的边缘/云的智能方法的研究,如数字孪生等 录用案例:2个月2天录用 2023.09.27 | A…

吃鸡玩家必备!提升战斗力,分享干货,保护账号安全!

你好!吃鸡玩家们的福利来了!在这里,我将为大家分享一些关于提高游戏战斗力、分享顶级游戏作战干货以及保护账号安全的实用技巧。 首先,让我们来谈提高游戏战斗力的技巧。绝地求生是一款战略性的游戏,而好的作图工具可以…

Java笔记八(instanceof,类型转换,static详解,抽象类,接口,内部类以及异常)

instanceof 引用类型,判断一个对象是什么类型 使用方法: System.out.println(X instanceof Y); 代码理解: public class Application {public static void main(String[] args) {//Obiect>String//…

如何成为合格的测试开发工程师?

是入职两年半的测试开发工程师小编,虽然目前很菜,但还是希望自己继续努力,早日成为一名合格的测试开发工程师,本篇文章也是通过对身边同事的了解,整理了几点对自己的要求,以及重新梳理了下今后的学习路径&a…

CI522 13.56MHZ电动车NFC测试资料

Ci522是一颗工作在13.56MHz频率下的非接触式读写芯片,支持读A卡(CI523支持读A/B卡),可做智能门锁、电动车NFC一键启动、玩具NFC开锁等应用。为部分要求低成本,PCB小体积的产品提供了可靠的选择。 Ci522与Si522/MFRC52…

母婴店做微信小程序开发的重要性

随着移动互联网的发展,母婴店传统的线下销售模式已经无法满足现代年轻父母的需求。微信小程序作为一种新型的应用形态,为母婴店提供了新的销售渠道和推广方式。本文将探讨母婴店做微信小程序开发的作用。 一、拓展销售渠道 微信小程序是一种轻量级的应用…