SpringCloud微服务框架(通俗易懂,一秒上手)

article/2025/8/27 9:57:37

🎁🎁资源:https://pan.baidu.com/s/1zRmwSvSvoDkWh0-MynwERA&pwd=1234

SpringCloud微服务框架

  • (一)认识微服务
    • 服务架构演变
    • SpringCloud
  • (二)微服务拆分案例
    • 服务拆分
    • 服务间调用
  • (三)eureka注册中心
    • 远程调用的问题
    • eureka原理
    • 搭建EurekaServer
    • 服务注册
    • 服务发现
  • (四)Ribbon负载均衡原理
    • 负载均衡原理
    • 负载均衡策略
    • 懒加载
  • (五)nacos注册中心
    • 认识和安装Nacos
    • Nacos快速入门
    • Nacos服务分级存储模型
    • Nacos环境隔离

(一)认识微服务

服务架构演变

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

在这里插入图片描述

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

在这里插入图片描述
微服务

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

在这里插入图片描述

单体架构特点:
简单方便,高度耦合,扩展性差,适合小型项目。例如:学生管理系统
分布式架构特点:
松耦合,扩展性好,但架构复杂,难度大。适合大型互联网项目,例如:京东、淘宝
微服务:一种良好的分布式架构方案。
优点:拆分粒度更小、服务更独立、耦合度更低·缺点:架构非常复杂,运维、监控、部署难度提高

微服务这种方案需要技术框架来落地,全球的互联网公司都在积极尝试自己的微服务落地技术。在国内最知名的就是SpringCloud和阿里巴巴的Dubbo。
在这里插入图片描述
企业需求:
在这里插入图片描述

SpringCloud

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

在这里插入图片描述
在这里插入图片描述

(二)微服务拆分案例

服务拆分

服务拆分注意事项
1.单一职责:不同微服务,不要重复开发相同业务
2.数据独立:不要访问其它微服务的数据库
3.面向服务:将自己的业务暴露为接口,供其它微服务调用

在这里插入图片描述

启动项目,在浏览器中输入http://localhost:8080/order/id,http://localhost:8081/user/id
两个项目都能够根据id查询出对应的数据。

服务间调用

在这里插入图片描述
注册RestTemplate

在order-service的OrderApplication中注册RestTemplate

@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
public class OrderApplication {public static void main(String[] args) {SpringApplication.run(OrderApplication.class, args);}@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}
}

修改order-service中的OrderService的queryOrderById方法:

@Service
public class OrderService {@Resourceprivate OrderMapper orderMapper;@Autowiredprivate RestTemplate restTemplate;public Order queryOrderById(Long orderId) {// 1.查询订单Order order = orderMapper.findById(orderId);//查询用户String url="http://localhost:8081/user/"+order.getUserId();User user=restTemplate.getForObject(url,User.class);order.setUser(user);// 4.返回return order;}
}

提供者与消费者

服务提供者:一次业务中,被其它微服务调用的服务。(提供接口给其它微服务)服务消费者:一次业务中,调用其它微服务的服务。(调用其它微服务提供的接口)

在这里插入图片描述

(三)eureka注册中心

远程调用的问题

在这里插入图片描述

eureka原理

在这里插入图片描述

在EEureka架构中,微服务角色有两类:
EurekaServer:服务端,注册中心
记录服务信息
心跳监控
EurekaClient:客户端
Provider:服务提供者,例如案例中的user-service注册自己的信息到EurekaServer
每隔30秒向EurekaServer发送心跳
consumer:服务消费者,例如案例中的 order-service根据服务名称从EurekaServer拉取服务列表基于服务列表做负载均衡,选中一个微服务后发起远程调用

搭建EurekaServer

在这里插入图片描述
搭建EurekaServer

1.创建项目,引入spring-cloud-starter-netflix-eureka-server的依赖

<dependency> 
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

2.编写启动类,添加@EnableEurekaServer注解

3.添加application.yml文件,编写下面的配置:

server:port: 10086
spring:application:name: eurekaservereureka:client:service-url:  defaultZone: http://127.0.0.1:10086/eureka/

服务注册

注册user-service

在user-service项目引入spring-cloud-starter-netflix-eureka-client的依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency>

在application.yml文件,编写下面的配置:

spring:application:name: userserviceeureka:client:service-url:defaultZone: http://127.0.0.1:10086/eureka/

order-service完成服务注册

order-service虽然是消费者,但与user-service一样都是eureka的client端,同样可以实现服务注册:
1.在order-service项目引入spring-cloud-starter-netflix-eureka-client的依赖

<dependency><groupId>org.springframework.cloud</groupId>  <artifactId>spring-cloud-starter-netflix-eurekaclient</artifactId></dependency>

2.在application.yml文件,编写下面的配置:

spring:application:name: orderserviceeureka:client:service-url:defaultZone: http://127.0.0.1:10086/eureka/

1.服务注册
·引入eureka-client依赖
·在application. yml中配置eureka地址
2.无论是消费者还是提供者,引入eureka-client依赖知道eureka地址后,都可以完成服务注册

服务发现

在order-service完成服务拉取

服务拉取是基于服务名称获取服务列表,然后在对服务列表做负载均衡
1.修改OrderService的代码,修改访问的url路径,用服务名代替ip、端口:

String url = "http://userservice/user/" + order.getUserId();

2.在order-service项目的启动类OrderApplication中的RestTemplate添加负载均衡注解:

@Bean
@LoadBalanced
public RestTemplate restTemplate() {return new RestTemplate();}

在这里插入图片描述

(四)Ribbon负载均衡原理

负载均衡原理

在这里插入图片描述

负载均衡策略

Ribbon的负载均衡规则是一个叫做IRule的接口来定义的,每一个子接口都是一种规则:

在这里插入图片描述
在这里插入图片描述

通过定义IRule实现可以修改负载均衡规则,有两种方式:
1.代码方式:在order-service中的OrderApplication类中,定义一个新的IRule:

@Bean
public IRule randomRule(){return new RandomRule();}

2.配置文件方式:在order-service的application.yml文件中,添加新的配置也可以修改规则:

userservice:
ribbon:NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule# 负载均衡规则

懒加载

Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。
而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

ribbon:eager-load:enabled: true # 开启饥饿加载 clients: userservice # 指定对userservice这个服务饥饿加载

在这里插入图片描述

(五)nacos注册中心

认识和安装Nacos

Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。相比Eureka功能更加丰富,在国内受欢迎程度较高。
在这里插入图片描述

Nacos服务搭建
a.下载安装包
GitHub主页:https://github.com/alibaba/nacos
GitHub的Release下载页:https://github.com/alibaba/nacos/releases
b.解压
c.在bin目录下运行指令:startup.cmd -m standalone

Nacos快速入门

服务注册到Nacos

1.在cloud-demo父工程中添加spring-cloud-alilbaba的管理依赖:

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.6.RELEASE</version>  <type>pom</type><scope>import</scope></dependency>

2.注释掉order-service和user-service中原有的eureka依赖。
3.添加nacos的客户端依赖:

<!-- nacos客户端依赖 -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>

4.修改user-service&order-service中的application.yml文件,注释eureka地址,添加nacos地址:

spring:cloud:nacos:server-addr: localhost:8848 # nacos 服务端地址 

在这里插入图片描述

Nacos服务分级存储模型

在这里插入图片描述

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高
本地集群不可访问时,再去访问其它集群

服务集群属性

1.修改application.yml,添加如下内容:

spring:
cloud:nacos:   server-addr: localhost:8848 # nacos 服务端地址    discovery: cluster-name: HZ # 配置集群名称,也就是机房位置,例如:HZ,杭州

2.在Nacos控制台可以看到集群变化:

在这里插入图片描述
在这里插入图片描述
根据集群负载均衡

1.修改order-service中的application.yml,设置集群为HZ:

spring:cloud:nacos:server-addr: localhost:8848 # nacos 服务端地址 discovery:  cluster-name: HZ # 配置集群名称,也就是机房位置

2.然后在order-service中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务

userservice:ribbon:NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

在这里插入图片描述
根据权重负载均衡

实际部署中会出现这样的场景:
服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请求
Nacos提供了权重配置来控制访问频率,权重越大则访问频率越高

1.在Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮

在这里插入图片描述

2.将权重设置为0.1(0-1),测试可以发现8081被访问到的频率大大降低

在这里插入图片描述
在这里插入图片描述

Nacos环境隔离

在这里插入图片描述

1.在Nacos控制台可以创建namespace,用来隔离不同环境

在这里插入图片描述

2.然后填写一个新的命名空间信息:

在这里插入图片描述

3.保存后会在控制台看到这个命名空间的id:

在这里插入图片描述

4.修改order-service的application.yml,添加namespace

spring:datasource:url: jdbc:mysql://localhost:3306/heima?useSSL=falseusername: rootpassword: 123driver-class-name: com.mysql.jdbc.Driver cloud:nacos:server-addr: localhost:8848 discovery:cluster-name: SH # 上海namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID

5.重启order-service后,再来查看控制台:

在这里插入图片描述
在这里插入图片描述

6.此时访问order-service,因为namespace不同,会导致找不到userservice,控制台会报错

在这里插入图片描述

后记
👉👉💕💕美好的一天,到此结束,下次继续努力!欲知后续,请看下回分解,写作不易,感谢大家的支持!! 🌹🌹🌹


http://chatgpt.dhexx.cn/article/4Cw03Y4q.shtml

相关文章

微服务学习——微服务框架

Nacos配置管理 统一配置管理 配置更改热更新 将配置交给Nacos管理的步骤&#xff1a; 在Nacos中添加配置文件在微服务中引入nacos的config依赖在微服务中添加bootstrap.yml&#xff0c;配置nacos地址、当前环境、服务名称、文件后缀名。这些决定了程序启动时去nacos读取哪个…

SpringCloud 微服务框架

单体架构&#xff1a;将业务全部功能集中到一个项目中&#xff0c;打成一个war包存储,部署在一台服务器中&#xff0c;只有一个数据库 优点 &#xff1a;架构简单&#xff0c;部署成本低。适合小型项目 问题&#xff1a;高并发性能问题&#xff0c;开发时代码耦合问题&#x…

零基础秒懂:手把手教你搭建一套微服务框架!

个人博客请访问 http://www.x0100.top 这套微服务框架能干啥&#xff1f; 这套系统搭建完之后&#xff0c;可以实现&#xff1a; 微服务架构&#xff0c;你的整个应用程序将会被拆分成一个个功能独立的子系统&#xff0c;独立运行&#xff0c;系统与系统之间通过 RPC 接口通…

微服务架构 — 微服务框架

目录 文章目录 目录微服务框架第一代微服务框架Spring CloudDubbo下一代微服务框架 — Service MeshIstioEnvoyKubernetes + Service Mesh = 完整的微服务框架微服务框架 微服务架构首先要面对分布式架构的内生复杂性,即:服务通信和服务治理的复杂性,例如:服务发现、熔断、…

微服务架构与开源框架

微服务架构介绍及实践 微服务现在是一个很火的概念&#xff0c;尤其是搞IT的大多数都对其有所了解。 到底火到什么程度呢&#xff1f;2016年有一个统计说&#xff0c;两千家企业里&#xff0c;30%在使用微服务&#xff0c;15%在实验开发和测试微服务架构&#xff0c;24%在学习…

微服务框架

这里写自定义目录标题 微服务框架功能Spring Cloud简介Eureka简介Eureka⼊⻔源码解析Eureka的⼀些概念 Register 服务注册 微服务框架功能 微服务具有以上的这些特点&#xff0c;那么作为⼀个微服务框架&#xff0c;⽐如Spring Cloud&#xff0c;应该具备⼀些什么功能 呢&…

微服务框架springcloud

基础 单体架构&#xff1a;将业务全部功能集中到一个项目中&#xff0c;打成一个war包存储,部署在一台服务器中&#xff0c;只有一个数据库 优点 &#xff1a;架构简单&#xff0c;部署成本低。适合小型项目 问题&#xff1a;高并发性能问题&#xff0c;开发时代码耦合问题&…

微服务框架的介绍

一、什么是微服务 微服务并没有一个官方的定义&#xff0c;可以理解为一种架构风格&#xff0c;将一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署&#xff0c;各个微服务之间是松耦合的。每个微服务仅关注于完成一件任务并很好地完成该任务。在…

第六篇:微服务框架(SpringBoot、SpringCloud)

目录 一. 微服务框架 1. 微服务架构概念 2. 微服务的利与弊&#xff08;为什么要用微服务&#xff09; 二. SpringBoot 1. SpringBoot是什么&#xff1f; 2. SpringBoot核心注解是什么&#xff1f; 3. 什么是SpringBoot的自动配置&#xff1f;原理是什么&#xff1f; 4…

DLL文件的创建和调用

文章目录 前言一、DLL的优势二、使用步骤1.创建DLL文件2.调用DLL文件 总结 前言 动态数据库 (DLL) 是作为共享函数库的可执行文件。动态数据库提供了一种方法&#xff0c;使进程可以调用不属于其可执行代码的函数。本文将对DLL的创建和调用步骤进行保姆级讲解。 一、DLL的优势…

C# 调用 dll 文件

一、先使用C来创建一个 .dll 文件 1、创建新项目&#xff1a;CreateDll01 2、选择 “动态链接库(.dll)” 文件 3、在 CreateDll01.cpp 源文件中添加如下代码 // CreateDll01.cpp : 定义 DLL 应用程序的导出函数。 //#include "stdafx.h"extern "C" __decl…

dll是什么呢?dll丢失如何解决?

DLL的概念 DLL(Dynamic Link Library)文件为动态链接库文件&#xff0c;又称“应用程序拓展”&#xff0c;是软件文件类型。在Windows中&#xff0c;许多应用程序并不是一个完整的可执行文件&#xff0c;它们被分割成一些相对独立的动态链接库&#xff0c;即DLL文件&#xff0…

C++ 制作动态链接库.dll及.dll使用

声明&#xff1a;IDE是Visual studio -version 2022 其制作的动态链接库dll里面实现简单的加减法&#xff0c;提供给其他项目调用。 一、动态链接库&#xff08;DLL&#xff09;创建 1、创建DLL工程 流程&#xff1a;文件 -> 新建 -> 项目 -> 动态链接库&#xf…

.dll、.lib、.dll.a 的区别

我们已 ffmpeg 的动态链接库为例&#xff0c;描述一下这三个文件的作用&#xff1a; 目录整体结构&#xff1a; 分析 bin 目录&#xff1a; ffmpeg、ffplay、ffprobe 之所以这么小&#xff0c;是因为他们运行的时候会调用 .dll 文件当中的代码。dll&#xff1a;真正存放函数…

Java调用dll文件

目录 1 C创建dll 1.1 项目与工具 1.2 步骤与代码 2 Java使用JNA调用dll 2.1 项目与工具 2.2 步骤与代码 3 实际效果 4 参考链接 1 C创建dll 1.1 项目与工具 Visual Studio 2019 1.2 步骤与代码 ①使用VS创建动态链接库&#xff08;DLL&#xff09;项目 ②设置项目名与…

什么是dll文件

动态链接库&#xff08;Dynamic Link Library 或者 Dynamic-link Library&#xff0c;缩写为 DLL&#xff09;&#xff0c;是微软公司在微软Windows操作系统中&#xff0c;实现共享函数库概念的一种方式。这些库函数的扩展名是 ”.dll"、".ocx"&#xff08;包含…

什么是dll

DLL的概念 DLL(Dynamic Link Library)文件为动态链接库文件&#xff0c;又称“应用程序拓展”&#xff0c;是软件文件类型。在Windows中&#xff0c;许多应用程序并不是一个完整的可执行文件&#xff0c;它们被分割成一些相对独立的动态链接库&#xff0c;即DLL文件&#xff0c…

XWiKi 部分汉化

一、进入XWiki首页&#xff0c;用管理员进行登陆 账号&#xff1a;superadmin 密码&#xff1a;system 登陆后点击右上角&#xff0c;如下图所示 二、点开管理页面 如下图所示&#xff1a; 三、搜索localization 四、按照图中进行修改 然后部分汉化就完成了 当然&#xff0c;如…

XWiKi 汉化

进入XWiKi主页&#xff0c;然后点击菜单栏&#xff0c;进入管理&#xff0c;汉化前图片显示&#xff1a; 汉化后图片显示 一、进入安装目录/xwiki/WEB-INF/lib/下找到xwiki-platform-legacy-oldcore-10.7.jar 二、用zip解压软件进入xwiki-platform-legacy-oldcore-10.7.jar不要…

xwiki开发指南1-使用XWiki创建FAQ应用

本文是按照XWiki官网开发指南-FAQ应用创建&#xff0c;自己翻译总结的版本。 此篇含有大量图片&#xff0c;关于XWiki的开发&#xff0c;将在下一篇讲解。 关于XWiki的部署也会单独写一篇基于docker的部署文。 使用XWiki创建FAQ应用 1.首先下载并部署XWiki&#xff08;之后会…