JAVA面试专题-微服务篇

Spring cloud

Spring Cloud 5大组件有哪些

注册中心/配置中心:nacos
负载均衡:Ribbon
服务远程调用:Feign
服务保护:sentinel
服务网关:Gateway

微服务注册和发现

 nacos和eureka的区别

 负载均衡

        微服务向Ribbon发送请求,Ribbon从注册中心中拉取相应的微服务,返回微服务列表,最后选择一个微服务进行调用。

Ribbon负载均衡策略

 自定义负载均衡策略

自己创建类实现IRule接口,再通过配置类(全局生效)或者配置文件(局部生效)即可

服务雪崩

服务雪崩:一个服务失败,导致整条链路的服务都失败的情形。

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

服务熔断:默认关闭,需要手动打开,如果检测到十秒内请求失败率超过百分之五十 ,就触发熔断机制,之后每个五秒重新尝试请求微服务,如果不能响应继续走熔断机制,如果微服务可达,则关闭熔断机制,恢复正常请求。

服务监控

采用skywalking进行监控:

1. skywalking主要可以监控接口、服务、物理实例的一些状态,特别是压测的时候可以看到众多服务中哪些服务的接口比较慢,可以针对性的分析和优化。

2. 在skywalking设置告警规则,当项目上线以后,设置给负责人发短信和邮件,第一时间知道bug修复。

业务相关

限流

限流的实现方式:

Tomcat:可以设置最大连接数
Nginx:漏桶算法


网关:令牌桶算法
自定义拦截器

CAP 和 BASE

CAP定理

Consistency:一致性        Availability:可用性        Partition tolerance:分区容错性

这三个指标无法同时满足,就叫做cap定理

BASE理论

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

解决分布式事务的思想和模型:

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

分布式事务解决方案

Seata架构

TC(Transaction Coordinator)-事务协调者:维护全局和分支事务状态,协调全局事务提交或回滚。
TM(Transaction Manager)- 事务管理器:定义全局事务的范围、开始全局事务、提交或回滚全局事务。
RM(Resource Manager)- 资源管理器:管理分支实物处理的资源,与TC交谈以注册分支实物和报告分支事务的状态,并驱动分支事务提交或回滚。

 XA模式:

         TM开启全局事务,调用分支RM,注册分支事务到TC,之后RM执行sql业务但是不提交,向TC报告事务状态。TC检测各分支事务执行状态,如果都成功,则提交,如果有失败则回滚,最后提交事务。

AT模式:

 TM开启全局事务,调用分支RM,向TC注册事务分支,RM执行sql并提交,同时记录更新前后快照undo log,向TC报告实物状态,TM申请提交或者回滚全局事务,TC检查事务分支状态,如果都成功则提交,同时删除undo log,如果有失败,则回顾log数据回滚。

TCC模式:

Try:资源的检测和预留        Confirm:完成资源操作业务        Cancel:预留资源释放

在注册分支事务以后,进行一次资源预留try,报告事务状态,在TC决定提交还是回滚时,如果提价,则confirm,如果回滚则cancel

MQ分布式事务

 

分布式服务接口幂等性

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

如果是新增数据,可以使用数据库唯一索引
如果是新增或者修改数据
        分布式锁,性能较低
        使用token+redis实现,性能较好:第一次请求,生成一个唯一token存入redis返回给前端,第二次请求,携带之前的token,到redis进行验证,如果存在执行业务,删除token,如果不存在,直接返回不处理业务

分布式任务调度

xxl-job路由策略:

大数据量的任务同时都需要执行

执行器集群部署时,任务路由策略选择分片广播,一次任务调度将会广播出发对应急群众所有执行器执行一次任务。

RabbitMQ

RabbitMQ如何保证数据不丢失

 三种情况数据丢失:消息未达到交换机或则消息未到达队列、队列中消息丢失、消费者未接收到消息。

生产者确认机制publisher confirm

消息发送到MQ后,会返回一个结果给发送者,表示消息是否成功。

如果传到给了消费者,就返回ack publish-confirm
如果没有传到MQ中,则返回ack publish-return
如果没传到交换机,则返回 nack publish-confirm

消息失败以后,可以回调方法即使重发,记录日志,或者保存到数据库然后定时重发,成功发送后删除表中数据。

消息持久化

 消费者确认

消息重复消费问题 

解决方案:每条消息设置一个唯一的标识Id

死信交换机

解决延迟队列=死信交换机+TTL(生存时间)

惰性队列

接收消息后存入磁盘而非内存,消费者要消费消息时才会从磁盘中读取并加载到内存,支持数百万条的消息存储。加入lazy()

RabbitMQ高可用

普通集群

会在集群的各个节点共享部分数据,但不包含队列中的消息,访问集群某节点时,如果队列不在该节点,会从数据所在节点传递到当前节点并返回,队列所在节点宕机,队列中的消息就会消失。

镜像集群

本质是主从模式,交换机,队列,队列消息会在各个mq的镜像节点之间同步备份,创建队列的节点被称为主节点,备份到其他节点的叫镜像节点。所有操作都是主节点完成,然后同步给镜像节点,主宕机后,镜像节点取而代之。

仲裁队列

主从模式,支持主从数据同步,基于Raft协议,强一致。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue 之 在当前页面的实现分页效果

目录 场景实现 场景 假设,我们现在有这么一个需求: 上述图片的空白内容是活动的,由下面的两个按钮控制上一页、下一页;我们应该可以怎么去实现? 实现 思路: 其实这个问题,我们仿照其他的UI框…

数字旅游以科技创新为动力:推动旅游服务的智能化、网络化和个性化发展,满足游客日益增长的多元化、个性化需求

目录 一、引言 二、科技创新推动旅游服务智能化发展 1、智能化技术的引入与应用 2、智能化提升旅游服务效率与质量 三、科技创新推动旅游服务网络化发展 1、网络化平台的构建与运营 2、网络化拓宽旅游服务渠道与范围 四、科技创新推动旅游服务个性化发展 1、个性化需求…

Sortable 拖拽行实现el-table表格顺序号完整例子,vue 实现表格拖拽行顺序号完整例子

npm install sortable<template><vxe-modalref"modalRef"v-model"showModal"title"详情"width"70vw"height"60vh"class"his"transfer><el-table ref"tableRef" :data"tableData&q…

mysql从入门到起飞+面试基础题

mysql基础 MySQL基础 企业面试题1 代码 select m.id,m.num from ( select t.id as id,count(1) num from ( select ra.requester_id as id from RequestAccepted raunion all select ra.accepter_id as id from RequestAccepted ra ) t group by t.id ) m group by id ord…

鸿蒙原生应用元服务开发-Web加载本地页面

将本地页面文件放在应用的rawfile目录下&#xff0c;开发者可以在Web组件创建的时候指定默认加载的本地页面 &#xff0c;并且加载完成后可通过调用loadUrl()接口变更当前Web组件的页面。 在下面的示例中展示加载本地页面文件的方法&#xff1a; 将资源文件放置在应用的resou…

HarmaonyOS鸿蒙应用科普课

一、什么是鸿蒙OS&#xff1f; 1.概念&#xff1a; 先给大家讲讲今天讲课的主题&#xff0c;鸿蒙OS是什么&#xff1f;鸿蒙系统大家都知道&#xff0c;就是一个操作系统&#xff0c;我们未来是为的成为鸿蒙程序员。所以我们不要将鸿蒙os完全等同于手机操作系统&#xff0c;太…

C#技巧之同步与异步

区别 首先&#xff0c;同步就是程序从上往下顺序执行&#xff0c;要执行完当前流程&#xff0c;才能往下个流程去。 而异步&#xff0c;则是启动当前流程以后&#xff0c;不需要等待流程完成&#xff0c;立刻就去执行下一个流程。 同步示例 创建一个窗体&#xff0c;往窗体里…

Python_GUI框架 Pyside6的信号与槽应用

Python_GUI框架 Pyside6的信号与槽应用 在Pyside6框架中&#xff0c;信号与槽&#xff08;Signals and Slots&#xff09;机制是连接用户界面元素与响应功能的核心机制。我们可以把信号想象成一根电线&#xff0c;而槽就是电线的另一端连接的灯泡。当电线&#xff08;信号&…

贪心算法 Greedy Algorithm

1) 贪心例子 称之为贪心算法或贪婪算法&#xff0c;核心思想是 将寻找最优解的问题分为若干个步骤 每一步骤都采用贪心原则&#xff0c;选取当前最优解 因为没有考虑所有可能&#xff0c;局部最优的堆叠不一定让最终解最优 v2已经不会更新v3因为v3更新过了 贪心算法是一种在…

第八篇:隔离即力量:Python虚拟环境的终极指南

隔离即力量&#xff1a;Python虚拟环境的终极指南 1 引言 在编程的多元宇宙中&#xff0c;Python语言犹如一颗闪耀的星辰&#xff0c;其魅力不仅仅在于简洁的语法&#xff0c;更在于其庞大而繁荣的生态系统。然而&#xff0c;随着应用的增长和复杂性的提升&#xff0c;开发者们…

WinRAR经典压缩神器,高效管理您的文件烈火汉化版 v7.0.

01 软件介绍 WinRAR&#xff0c;作为一款历史悠久且广为人知的压缩文件管理工具&#xff0c;已经成为压缩软件行业的标杆产品。其提供的完整支持覆盖了RAR和ZIP文件格式&#xff0c;同时&#xff0c;该软件还拥有诸多强大的解压缩功能&#xff0c;包括但不限于固体压缩、分卷压…

链表面试题2

1&#xff0c;合并两个有序链表 我们先定义一个虚拟节点newH&#xff0c; 然后按照上图所走&#xff0c;但是当其中一个链表走空时&#xff0c;我们只需返回另一个链表即可 class Solution {public ListNode mergeTwoLists(ListNode headA, ListNode headB) {ListNode newhead…

【C++】滑动窗口:长度最小的子数组

1.题目 2.算法分析 这种题目&#xff0c;首先想到的是暴力穷举法&#xff1a; 用两层循环取遍该数组的所有子数组&#xff0c;然后找到那个最短的就可以了。 我们的滑动窗口就是对这种暴力穷举法进行优化&#xff1a; 主要是舍弃的思想&#xff0c;舍弃那些一定不可能是最终…

03_电子设计教程基础篇(软件推荐)

文章目录 前言一、通用工具软件1.输入法2.截图3.录屏4.桌面管理5.文件检索6.笔记整理7.翻译软件8.AI软件9.文件对比10.思维导图、流程框图、表格软件11.项目托管平台12.解压缩软件13.休闲娱乐软件 二、专业工具软件1.硬件工程师1.原理图、PCB设计2.原理图、PCB仿真3.PCB下单软件…

DNS、ICMP、NAT以及代理服务器

目录 1. DNS 1.1. DNS 背景 1.2. 域名简介 1.3. 域名解析过程 2. ICMP 2.1. ICMP 的功能 2.2. ICMP 的报文格式 2.3. ping 命令 2.4. traceroute 命令 3. NAT和代理服务器 3.1. NAT 技术 3.2. NAT IP转换过程 3.3. NAT 技术的缺陷 3.4. 代理服务器 3.4.1. 正向…

界面组件DevExpress Blazor UI v23.2 - 网格、工具栏功能全新升级

DevExpress Blazor UI组件使用了C#为Blazor Server和Blazor WebAssembly创建高影响力的用户体验&#xff0c;这个UI自建库提供了一套全面的原生Blazor UI组件&#xff08;包括Pivot Grid、调度程序、图表、数据编辑器和报表等&#xff09;。 DevExpress Blazor控件目前已经升级…

通信接口——时钟和信号

前言 所有接口只要抓住三个核心点就能分清&#xff1a;时钟同步和异步&#xff0c;时钟的来源&#xff0c;信号的传输方向。 一、时钟同步和异步 接口之间的交互方式存在多种形式&#xff0c;如果按照是否有公共时钟CLK的参与&#xff0c;可以分为同步传输和异步传输。 同步&…

【Gateway】网关集成Knife4j—swagger接口文档

文章目录 前言一、相关配置1.网关gateway配置①.网关增加配置 pom文件②.网关增加配置 SwaggerHandler③.网关增加配置 SwaggerResourceConfig④.网关增加配置 SwaggerConfig 2.网关过滤器 二、接口文档使用1.访问文档2.查看文档 总结 前言 在日常开发中是需要前后端联调的&am…

Liunx磁盘管理(上)

Liunx磁盘管理&#xff08;中&#xff09;-CSDN博客 目录 一.硬盘类型 机械硬盘&#xff08;HDD&#xff09; 固态硬盘&#xff08;SSD&#xff09; 二.插拔方式 1. 热插拔&#xff08;Hot Swapping&#xff09; 2. 冷插拔&#xff08;Cold Swapping&#xff09; 3. 模块…

C++仿函数周边及包装器

我最近开了几个专栏&#xff0c;诚信互三&#xff01; > |||《算法专栏》&#xff1a;&#xff1a;刷题教程来自网站《代码随想录》。||| > |||《C专栏》&#xff1a;&#xff1a;记录我学习C的经历&#xff0c;看完你一定会有收获。||| > |||《Linux专栏》&#xff1…