当前位置: 首页 > news >正文

微服务面试题

五大组件

注册中心/配置中心

nacos

服务注册 服务启动时 将自己的id等信息发送给nacos 完成注册

服务发现 服务需要调用其他服务时 从nacos获取服务列表 交给负载均衡选择

服务监控

  1. 临时实例 由服务每隔一段时间注册中心发送信息 表示自己存活 若注册中心超过一定时间没有接收到信息 则默认服务已死亡 直接从列表中剔除

  2. 非临时实例 由注册中心每隔一段时间向服务发送信息 询问是否存活 若未收到信息 则剔除

  3. 当注册中心服务变更时 nacos会主动推送新服务列表信息给其他服务

负载均衡

loadbalance/ribbon

当同一个服务有多个实例可使用时 由负载均衡根据策略选择使用哪个服务

策略

轮询 随机询问 询问最小连接数 询问最长无连接时间数 按优先级询问

网关

gateway

限流 采用令牌桶算法 即预先准备好一批令牌存入桶中 令牌生成效率固定 当桶满时 停止生成令牌 当流量通过时 需要获取一个令牌 才会被放行 当大量请求发送时 桶中令牌会被获取 被获取的同时 新的令牌也正在生成 每生成一批令牌就可以使一些流量被放行 其他没有获得令牌的 请求被丢弃或者阻塞

也可以采用nginx的限流方法 nginx采用的是漏桶算法 即将请求存入桶中 一段时间放行一批请求 当桶满时 其他请求阻塞

熔断

sentinel

熔断方法 内部有一个开关 正常情况为开 当通过的请求失败次数达到预设值时 开关关闭 等待一段时间后 开关半开 尝试发送一个请求 看是否正常执行 若正常执行 则开关开放 若失败 则继续关闭 继续等待一段时间

远程调用

openfeign

用于微服务之间相互调用 可以设置兜底回调 当请求发送失败或者超时时 默认执行兜底回调的方法 返回默认数据

分布式事务
seata

seata分为TC TM RM三个部分 RM管理事务资源 TM管理全局事务 负责开启提交回滚事务 TC负责维护各个服务中的事务状态 协助TM

模式

XA

RM注册各分支事务 此时若分支执行成功 暂不提交 将事务状态提交给TC 当TC收到所有事务的成功状态时 通知所有RM提交事务 若出现一个失败分支 则通知所有RM回滚事务

AT

RM注册各分支事务 提交事务后 记录数据库更新前后快照 将执行结果发给TC 若所有事务均成功完成 TC通知RM将快照删除 若出现失败 则通知RM根据快照回滚

TCC

xxljob

路由策略

轮询

故障转移依次询问所有实例 获取健康心跳 使用第一个获取到的健康实例

分片广播 当大量事件需要执行时 xxljob集群通过取模等方式 将事件分配给不同单机去执行

相关文章:

  • 在 STM32 中实现电机测速的方法介绍
  • 职责分配矩阵(RAM)详解
  • GPU显存不足?分布式训练如何让单卡变百卡:PyTorch实战与弹性算力启示
  • 014_多线程
  • 2、文件上传漏洞的防范
  • 12、nRF52XX蓝牙学习(GPIOTE任务触发LED)
  • Python爬虫第11节-解析库Beautiful Soup的使用上篇
  • 安装NVIDIA驱动、配置docker运行时、docker部署GPUStack及ragflow集成GPUStack模型(WSL下ubuntu)
  • uniapp微信小程序基于wu-input二次封装TInput组件(支持点击下拉选择、支持整数、电话、小数、身份证、小数点位数控制功能)
  • iframe学习与应用场景指南
  • 【技术白皮书】外功心法 | 第四部分 | 数据结构与算法基础(常用的数据结构)
  • MySQL之事务理论和案例
  • SQLyog使用教程
  • ASP.NET中将 PasswordHasher 使用的 PBKDF2 算法替换为更现代的 Scrypt 或 Argon2 算法
  • 语音外呼提高CPS转化案例
  • 【教程】优化xrdp的性能
  • 数字内容体验构建品牌忠诚新路径
  • Open GL ES-> 工厂设计模式包装 SurfaceView + 自定义EGL的OpenGL ES 渲染框架
  • AI大模型学习七:‌小米8闲置,直接安装ubuntu,并安装VNC远程连接手机,使劲造
  • selenium元素获取
  • 网站建设需求调研/免费发帖平台
  • wordpress 显示页面标题/搜索引擎优化方法
  • 网站建设中 什么意思/seo专员是干什么的
  • 做网站申请域名空间/聚合广告联盟
  • 阜阳网站建设公司/哪里可以学企业管理培训
  • 政府网站 建设管理自查报告/网页设计期末作业模板