微服务保护相关面试题

微服务保护

思考面试题:

是否了解什么是微服务的雪崩效应? 或 微服务间如果调用失败,该如何处理?

微服务组件 alibaba-sentinel 介绍? 可以做什么?

如何基于sentinel实现限流功能? sentinel支持的限流规则?

什么是线程隔离? sentinel中如何实现线程隔离?

什么是服务熔断?sentinel中熔断如何配置的? 工作原理是否了解(熔断器)

如何整合Feign + Sentinel 实现服务降级配置?

是否了解什么是微服务的雪崩效应? 或 微服务间如果调用失败,该如何处理?

1. 什么是雪崩效应

在分布式框架中 , 由于其中的一个微服务节点发生问题 , 导致调用该节点的其他微服务发送阻塞 , 而调用方微服务又被其他微服务所调用 , 由此而产生的调用链中所有的微服务都出现问题

2. 如何处理雪崩问题

  • 1.流量控制

对于不同微服务的QPS可以进行一个合理的评估 , 限制流量在服务访问最大QPS的范围内

  • 2.线程隔离

给定每个业务限定的线程数 , 以保证不会出现整个容器资源耗尽而导致服务崩溃

  • 3.超时处理

对请求设置超时时间 , 如果请求超时则直接拒绝

  • 4.熔断

给服务添加熔断器 , 合理设置熔断规则

微服务组件 alibaba-sentinel 介绍? 可以做什么?

微服务组件 alibaba-sentinel是用来对微服务就行保护以避免出现雪崩现象

如何基于sentinel实现限流功能? sentinel支持的限流规则?

1. 如何基于sentinel实现限流功能

首先安装并运行sentinel , 在对应的服务中添加相关依赖并在配置文件中对sentinel 进行配置

2. sentinel支持的限流规则?

  • 1.直接限流

设置限流规则 --> 设置访问的QPS阈值 , 当QPS超出阈值则拒绝访问

  • 2.关联

与当前资源相关的另一个资源同时进行操作时 , 我们可以设置当其中一个微服务访问的QPS达到一定值时对另一个微服务的访问进行限制

使用场景: 当查询订单和修改订单同时进行时 , 对查询就行限制以保证修改的安全.

  • 3.链路

当不同服务同时对一资源进行访问时 , 可以对资源进行流控 , 设置入口服务的访问流量

ps : 关联与链路之前的区别在于 , 关联是两个不同的服务如读和写 , 这两种操作 , 虽然都是对数据库进行操作 , 但是实现过程不一样. 而对于链路来说是不同服务调用同一资源.

什么是线程隔离? sentinel中如何实现线程隔离?

什么是线程隔离?

给每个业务限定能使用的线程数 , 以避免耗尽整个容器的资源 , 导致服务崩溃

sentinel中如何实现线程隔离?

sentinel采用信号量隔离的模式 , 记录业务所使用的线程数量 , 当达到阈值是则拒绝请求

什么是服务熔断?sentinel中熔断如何配置的? 工作原理是否了解(熔断器)

什么是服务熔断?

服务熔断是在服务中配置熔断器 , 当请求失败达到设定的阈值时开启熔断器拒绝所有请求 , 并在设置的熔断时间后尝试放行一个请求 , 如果该请求成功 , 则关闭熔断器 , 反之继续执行

sentinel中熔断如何配置的?

sentinel的服务熔断分为三种方式

  • 慢调用

设置在规定时间内的规定请求数与超时时间 , 如果请求超时占比达到设定的阈值则开启熔断

  • 异常比列

设定在规定时间内的规定请求数 , 如果请求失败占比达到设定的阈值则开启熔断器

  • 异常数

设定在规定时间内 , 如果请求失败数达到设定的阈值则开启熔断

如何整合Feign + Sentinel 实现服务降级配置?

  1. 修改Feign配置 , 开启Sentinel功能
  2. 在需要进行服务降级的微服务中定义类继承FallBackFactory/FallbackClass , 重写里面的方法 , 定义服务降级策略
  3. 将该类交给Spring容器管理
  4. 在Feign的FeignClient注解中开启自定义策略
相关推荐
水淹萌龙4 小时前
k8s 中使用 Service 访问时NetworkPolicy不生效问题排查
云原生·容器·kubernetes
码农飞哥11 小时前
互联网大厂Java求职面试实战:Spring Boot到微服务全景解析
java·spring boot·微服务·maven·hibernate·技术栈·面试技巧
MZWeiei12 小时前
Spark SQL 运行架构详解(专业解释+番茄炒蛋例子解读)
大数据·分布式·sql·架构·spark
#金毛12 小时前
一、HAL库的设计理念详解:从架构到实践
stm32·嵌入式硬件·架构
是麟渊12 小时前
【大模型面试每日一题】Day 17:解释MoE(Mixture of Experts)架构如何实现模型稀疏性,并分析其训练难点
人工智能·自然语言处理·面试·职场和发展·架构
好吃的肘子12 小时前
MongoDB 高可用复制集架构
数据库·mongodb·架构
TsingtaoAI12 小时前
医疗系统开发架构和技术路线建议-湖南某三甲医院
架构·医疗ai系统·医疗信息化·医疗系统架构·医疗ai机构
敲代码的 蜡笔小新12 小时前
【行为型之命令模式】游戏开发实战——Unity可撤销系统与高级输入管理的架构秘钥
unity·设计模式·架构·命令模式
云攀登者-望正茂13 小时前
最大化效率和性能:AKS 中节点池的强大功能
云原生·容器·kubernetes
码上飞扬13 小时前
MongoDB数据库深度解析:架构、特性与应用场景
数据库·mongodb·架构