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

持续总结中!2024年面试必问 20 道分布式、微服务面试题(七)

上一篇地址:持续总结中!2024年面试必问 20 道分布式、微服务面试题(六)-CSDN博客

十三、请解释什么是服务网格(Service Mesh)?

服务网格(Service Mesh)是一种用于处理服务间通信的基础设施层。它提供了一种将服务间通信控制和安全性从业务逻辑中解耦出来的方法,使得微服务架构中的服务能够更加专注于它们的核心功能。

服务网格的关键概念:

  1. 微服务间通信

    • 服务网格专门处理微服务之间的网络通信,包括请求的路由、负载均衡、故障恢复等。
  2. 控制平面(Control Plane)

    • 控制平面负责配置和管理服务网格的行为,如服务发现、路由规则、安全策略等。
  3. 数据平面(Data Plane)

    • 数据平面由部署在每个服务实例旁边的代理(通常是Sidecar模式)组成,负责实际的网络流量处理。
  4. Sidecar模式

    • 服务网格中的代理通常以Sidecar模式部署,与服务实例运行在同一网络命名空间内,但作为独立的进程或容器。
  5. 流量管理

    • 服务网格提供了流量管理功能,如重试、超时、断路器等。
  6. 服务发现

    • 服务网格包括服务发现机制,允许服务实例相互识别和通信。
  7. 安全

    • 服务网格实现了服务间的安全通信,包括加密、认证和授权。
  8. 可观察性

    • 服务网格提供了监控和日志记录功能,帮助开发者和运维人员了解服务间的通信情况。

服务网格的工作原理:

  1. 服务实例注册

    • 每个服务实例在启动时向控制平面注册自己,控制平面维护一个服务注册表。
  2. 流量拦截

    • Sidecar代理拦截服务实例的所有出站和入站流量,然后根据控制平面的配置规则处理这些流量。
  3. 服务发现和负载均衡

    • 代理使用控制平面提供的信息来发现服务,并实现负载均衡。
  4. 安全通信

    • 代理负责在服务间建立安全的通信通道,如使用mTLS(双向TLS)进行加密。
  5. 流量控制

    • 代理根据控制平面的策略执行流量控制,如重试、超时、断路等。
  6. 监控和日志

    • 代理收集服务间的通信数据,并将其发送到监控和日志系统。

常见的服务网格技术:

  1. Istio

    • 由Google、IBM和Lyft共同开发的开源服务网格,提供了流量管理、安全、可观察性等功能。
  2. Linkerd

    • CNCF(Cloud Native Computing Foundation)的孵化项目,是一个轻量级、安全且易于使用的服务网格。
  3. Consul

    • HashiCorp开发的服务网格,提供了服务发现、配置和安全通信。
  4. AWS App Mesh

    • 亚马逊云服务提供的服务网格,用于微服务架构的应用程序。
  5. Kuma

    • 开源的服务网格,提供了灵活的配置和多运行时支持。

服务网格为微服务架构带来了许多好处,包括简化的服务间通信、增强的安全性、改进的可观察性以及更好的流量控制。然而,它也引入了额外的复杂性,需要对控制平面和数据平面进行适当的配置和管理。

十四、什么是容器化,它在微服务中扮演什么角色?

容器化是一种轻量级、可移植的、自给自足的软件打包技术,它允许开发者将应用及其依赖项打包到一个隔离的容器中。容器与底层基础设施和运行环境无关,可以在任何支持容器技术的平台上运行,从而实现应用的快速部署、扩展和管理。

容器化的关键概念:

  1. 容器(Container)

    • 容器是一个轻量级、可执行的软件包,包含应用的所有依赖项,但不包含操作系统。
  2. 镜像(Image)

    • 容器镜像是一个只读模板,包含了运行容器所需的所有内容:代码、运行时、库、环境变量和配置文件。
  3. 容器引擎(Container Engine)

    • 容器引擎是一个软件,负责运行容器、构建容器镜像和管理容器的生命周期。
  4. 容器编排(Container Orchestration)

    • 容器编排工具帮助管理大规模容器部署,提供服务发现、负载均衡、扩展和自我修复等功能。
  5. 隔离性(Isolation)

    • 容器提供了操作系统级别的隔离,每个容器有自己的文件系统、网络接口和进程空间。
  6. 可移植性(Portability)

    • 容器可以在不同的环境和平台上无缝迁移和运行,包括开发、测试和生产环境。
  7. 轻量级(Lightweight)

    • 容器共享宿主机的内核,不需要像虚拟机那样模拟整个操作系统,因此启动速度快,资源占用小。

容器化在微服务中的角色:

  1. 环境一致性

    • 容器化确保了微服务在不同环境(开发、测试、生产)中具有一致的运行环境,减少了“在我机器上可以运行”的问题。
  2. 快速部署

    • 容器可以快速启动和停止,使得微服务的部署和扩展更加迅速。
  3. 服务隔离

    • 容器提供了服务之间的隔离,确保一个服务的问题不会影响其他服务。
  4. 依赖管理

    • 容器镜像包含了微服务的所有依赖项,简化了依赖管理。
  5. 持续集成和持续部署(CI/CD)

    • 容器化与CI/CD流程无缝集成,使得自动化测试、构建和部署更加容易。
  6. 资源利用率

    • 容器化提高了资源的利用率,可以在单个宿主机上运行多个微服务容器。
  7. 可扩展性

    • 容器化使得微服务可以水平扩展,根据负载动态增加或减少实例数量。
  8. 故障隔离

    • 容器化提供了更好的故障隔离,一个容器的故障不会导致整个系统的崩溃。
  9. 安全性

    • 容器可以运行在受限模式下,降低安全风险。
  10. 多语言和多平台支持

    • 容器化支持多种编程语言和框架,可以在不同的操作系统平台上运行。

容器化技术,如Docker,已经成为微服务架构的基石之一。它为微服务提供了一种高效、灵活和可移植的部署方式,简化了开发、测试和运维的复杂性。同时,容器编排工具,如Kubernetes,进一步扩展了容器化的优势,使得大规模微服务部署和管理成为可能。

相关文章:

持续总结中!2024年面试必问 20 道分布式、微服务面试题(七)

上一篇地址:持续总结中!2024年面试必问 20 道分布式、微服务面试题(六)-CSDN博客 十三、请解释什么是服务网格(Service Mesh)? 服务网格(Service Mesh)是一种用于处理服…...

AJAX 跨域

这里写目录标题 同源策略JSONPJSONP 是怎么工作的JSONP 的使用原生JSONP实践CORS 同源策略 同源: 协议、域名、端口号 必须完全相同、 当然网页的URL和AJAX请求的目标资源的URL两者之间的协议、域名、端口号必须完全相同。 AJAX是默认遵循同源策略的,不…...

3 数据类型、运算符与表达式-3.1 C语言的数据类型和3.2 常量与变量

数据类型 基本类型 整型字符型实型(浮点型) 单精度型双精度型 枚举类型 构造类型 数组类型结构体类型共用体类型 指针类型空类型 #include <stdio.h> #include <string.h> #include <stdbool.h> // 包含布尔类型定义 // 常量和符号常量 #define PRICE 30//…...

NSSCTF-Web题目5

目录 [SWPUCTF 2021 新生赛]error 1、题目 2、知识点 3、思路 [LitCTF 2023]作业管理系统 1、题目 2、知识点 3、思路 [HUBUCTF 2022 新生赛]checkin 1、题目 2、知识点 3、思路 [SWPUCTF 2021 新生赛]error 1、题目 2、知识点 数据库注入、报错注入 3、思路 首先…...

cnvd_2015_07557-redis未授权访问rce漏洞复现-vulfocus复现

1.复现环境与工具 环境是在vulfocus上面 工具&#xff1a;GitHub - vulhub/redis-rogue-getshell: redis 4.x/5.x master/slave getshell module 参考攻击使用方式与原理&#xff1a;https://vulhub.org/#/environments/redis/4-unacc/ 2.复现 需要一个外网的服务器做&…...

免费,C++蓝桥杯等级考试真题--第7级(含答案解析和代码)

C蓝桥杯等级考试真题--第7级 答案&#xff1a;D 解析&#xff1a;步骤如下&#xff1a; 首先&#xff0c;--a 操作会使 a 的值减1&#xff0c;因此 a 变为 3。判断 a > b 即 3 > 3&#xff0c;此时表达式为假&#xff0c;因为 --a 后 a 并不大于 b。因此&#xff0c;程…...

python为什么要字符串格式化

Python2.6 开始&#xff0c;新增了一种格式化字符串的函数 str.format()&#xff0c;它增强了字符串格式化的功能。相对于老版的%格式方法&#xff0c;它有很多优点。 1.在%方法中%s只能替代字符串类型&#xff0c;而在format中不需要理会数据类型&#xff1b; 2.单个参数可以…...

go语言后端开发学习(三)——基于validator包实现接口校验

前言 在我们开发模块的时候,有一个问题是我们必须要去考虑的&#xff0c;它就是如何进行入参校验&#xff0c;在gin框架的博客中我就介绍过一些常见的参数校验&#xff0c;大家可以参考gin框架学习笔记(四) ——参数绑定与参数验证&#xff0c;而这个其实也不是能够完全应对我…...

系统架构设计师【补充知识】: 应用数学 (核心总结)

一、 图论之最小生成树 (1)定义: 在连通的带权图的所有生成树中&#xff0c;权值和最小的那棵生成树(包含图中所有顶点的树)&#xff0c;称作最小生成树。 (2)针对问题: 带权图的最短路径问题。 (3)最小生成树的解法有普里姆(Prim)算法和克鲁斯卡尔(Kruskal)算法&#xff0c;我…...

【ArcGIS微课1000例】0118:一文讲清楚tif(geotiff)栅格数据格式

文章目录 一、Tiff概述二、GeoTiff概述1. ovr文件2. tfw文件3. xml文件4. dbf文件一、Tiff概述 TIFF(Tagged Image File Format)是一种常见的图像文件格式,它被广泛用于存储和传输各种类型的图像数据。下面是对TIFF格式数据的介绍: 图像存储:TIFF格式可以存储多通道的位…...

调用第三方API --------------Python篇

在项目开发过程中&#xff0c;可能需要调用第三方的一些API或者公司提供的数据接口来得到相应的数据或者实现对应的功能。 因此API的调用和数据接口的访问都是做数据分析的一个常用操作&#xff0c;如何快速实现API和数据接口的调用&#xff0c;网上一般提供很多语言版本&#…...

Web自动化测试-掌握selenium工具用法,使用WebDriver测试Chrome/FireFox网页(Java

目录 一、在Eclipse中构建Maven项目 1.全局配置Maven 2.配置JDK路径 3.创建Maven项目 4.引入selenium-java依赖 二、Chrome自动化脚本编写 1.创建一个ChromeTest类 2.测试ChromeDriver 3.下载chromedriver驱动 4.在脚本中通过System.setProperty方法指定chromedriver的…...

maven多模块项目搭建

文章目录 创建方式创建父项目创建子模块 目录结构示例父模块模块A模块B&#xff08;并在模块B中引入模块A&#xff09; 注意事项 创建方式 创建父项目 #创建文件夹后&#xff0c;进入目录&#xff0c;执行以下命令 PS D:\demo> mvn archetype:generate #将输出很多模板&am…...

PostgreSQL的视图pg_tables

PostgreSQL的视图pg_tables pg_tables 是 PostgreSQL 中的一个系统视图&#xff0c;用于显示当前数据库中所有用户定义的表的信息。这个视图提供了关于表的名称、所属模式&#xff08;schema&#xff09;、所有者以及表类型等详细信息。 pg_tables 视图的主要列 列名类型描述…...

Stable diffusion采样器详解

在我们使用SD web UI的过程中&#xff0c;有很多采样器可以选择&#xff0c;那么什么是采样器&#xff1f;它们是如何工作的&#xff1f;它们之间有什么区别&#xff1f;你应该使用哪一个&#xff1f;这篇文章将会给你想要的答案。 什么是采样&#xff1f; Stable Diffusion模…...

为什么要进行渗透测试?

渗透测试的重要性 渗透测试是一种安全评估技术&#xff0c;旨在模拟黑客攻击&#xff0c;发现和利用系统漏洞&#xff0c;以评估企业信息系统的安全性。以下是进行渗透测试的几个主要原因&#xff1a; 1.发现潜在的漏洞和安全风险&#xff1a;渗透测试可以模拟真实的攻击行为…...

后方碰撞预警系统技术规范(简化版)

后方碰撞预警系统技术规范(简化版) 1 系统概述2 预警区域3 预警目标4 功能需求功能条件5 显示需求6 指标需求1 系统概述 后方碰撞预警系统RCW(Rear Collision Warning)是在后方车辆即将与自车发生碰撞之前,激活危险警告灯以较高频率闪烁,从而吸引后方驾驶员的注意力,避免…...

Position定位

Position定位 CSS中position属性是比较常用的元素定位方案&#xff0c;position常用的取值有static、relative、absolute、fixed、sticky、inherit。 static static属性是HTML元素的默认值&#xff0c;即没有定位&#xff0c;遵循正常的文档流对象&#xff0c;对于top、bott…...

npm install 的原理

1. 执行命令发生了什么 &#xff1f; 执行命令后&#xff0c;会将安装相关的依赖&#xff0c;依赖会存放在根目录的node_modules下&#xff0c;默认采用扁平化的方式安装&#xff0c;排序规则为&#xff1a;bin文件夹为第一个&#xff0c;然后是开头系列的文件夹&#xff0c;后…...

基于I2C协议的OLED显示(利用U82G库)

目录 一、I2C协议 1、了解I2C协议的基本原理和时序协议 基本原理 时序协议 2、掌握0.96寸OLED屏的工作原理&#xff0c;汉字点阵显示原理 OLED 工作原理 汉字点阵显示原理 3、掌握开源GUI库U82G在stm32上的移植编译方法&#xff0c;以及图形界面可视化技术。 二、具体…...

微信小程序之bind和catch

这两个呢&#xff0c;都是绑定事件用的&#xff0c;具体使用有些小区别。 官方文档&#xff1a; 事件冒泡处理不同 bind&#xff1a;绑定的事件会向上冒泡&#xff0c;即触发当前组件的事件后&#xff0c;还会继续触发父组件的相同事件。例如&#xff0c;有一个子视图绑定了b…...

使用分级同态加密防御梯度泄漏

抽象 联邦学习 &#xff08;FL&#xff09; 支持跨分布式客户端进行协作模型训练&#xff0c;而无需共享原始数据&#xff0c;这使其成为在互联和自动驾驶汽车 &#xff08;CAV&#xff09; 等领域保护隐私的机器学习的一种很有前途的方法。然而&#xff0c;最近的研究表明&…...

MVC 数据库

MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

【JavaSE】绘图与事件入门学习笔记

-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角&#xff0c;以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向&#xff0c;距离坐标原点x个像素;第二个是y坐标&#xff0c;表示当前位置为垂直方向&#xff0c;距离坐标原点y个像素。 坐标体系-像素 …...

Razor编程中@Html的方法使用大全

文章目录 1. 基础HTML辅助方法1.1 Html.ActionLink()1.2 Html.RouteLink()1.3 Html.Display() / Html.DisplayFor()1.4 Html.Editor() / Html.EditorFor()1.5 Html.Label() / Html.LabelFor()1.6 Html.TextBox() / Html.TextBoxFor() 2. 表单相关辅助方法2.1 Html.BeginForm() …...

人工智能--安全大模型训练计划:基于Fine-tuning + LLM Agent

安全大模型训练计划&#xff1a;基于Fine-tuning LLM Agent 1. 构建高质量安全数据集 目标&#xff1a;为安全大模型创建高质量、去偏、符合伦理的训练数据集&#xff0c;涵盖安全相关任务&#xff08;如有害内容检测、隐私保护、道德推理等&#xff09;。 1.1 数据收集 描…...

Golang——7、包与接口详解

包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制

目录 节点的功能承载层&#xff08;GATT/Adv&#xff09;局限性&#xff1a; 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能&#xff0c;如 Configuration …...

ubuntu系统文件误删(/lib/x86_64-linux-gnu/libc.so.6)修复方案 [成功解决]

报错信息&#xff1a;libc.so.6: cannot open shared object file: No such file or directory&#xff1a; #ls, ln, sudo...命令都不能用 error while loading shared libraries: libc.so.6: cannot open shared object file: No such file or directory重启后报错信息&…...