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协议,强一致。

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

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

相关文章

基于Spring Boot的校园疫情防控系统设计与实现

基于Spring Boot的校园疫情防控系统设计与实现 开发语言:Java框架:springbootJDK版本:JDK1.8数据库工具:Navicat11开发软件:eclipse/myeclipse/idea 系统部分展示 管理员登录首页界面图,管理员进入校园疫…

Android --- 消息机制与异步任务

在Android中,只有在UIThread(主线程)中才能直接更新界面, 在Android中,长时间的工作联网都需要在workThread(分线程)中执行 在分线程中获取服务器数据后,需要立即到主线程中去更新UI来显示数据, 所以,如…

手撕spring框架(2)

相关系列 java中spring底层核心原理解析(1)-CSDN博客 java中spring底层核心原理解析(2)-CSDN博客 手撕spring框架(1)-CSDN博客 手撕spring框架(3)-CSDN博客 手撕spring框架(4)-CSDN博…

用龙梦迷你电脑福珑2.0做web服务器

用龙梦迷你电脑福珑2.0上做web服务器是可行的。已将一个网站源码放到该电脑,在局域网里可以访问网站网页。另外通过在同一局域网内的一台windows10电脑上安装花生壳软件,也可以在外网访问该内网服务器网站网页。该电脑的操作系统属于LAMP。在该电脑上安装…

Qt Creator导入第三方so库和jar包——Qt For Android

前言 之前了解了在Android Studio下导入so库和jar包,现在实现如何在Qt上导入so库和jar包。 实现 下面是我安卓开发(需调用安卓接口的代码)的目录(图1),此目录结构和原生态环境(Android Studi…

详细分析Java中的脱敏注解(附Demo)

目录 前言1. 基本知识2. 核心逻辑3. Demo4. 模版 前言 对于隐私信息,需要做特殊处理,比如身份证或者手机号等 对于Java的相关知识推荐阅读:java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全) 1. 基本知…

软件定义汽车落地的五大关键要素

1、架构升级 1.1 软件架构:分层解耦、服务化、API 接口标准化 随着企业向软件定义汽车开发方法的转变,软件架构也需要同步进行升级,引入面向服务的架构(Service-Oriented Architecture,简称 SOA)方法论。…

ThreeJS:响应式画布与全屏控制

响应式画布 响应式画布:在用户缩放浏览器窗口时,为便于动态更新画布尺寸与宽高比例,需要通过监听resize事件,来实现响应式画布。 window.onresize function () {//TODO:重置渲染器宽高比renderer.setSize(window.innerWidth, wi…

为人处事电影解说,全新升级瀚海跑道一分钟一条视频,全平台可推广,轻轻松松日入1000

自古以来,我国流行的一种现象是,大多数人都会与领导或上司打交道。由于某些话题不宜公开讨论,因此出现了许多含蓄的表达方式。随着年龄的增长,人们的态度也发生了变化,从最初的轻视到现在的重视。 下 载 地 址&#…

VG做mirror引起的块偏移

事件起因 Oracle10.2环境 Aix操作系统使用aix的lvm技术。制作vg的mirror。以此来替换掉老的存储。 做mirror前,数据库已完全关闭 故障现象 在启动数据库时,发现IO错误。该系统的spfile,ctl,dbf均是用lv做的裸设备。其中dbf是使…

cmake的使用方法: 编译生成库文件

一. 简介 前面文章学习了针对单个 .c文件,cmake 工具是如何编译的? 针对包含多个 .c文件,cmake工具又是如何编译的?文章如下: cmake的使用方法: 单个源文件的编译-CSDN博客 cmake的使用方法: 多个源文件的编译-CS…

Java入门-final关键字

final关键字 修饰基本类型 变量为只读,不能修改变量的内容。 final int SIZE 3;修饰引用类型 引用的对象不能改变,但是对象的内容可以修改。 final Car c new Car( );c.setColor("红色");修饰类的属性 类的属性不能被修改。 第一种方式&…

Linux 进程间通信之命名管道

💓博主CSDN主页:麻辣韭菜💓   ⏩专栏分类:Linux知识分享⏪   🚚代码仓库:Linux代码练习🚚   🌹关注我🫵带你学习更多Linux知识   🔝 目录 前言 命名管道 创建一个命名管道 …

Leetcode—976. 三角形的最大周长【简单】(ranges::sort函数)

2024每日刷题&#xff08;122&#xff09; Leetcode—976. 三角形的最大周长 实现代码 class Solution { public:int largestPerimeter(vector<int>& nums) {ranges::sort(nums);for(int i nums.size() - 1; i > 1; i--) {if(nums[i - 1] nums[i - 2] > nu…

洛谷 P1377 [TJOI2011]:树的序 ← 笛卡尔树

【题目来源】https://www.luogu.com.cn/problem/P1377【题目描述】 众所周知&#xff0c;二叉查找树的形态和键值的插入顺序密切相关。准确的讲&#xff1a; 1.空树中加入一个键值 k&#xff0c;则变为只有一个结点的二叉查找树&#xff0c;此结点的键值即为 k。 2.在非空树中插…

智能物联网与Web3:连接未来数字生活的桥梁

随着科技的不断进步&#xff0c;智能物联网&#xff08;IoT&#xff09;和Web3技术正成为数字化时代的关键驱动力。智能物联网将各种物理设备连接到互联网&#xff0c;使其能够感知环境、收集数据并与其他设备通信&#xff0c;而Web3技术则以去中心化、安全性和透明性为核心&am…

Linux开发板 FTP 服务器移植与搭建

VSFTPD&#xff08;Very Secure FTP Daemon&#xff09;是一个安全、稳定且快速的FTP服务器软件&#xff0c;广泛用于Unix和Linux操作系统。它以其轻量级、高效和易于配置而受到赞誉。VSFTPD不仅支持标准的FTP命令和操作&#xff0c;还提供了额外的安全特性&#xff0c;如匿名F…

Python日志记录库之logbook使用详解

概要 在软件开发和运维中,日志记录是一项至关重要的任务。Python 的 Logbook 库是一个强大而灵活的日志记录工具,提供了丰富的功能和易用的接口。本文将深入探讨 Logbook 库的特性、用法,并通过丰富的示例代码展示其在实际项目中的应用。 Logbook 简介 Logbook 是一个为 P…

本地搭建llama大模型及对话UI

环境说明&#xff1a;MBP 2023 M2Pro芯片 用到的工具/组件/技术&#xff1a;ollama、llama3:8b、docker、open-webui 1.下载ollama ollama官网下载地址&#xff1a;https://ollama.com/download 到ollama官网地址下载对应操作系统版本的ollama平台&#xff0c;按照安装指引…

springboot 获取maven打包时间

springboot 获取maven打包时间 pom <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.13.RELEASE</version><relativePath /> <!-- lookup parent…