面试总结之微服务篇

news2025/1/6 20:09:56

一、概览

1、微服务常用组件

  • 微服务给系统开发带来了诸多问题和挑战,如服务间通信和调用的复杂性、数据一致性和事务管理、服务治理和版本管理等,为解决应对这些问题和挑战,各种微服务组件应运而生
  • 微服务的常见组件和实现:
    -
    在这里插入图片描述

1)注册中心:用于服务的注册和发现,管理微服务的地址信息,常见实现有:

  • SpringCloud Netflix:Eureka、Consul
  • SpringCloud Alibaba:Nacos
    2)配置中心:用于集中管理微服务的配置信息,可动态修改配置而不需要重启服务,常见的实现有:
  • SpringCloud Netflix:SpringCloud Config
  • SpringCloud Alibaba:Nacos Config
    3)远程调用:用于在不同的微服务之间进行通信和协作,常见的实现有:
  • RESTful API:RestTemplate、OpenFeign、Feign
  • RPC(远程过程调用):Dubbo、gRPC
    4)API网关:作为微服务架构的入口,统一暴露服务,并提高路由、负载均衡、安全认证等功能,常见的实现有:
  • Spring Cloud Netflix:Zuul、Gateway
  • Spring Cloud Alibaba:Gateway、Apisix等
    5)分布式事务:保证跨多个微服务的一致性和原子性操作,常见的实现有 Spring Cloud Alibaba的Seata
    6)熔断器:用于防止微服务之间的故障扩散,提高系统的容错能力,常见的实现有:
  • Spring Cloud Netflix:Hystrix
  • Spring Cloud Alibaba:Sentinel、Resilience4j
    7)限流和降级:用于防止微服务过载,对请求进行限制和降级处理,常见的实现有:
  • Spring Cloud Netflix:Hystrix
  • Spring Cloud Alibaba:Sentinel
    8)分布式追踪和监控:用于跟踪和监控微服务的请求流程和性能指标,常见的实现有:
  • Spring Cloud Netflix:Spring Cloud Sleuth + Zipkin
  • Spring Cloud Alibaba:SkyWalking、Sentinel Dashboard

二、注册中心

1、注册中心的作用

  • 注册中心是用来管理和维护分布式系统中各个服务的地址和元数据的组件,主要用于实现服务的发现和注册功能
    在这里插入图片描述
    注册中心的作用:
  • 服务注册:各个服务在启动时向注册中心注册自己的网络地址、服务实例信息和其他相关的元数据,如此,其他服务就可以通过注册中心获取到当前可用的服务列表
  • 服务发现:客户端通过向注册中心查询特定服务的注册信息,获得可用的服务实例列表,如此客户端即可根据需要选择合适的服务进行调用,实现了服务间的解耦
  • 负载均衡:注册中心可以对同一服务的多个实例进行负载均衡,将请求分发到不同的实例上,提高整体的系统性能和可用性
  • 故障恢复:注册中心能够监测和检测服务的状态,当服务实例发生故障或下线时,可以及时地更新注册信息,从而保证服务能够正常工作
  • 服务治理:通过注册中心可以进行服务的配置管理、动态扩容/ 缩容,服务路由、灰度发布等操作,实现对服务的动态管理和控制

2、注册中心的实现方案

SpringCloud可以和多种注册中心进行集成,常见的注册中心有Eureka、Consul、Zookeeper、Nacos

  • Eureka:Netflix开源的服务发现组件,具有高可用、弹性、可扩展等特点,与Spring Cloud集成良好
  • Consul:分布式服务发现和配置管理系统,提供了服务的注册和发现、健康检查、键值存储等功能,并支持多数据源中心部署
  • Nacos:阿里开源的动态服务发现、配置管理和服务管理组件,提供了服务注册和发现、配置管理、动态DNS服务等功能
  • Zookeeper:Apache开源的分布式协调服务,可用作服务注册中心,具有高可用、一致性、可靠性等特点

3、Eureka、Zookeeper和Nacos的区别

在这里插入图片描述
三者最大的区别在于Eureka支持AP,Zookeeper支持CP,而Nacos既支持AP,也支持CP

4、Eureka实现原理

在这里插入图片描述
Eureka的实现原理,大致可以从服务的注册与发现、服务的健康检查、服务负载均衡三个三面来看:

  • 1)服务注册与发现:当一个服务实例启动时,会向Eureka Server发送注册请求,将其信息登记到注册中心,Eureka Server会将这些信息保存到内存中,并提供REST接口以供其他服务查询,服务消费者可以通过查询服务实例列表来获取可用的服务提供者实例,从而实现服务的发现
  • 2)服务健康检查:Eureka通过心跳机制来检测服务实例的健康状态,服务实例会定期向Eureka Server发送心跳,即续约,以表明自己的存货状态,如果Eureka Server在一定时间内没有收到某个服务实例的心跳,则会将其标记为不可用,并从服务列表中移除,下线实例
  • 3)服务负载均衡:Eureka客户端在调用其他服务时,会从本地缓存中获取服务的注册信息,如果缓存中没有对应的信息,则会向Eureka Server发送查询请求,Eureka Server会返回一个可用的服务实例列表给客户端,客户端可以使用负载均衡算法选择其中的服务实例进行调用

其他的注册中心,如Nacos、Consul等,在服务注册和发现上,实现原理都大同小异

5、Eureka如何保证高可用

  • Eureka Server保证高可用,主要通过如下三个方面来实现:
    在这里插入图片描述1)多实例部署:将多个Eureka Server实例部署在不同的节点上,实现其高可用性,当其中某个实例发生故障时,其他实例仍然可以提供服务,并保存注册信息的一致性
    2)服务注册信息的复制:当一个服务实例向Eureka Server注册时,每个Eureka Server实例都会复制其他实例的注册信息,以保证数据的一致性,当某个Eureka Server实例发生故障时,其他实例可以接管其工作,保证整个系统的正常运行
    3)自我保护机制当Eureka Server节点在一定时间内没有接收到心跳时,会进入自我保护模式,即Eureka不再剔除注册列表中的服务实例,以保护现有服务实例的注册信息,如此,可以防止由于网路抖动或其他原因导致的误删除

三、配置中心

1、微服务为什么需要配置中心

微服务架构中的每个服务通常都需要一些配置信息,如数据库连接地址、服务端口、日志级别等,这些配置可能因为不同环境、不同部署实例或动态运行时需要进行调整和管理
微服务的实例一般较多,如果每个都逐个去配置,就会造成较大的运维成本,因此,就需要集中化地管理这些配置

2、Nacos配置中心的原理

  • 配置中心需要完成配置信息的增删改查
    在这里插入图片描述

  • Nacos作为配置中心,其具体的实现大概可以分为如下几个部分:
    1)配置信息存储:Nacos默认使用内嵌数据库 Derby来存储配置信息(也可以采用MySQL等关系型数据库)
    2)注册配置信息:服务启动时,Nacos Client会向Nacos Server注册自己的配置信息(即将配置信息写入存储,并生成版本号
    3)获取配置信息:服务运行期间,Nacos Client通过API从Nacos Server获取配置信息,Server根据键查找对应的配置信息,并返回给client
    4)监听配置变化:Nacos Client可以通过注册监听器的方式,实现对配置信息的监听,当配置信息发生变化时,Nacos Server会通知已注册的监听器,并触发相应的回调方法

3、Nacos配置中心长轮询机制

  • 一般来说,客户端和服务端的交互分为两种:推(Push)和 拉(Pull),Nacos在Pull的基础上,采用了长轮询来进行配置的动态刷新
  • 在长轮询模式下,客户端定时向服务端发起请求,检查配置信息是否发生变更,如果没有变更,服务端会hold住该请求,即暂时不返回结果,直到配置发生变化或达到一定的超时时间 ==> 通过长轮询的方式,Nacos客户端能够实时感知配置的变化,并及时获取最新的配置信息,同时,此种方式也降低了服务端的压力,避免了大量的长连接占用内存资源

    具体的实现过程如下:
    1)客户端发起Pull请求,服务端检查配置是否有变更,如果没有变更,则设置定时任务,在一段时间后执行,并将当前的客户端连接加入到等待队列中
    2)在等待期间,如果配置发生变化,服务端会立即返回结果给客户端,完成一次"推送"操作
    3)如果在等待期间没有配置变更,等到时间达到预设的超时时间后,服务端会自动返回结果给客户端
    4)如果在等待期间,通过Nacos Dashboard或API对配置进行了修改,会触发事件机制,服务端会遍历等待队列,找到发生变更的配置项对应的客户端连接,并将变更的数据通过连接返回,完成一次"推送"操作

四、远程调用

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

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

相关文章

解决react报错“JSX 表达式必须具有一个父元素“

现象如下&#xff1a; 原因&#xff1a; 新插入的dom元素跟已有的dom元素平级了&#xff0c;必须创建一个共有的根元素 解决办法&#xff1a; 使用<> </>标签作为根元素&#xff0c;把所有子元素包裹起来 <> ....原代码 </> 问题解决&#xff01;…

sun.reflect.annotation.TypeNotPresentExceptionProxy

解决方法 找到TypeNotPresentExceptionProxy类,在sun.reflect.annotation下在TypeNotPresentExceptionProxy方法里打断点debug项目,查看断点错误 如图是缺少redis依赖导致的错误 https://www.cnblogs.com/qingmuchuanqi48/p/11716706.html

Spring学习笔记7 Bean的生命周期

Spring其实就是一个管理Bean对象的工厂.它负责对象的创建,对象的销毁. 这样我们才可以知道在哪个时间节点上调用了哪个类的哪个方法,知道代码该写在哪里 Bean的生命周期之粗略5步 Bean生命周期的管理可以参考Spring的源码: AbstractAutowireCapableBeanFactory Bean的生命周期…

乐得瑞推出1拖2功率分配快充线方案,支持数据传输

随着PD3.1协议的市场应用越来越多&#xff0c;一些充电器的Type-C接口的输出功率达到百瓦及以上&#xff0c;如何充分利用好这类充电器设备&#xff0c;乐得瑞电子推出1拖2快充线缆解决方案&#xff0c;支持智能功率分配策略。 上图是乐得瑞1拖2功率分配快充线样线实物&#…

力扣刷题-链表-设计链表

题意&#xff1a; 在链表类中实现这些功能&#xff1a; get(index)&#xff1a;获取链表中第 index 个节点的值。如果索引无效&#xff0c;则返回-1。 addAtHead(val)&#xff1a;在链表的第一个元素之前添加一个值为 val 的节点。插入后&#xff0c;新节点将成为链表的第一个节…

哈希 -- 开散列(哈希桶)

拉链法 这里我们要是用string&#xff08;string来做key&#xff09;来取模&#xff0c;再增加一个模板参数&#xff0c;配一个取模的仿函数即可

leetcode 133. 克隆图

leetcode 133. 克隆图 给你无向 连通 图中一个节点的引用&#xff0c;请你返回该图的 深拷贝&#xff08;克隆&#xff09;。 图中的每个节点都包含它的值 val&#xff08;int&#xff09; 和其邻居的列表&#xff08;list[Node]&#xff09;。 class Node { public int val;…

Flex布局是什么?

一、Flex布局是什么&#xff1f; Flex是Flexible Box的缩写&#xff0c;意为”弹性布局”&#xff0c;用来为盒状模型提供最大的灵活性。 注意&#xff0c;设为Flex布局以后&#xff0c;子元素的float、clear和vertical-align属性将失效。 二、基本概念 采用Flex布局的元素…

基于JavaWeb(Servlet+jsp)的个人通讯录管理系统(含实验报告)

基于JavaWeb&#xff08;Servletjsp&#xff09;的个人通讯录管理系统&#xff08;含实验报告&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 本项目为简单的基于Javaweb实现的个人通讯录管理系统&#xff0c;实现主要功能为用户注册登录、首页展示、用户联…

C++——如何正确的使用STL中的vector?

什么是vector&#xff1f; 在STL&#xff08;标准模板库&#xff09;中&#xff0c;vector是一种动态数组容器&#xff0c;可根据需要自动增长或缩小。它可以存储任意类型的元素&#xff0c;并且支持快速的随机访问。 vector是表示可变大小数组的序列容器vector采用的是连续的…

Java面试题整理(带答案)

目录 TCP和UDP的区别 get和post的区别 Cookie和session的区别 Java的基本类型有哪些&#xff1f; 抽象类和接口区别&#xff1f; 对于堆栈的理解 和equals区别 如何理解Java多态&#xff1f; 创建线程都有哪些方式 脏读、不可重复度、幻读都是什么&#xff1f; Jav…

YUM 升级 PHP7

文章目录 YUM 升级 PHP71. 查看当前 PHP 信息2. YUM 安装 PHP73. 查看 PHP 版本4. 启动PHP-FPM YUM 升级 PHP7 参考地址&#xff1a;网站地址 参考地址&#xff1a;网站地址 1. 查看当前 PHP 信息 # 查看 PHP 版本信息 php -v# 查看 yum 源中 PHP 信息 yum list | grep php2. …

最美壁纸小程序源码全新修复版 带激励广告

最美壁纸小程序源码全新修复版&#xff0c;带激励广告&#xff0c;刚刚修复的&#xff0c;程序包里有安全域名与广告id配置说明&#xff0c;这个源码无PHP后台发布后添加合法域名就可以了。 源码下载&#xff1a;https://download.csdn.net/download/m0_66047725/88368720

【vscode设置ctrl+滑轮调节代码字体大小】

vscode设置ctrl滑轮调节代码字体大小 打开设置之后在搜索框中输入"editor.mouseWheelZoom": true&#xff0c;勾选上对勾就OK了&#xff01; “editor.mouseWheelZoom”: true

左神高阶进阶班4 (尼姆博弈问题、k伪进制、递归到动态规划、优先级结合的递归套路、子串的递归套路,子序列的递归套路,动态规划的压缩技巧)

目录 【案例1 尼姆博弈问题】 【题目描述】 【思路解析】 【代码实现】 【案例2 k伪进制问题】 【题目描述】 【思路解析】 【代码实现】 【案例3 最大路径和】 【题目描述】 【思路解析】 【代码实现】 【案例4 优先级的递归套路】 【题目描述】 【思路解析】…

【Vue】ElementUI实现登录注册+axios全局配置+CORS跨域

目录 一、搭建项目 1.1 安装 Element-UI 1.2 导入组件 1.3 创建登录、注册界面 二、后台交互 2.1 引入axios 2.2 添加vue-axios的全局配置 2.2 ssm项目准备 (后端) 2.2.1 准备数据表 2.2.2 导入ssm项目 2.2.3 编写控制器 2.3 前端编写 2.4 登入测试 2.5 注册测试…

亚马逊云科技携手西门子运用生成式AI之力,打破数据孤岛

2023年&#xff0c;以基于GPT模型对话应用为代表的生成式AI浪潮席卷全球&#xff0c;引起企业广泛关注。自此&#xff0c;由生成式AI引导的企业变革序幕全面展开&#xff0c;企业向数智化转型迈出了坚实的一步。 西门子股份公司&#xff08;以下简称“西门子”&#xff09;是一…

《C++ primer》练习6.54-6.56:函数指针定义并调用

《C primer》里面讲到函数指针定义并调用&#xff0c;做一下练习6.54-6.56&#xff0c;题目如下&#xff1a; vector元素的类型是函数指针的类型是int (*)(int, int)&#xff0c;指向的元素是有两个int形参&#xff0c;返回类型也是int的函数。 #include <vector> #incl…

如何利用人才测评系统提升企业招聘效率

公司需要的是能产出价值的员工&#xff0c;但是要想找到完全符合条件的员工&#xff0c;其实并不容易&#xff0c;尽管应聘的人数很多&#xff0c;但不是跳槽的&#xff0c;就是转行的&#xff0c;要么就只能从应届生培养开始了。 从招聘流程上&#xff0c;以现在的模式&…

使用 PyTorch 的计算机视觉简介 (6/6)

一、说明 本文主要介绍CNN中在pytorch的实现&#xff0c;其中MobileNet 网络&#xff0c;数据集来源&#xff0c;以及训练过程&#xff0c;模型生成和存储&#xff0c;模型调入等。 二、轻量级网络和移动网络 我们已经看到&#xff0c;复杂的网络需要大量的计算资源&#xff0c…