【高频面试题】微服务篇

news2025/1/10 11:43:19

文章目录

  • Spring Cloud
    • 1.Spring Cloud 5大组件有哪些?
    • 2.服务注册和发现是什么意思?Spring Cloud 如何实现服务注册发现?
    • 3.负载均衡如何实现的 ?
    • 4.什么是服务雪崩,怎么解决这个问题?
    • 5.微服务是怎么监控的
  • 业务相关
    • 6.项目中有没有做过限流 ? 怎么做的 ?
    • 7.解释一下CAP和BASE
    • 8.分布式事务解决方案?
    • 9.分布式服务的接口幂等性如何设计?
    • 10.分布式任务调度

Spring Cloud

1.Spring Cloud 5大组件有哪些?

以下面这幅图为例:
在这里插入图片描述
通常情况下可以分为:

  • Eureka : 注册中心
  • Ribbon : 负载均衡
  • Feign : 远程调用
  • Hystrix : 服务熔断
  • Zuul/Gateway : 网关

一般现在使用SpringCloudAlibba比较多:

  • 注册中心/配置中心 Nacos
  • 负载均衡 Ribbon
  • 服务调用 Feign
  • 服务保护 sentinel
  • 服务网关 Gateway

2.服务注册和发现是什么意思?Spring Cloud 如何实现服务注册发现?

注册中心的核心作用是:服务注册和发现

而现在常用的注册中心可以分为两种:

Eureka(被动型)

在这里插入图片描述
具体流程:

  1. 服务注册:服务提供者需要把自己的信息注册到eureka,由eureka来保存这些信息,比如服务名称、ip、端口等等
  2. 服务发现:消费者向eureka拉取服务列表信息,如果服务提供者有集群,则消费者会利用负载均衡算法选择一个发起调用
  3. 服务监控:服务提供者会每隔30秒向eureka发送心跳,报告健康状态,如果eureka服务90秒没接收到心跳,从eureka中剔除

nacos(主动型)
在这里插入图片描述
具体流程:

具体流程与Eureka类似

Nacos与eureka的共同点(注册中心)

  • 都支持服务注册和服务拉取
  • 都支持服务提供者心跳方式做健康检测

Nacos与Eureka的区别(注册中心)

  • Nacos支持服务端主动检测提供者状态:
    临时实例采用心跳模式非临时实例采用主动检测模式
    临时实例心跳不正常会被剔除,非临时实例则不会被剔除
  • Nacos支持服务列表变更的消息推送模式服务列表更新更及时
  • Nacos集群默认采用AP(高可用)方式,当集群中存在非临时实例时,采用CP(强一致)模式;Eureka采用AP方式
  • Nacos还支持了配置中心,eureka则只有注册中心,也是选择使用nacos的一个重要原因

3.负载均衡如何实现的 ?

微服务的负载均衡主要使用了一个组件Ribbon,比如,我们在使用feign远程调用的过程中,底层的负载均衡就是使用了ribbon
在这里插入图片描述
Ribbon负载均衡策略有哪些 ?

  • RoundRobinRule:简单轮询服务列表来选择服务器
  • WeightedResponseTimeRule:按照权重来选择服务器,响应时间越长,权重越小
  • RandomRule(随机):随机选择一个可用的服务器
  • ZoneAvoidanceRule(就近原则):区域敏感策略,以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询(默认)(如果没有区域的概念,就默认轮询)

自定义负载均衡策略

有两种方式:

  1. (创建类配置)创建类实现IRule接口,可以指定负载均衡策略(全局

在这里插入图片描述

  1. (配置文件配置单个服务)在客户端的配置文件中,可以配置某一个服务调用的负载均衡策略(局部
    在这里插入图片描述

4.什么是服务雪崩,怎么解决这个问题?

服务与服务之间是存在互相调用的情况

服务雪崩就是一个服务失败,导致整条链路的服务都失败的情形。
在这里插入图片描述
解决办法有两种:

1. 服务降级(服务部分接口)

服务降级是服务自我保护的一种方式,或者保护下游服务的一种方式,用于确保服务不会受请求突增影响变得不可用,确保服务不会崩溃
一般在实际开发中与feign接口整合,编写降级逻辑

在这里插入图片描述
例如上图,update方法可以正常访问,但是save方法不能访问,这个时候就会走一个服务降级的方案(也就是走另一个方案),给用户一些提示消息
在这里插入图片描述
上图通过在服务接口上加上@FeignClient注解,指定服务的名字出现异常后要降级的执行类

如果降级的接口达到一定数量,就会触发熔断机制

2. 熔断机制(整个服务)

默认关闭,需要手动打开,如果检测到 10 秒内请求的失败率超过 50%,就触发熔断机制。之后每隔 5 秒重新尝试请求微服务,如果微服务不能响应继续熔断机制。如果微服务达,则关闭熔断机制,恢复正常请求

在这里插入图片描述


5.微服务是怎么监控的

  • 1,skywalking主要可以监控接口、服务、物理实例的一些状态。特别是在压测的时候可以看到众多服务中哪些服务和接口比较慢,我们可以针对性的分析优化
  • 2,我们还在skywalking设置了告警规则,特别是在项目上线以后,如果报错,我们分别设置了可以给相关负责人发短信和发邮件,第一时间知道项目的bug情况,第一时间修复

业务相关

6.项目中有没有做过限流 ? 怎么做的 ?

为什么要限流?

1,并发的确大(突发流量)
2,防止用户恶意刷接口

限流的实现方式:

  1. Tomcat:可以设置最大连接数

每一个服务都有一台tomcat服务器,可以在通过Tomcat设置最大连接数,但是这种只适合与单体项目

在这里插入图片描述

  1. Nginx限流:包括两种限流方式

控制速率(突发流量)

核心就是采用了漏桶算法做限流
使用的漏桶算法来实现过滤,让请求以固定的速率处理请求,可以应对突发流量

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

控制并发连接数

限制单个ip的链接数并发链接的总数

在这里插入图片描述

3. 网关限流

在spring cloud gateway中支持局部过滤器RequestRateLimiter来做限流,使用的是令牌桶算法
可以根据ip路径进行限流,可以设置每秒令牌填充平均速率,和令牌桶总容量

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

漏桶和令牌桶的区别
漏桶:固定速率放行请求;
令牌桶:固定速率生成令牌,请求拿到令牌则放行多余令牌则存储;
令牌桶处理的速度可能会超过生成令牌的速度

7.解释一下CAP和BASE

CAP理论

  • Consistency(一致性)

用户访问分布式系统中的任意节点,得到的数据必须一致

  1. Availability(可用性)

用户访问集群中的任意健康节点,必须能得到响应,而不是超时或拒绝

  1. Partition tolerance (分区容错性)

因为网络故障或其它原因导致分布式系统中的部分节点与其它节点失去连接,形成独立分区。在集群出现分区时,整个系统也要持续对外提供服务

在这里插入图片描述
结论:

  1. 分布式系统节点之间肯定是需要网络连接的,分区(P)必然存在的
  2. 如果保证访问的高可用性(A),可以持续对外提供服务,但不能保证数据的强一致性–> AP
  3. 如果保证访问的数据强一致性(C),就要放弃高可用性 --> CP

BASE理论
BASE理论是对CAP的一种解决思路,包含三个思想:

  • Basically Available (基本可用):分布式系统在出现故障时,允许损失部分可用性,即保证核心可用。
  • Soft State(软状态):在一定时间内,允许出现中间状态,比如临时的不一致状态。
  • Eventually Consistent(最终一致性):虽然无法保证强一致性,但是在软状态结束后,最终达到数据一致。

核心在于事务协调器

在这里插入图片描述
解决分布式事务的思想和模型:

  1. 最终一致思想:各分支事务分别执行并提交,如果有不一致的情况,再想办法恢复数据(AP
  2. 强一致思想:各分支事务执行完业务不要提交,等待彼此结果。而后统一提交或回滚(CP)

8.分布式事务解决方案?

Seata框架(XA、AT、TCC)

Seata事务管理中有三个重要的角色:

  • TC (Transaction Coordinator) - 事务协调者:维护全局和分支事务的状态,协调全局事务提交或回滚。
  • TM (Transaction Manager) - 事务管理器:定义全局事务的范围、开始全局事务、提交或回滚全局事务。
  • RM (Resource Manager) -资源管理器:管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。
    在这里插入图片描述
    XA模式(CP)
    在这里插入图片描述

AT模式(AP)
在这里插入图片描述
TCC模式(AP)

1、Try:资源的检测和预留;
2、Confirm:完成资源操作业务;要求 Try 成功 Confirm 一定要能成功。
3、Cancel:预留资源释放,可以理解为try的反向操作。
在这里插入图片描述

MQ
在这里插入图片描述
总结
只要是发生了多个服务之间的写操作,都需要进行分布式事务控制

描述项目中采用的哪种方案(seata | MQ)

像银行业务就不需要高可用性,只要达到最终一致就可以了
互联网业务就要高可用

  • seata的XA模式,CP,需要互相等待各个分支事务提交,可以保证强一致性,性能差(银行业务)
  • seata的AT模式,AP,底层使用undo log 实现,性能好(互联网业务)
  • seata的TCC模式,AP,性能较好,不过需要人工编码实现(银行业务)
  • MQ模式实现分布式事务,在A服务写数据的时候,需要在同一个事务内发送消息到另外一个事务异步,性能最好(互联网业务)

9.分布式服务的接口幂等性如何设计?

幂等:多次调用方法或者接口不会改变业务状态,可以保证重复调用的结果和单次调用的结果一致。

基于RESTful API的角度对部分常见类型请求的幂等性特点进行分析
在这里插入图片描述
所以,只有在请求方式是POST,或者PUT情况下会出现接口不幂等的情况。

有三种解决方案:

  1. 数据库唯一索引(可解决新增带来的不幂等)

如果数据库表没有唯一索引,就不能保证新增操作的幂等性(新增数据时会受唯一索引影响不能添加索引重复的数据)

  1. token+redis(新增、修改)----性能好

创建商品、提交订单、转账、支付等操作

举例提交订单的例子

在这里插入图片描述
在这里插入图片描述
第一次请求,生成一个唯一token存入redis返回给前端
第二次请求,业务处理,携带之前的token,到redis进行验证,如果存在,可以执行业务删除token;如果不存在,则直接返回,不处理业务

这样就解决了因为网络故障页面重复下单的问题,因为token在进行第一次下单创建订单之后,就会把redis中的token删除,就算再次点击下单,发现redis没有token导致验证失败,自然不能完成下单动作

  1. 分布式锁(新增、修改)----性能差

在这里插入图片描述

原理就是保证下单动作不受影响,直到完成下单才释放锁,其他线程拿不到锁就马上显示失败操作就行,而且使用分布式锁要保证锁的细粒度,要精确枷锁,不要锁住一些与原需要枷锁业务无关的业务枷锁,导致整体性能变差

10.分布式任务调度

xxl-job路由策略有哪些?
xxl-job提供了很多的路由策略,平时用的较多就是:轮询故障转移分片广播
在这里插入图片描述
xxl-job任务执行失败怎么解决?
路由策略选择故障转移,使用健康的实例来执行任务
设置重试次数
查看日志+邮件告警来通知相关负责人解决
在这里插入图片描述
在这里插入图片描述

如果有大数据量的任务同时都需要执行,怎么解决?
多个实例一块去执行(部署集群),路由策略分片广播
在任务执行的代码中可以获取分片总数当前分片,按照取模的方式分摊到各个实例执行

在这里插入图片描述

更新中-------------
素材来自----黑马程序员

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

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

相关文章

arcgis--数据库构建网络数据集

1、打开arcmap软件,导入数据,如下: 该数据已经过处理,各交点处均被打断,并进行了拓扑检查。 2、在文件夹下新建文件数据库,名称为路网,在数据库下新建要素类,并导入道路shp文件&…

Matlab修改文本编码格式为UTF-8

一、修改文本编码格式 Matlab默认使用GBK编码格式&#xff0c;当代码中有中文注释时&#xff0c;注释显示乱码。 修改配置文件(安装目录下的bin目录有个lcdata.xml)&#xff0c;如下&#xff1a; 1. 删除 2. 修改 < encoding name”UTF-8”> < encoding_alias nam…

文件的管理

一、目录文件的管理 1、创建 2、编辑 3、查看内容 4、删除 二、普通文件的管理 1、创建 2、编辑 3、查看 1&#xff09;整个文档内容的查看 2&#xff09;文档列内容处理后查看 面试重点&#xff0c;年年考 3&#xff09;搜索文件内容查看&#xff0c;列出有关键字的一行 4、…

谷粒商城第十天-分组新增级联显示商品分类分组修改级联回显商品分类

目录 一、总述 二、前端实现 三、后端实现 四、总结 一、总述 本次就是一个小的优化。 就是分组新增或者是修改的时候&#xff0c;直接显示商品分类的id可读性不高&#xff0c;新增的时候需要填写对商品分类的id&#xff0c;修改的时候&#xff0c;就只是给你一个商品分类…

One-4-All: Neural Potential Fields for Embodied Navigation 论文阅读

论文信息 题目&#xff1a;One-4-All: Neural Potential Fields for Embodied Navigation 作者&#xff1a;Sacha Morin, Miguel Saavedra-Ruiz 来源&#xff1a;arXiv 时间&#xff1a;2023 Abstract 现实世界的导航可能需要使用高维 RGB 图像进行长视野规划&#xff0c;这…

电影售票后台管理系统快速搭建(优惠券制作+java开源)

为了快速搭建电影售票后台管理系统并实现优惠券制作功能&#xff0c;你可以按照以下步骤进行操作&#xff1a; 1. 确定系统的需求和功能&#xff0c;包括用户管理、影院管理、电影管理、订单管理以及优惠券制作等模块。 2. 选择一款适合的Java开源框架来搭建系统&#xff0c;…

深度分析卡尔曼滤波算法原理

一、什么是卡尔曼滤波? 你可以在任何含有不确定信息的动态系统中使用卡尔曼滤波&#xff0c;对系统下一步的走向做出有根据的预测&#xff0c;即使伴随着各种干扰&#xff0c;卡尔曼滤波总是能指出真实发生的情况。 在连续变化的系统中使用卡尔曼滤波是非常理想的&#xff0c…

玩机搞机---安卓新机型payload.bin刷写救砖 无需专用线刷包

目前的新机型官方卡刷包解包后都是payload.bin分区格式的卡刷固件。而有个别一些机型没有线刷包&#xff0c;当这些机型出现系统问题的时候有以下几种方法参考救砖。遇到类似故障的朋友可以借鉴参考下. 其中的不足和相关的资源可以参考这两个博文。任何教程的目的只是拓展你的…

从零开始实现一个 mini-Retrofit 框架

前言 本篇文章将采用循序渐进的编码方式&#xff0c;从零开始实现一个Retorift框架&#xff0c;在实现过程中不断提出问题并分析实现&#xff0c;最终开发出一个mini版的Retrofit框架 演示一个使用OkHttp的项目Demo 为了更好的演示框架的实现过程&#xff0c;这里我先创建了一…

关于echarts遇到的一些问题

1.echarts监听legend&#xff0c;动态设置legend属性无效 动态更改legend中的icon&#xff0c; myChart.setOption(option&#xff09;失效&#xff0c;但是设置局部就生效 myChart.on(legendselectchanged, function (params) {if (params.selected[params.name]) {data1[dat…

SSM项目-博客系统

在线体验项目&#xff1a;登陆页面 项目连接&#xff1a;huhublog_ssm: 个人博客系统 技术栈&#xff1a;SpringBoot、SpringMVC、Mybatis、Redis、JQuery、Ajax、Json (gitee.com) 1.项目技术点分析 SpringBoot、SpringWeb(SpringMVC)、MyBatis、MySQL(8.x)、Redis(存储验…

Elastic的下载

文章目录 ElasticSearch的下载扩展1&#xff08;ElasticSearch 与 JDK 版本 适配&#xff09;扩展2&#xff08;访问 http://192.168.1.200:9200 没有显示信息&#xff09;扩展3&#xff08;免密登录&#xff09; ElasticSearch的下载 官方下载网址&#xff1a;https://www.el…

antd design 多个弹框设置区分状态的技巧

可以使用 enum 枚举的方式去做区分 // 置管状态区分 // eslint-disable-next-line no-shadow export enum catheteringType {ADD add,EDIT edit,EXAMINE examine, } 引入上述代码接着设置状态 // 置管记录弹框/状态区分const [catheteringModalTypeConfig, setCatheterin…

全志D1-H (MQ-Pro)驱动 OV5640 摄像头

内核配置 运行 m kernel_menuconfig 勾选下列驱动 Device Drivers ---><*> Multimedia support --->[*] V4L platform devices ---><*> Video Multiplexer[*] SUNXI platform devices ---><*> sunxi video input (camera csi/mipi…

DP与EDP接口协议学习

文章目录 一、概念介绍DP----DisplayPort&#xff0c;一种标准化数字式视频接口&协议EDP---Embedded DisplayPort&#xff0c;DP协议在嵌入式领域拓展DP和HDMI对比----HDMI当前应用更广&#xff0c;DP是PC领域推出协议 二、DP&EDP相关协议分析三条数据通路Manlink 、Au…

赛码网-打字100%AC代码(C语言)

———————————————————————————————————— ⏩ 大家好哇&#xff01;我是小光&#xff0c;嵌入式爱好者&#xff0c;一个想要成为系统架构师的大三学生。 ⏩最近在准备秋招&#xff0c;一直在练习编程。 ⏩本篇文章对赛码网的打字题目做一个详…

ViSQOL、PESQ、mosnet等mos分打分工具和Polqa语音感知音质打分测评

原创&#xff1a;转载需附链接&#xff1a; https://blog.csdn.net/qq_37100442/article/details/132057139?spm1001.2014.3001.5502 一、背景 Mos分评价音质重要指标&#xff0c;最近也有很多机构和公司在研究适合自己的评价体系。目前Mos分主要分为主观评测和客观感知评价。…

49. 海豚记账簿软件(b站的一个小项目)

闲着也是闲着就跟着别人做了一个小项目 目录 1.需求和目标 2.整体功能描述 3.核心思路 4.全部代码 1.需求和目标 项目的需求&#xff0c;实现一个叫做“海豚记账簿”的基于命令行界面的家庭记账软件。 2.整体功能描述 这个软件相对简单&#xff0c;只需要基于命令行做纯…

【数据结构OJ题】移除元素

原题链接&#xff1a;https://leetcode.cn/problems/remove-element/ 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 2. 思路分析 方法一&#xff1a;暴力删除&#xff0c;挪动数据覆盖。即遍历整个nums[ ]数组&#xff0c;遇到值等于val的元素&#xff0c;就将整…

Eclipse如何自动添加作者、日期等注释

一、创建类时自动添加注释 1、Window->Preferences 2、Java->Code Syle->Code Templates->Code->New Java files->Edit->要添加的注释->Apply 二、选中要添加的类或者方法通过AltShiftJ快捷键添加 1、Window->Preferences 2、Java->Code Syle…