进程与线程:09 进程同步与信号量
课程引入:进程同步与信号量
接下来这节课开始,我们再开始讲多进程图像。讲多进程图像的下一个点,前面我们讲清楚了多进程图像要想实现切换,调度是如何做的。同时,多个进程放在内存中,就会存在多进程合作的情况,而这种合作应该是合理有序的,这部分内容就是进程同步——让多进程之间的合作变得合理有序。那么怎么来实现这种合理有序呢?就要靠信号量。这堂课我们要讲清楚为什么会有信号量,以及如何依靠信号量来实现多个进程推进的合理有序,即同步。
现实案例:进程合作与同步的重要性
首先从一个例子看起,在现实社会中,司机和售货员就如同两个进程,司机的动作是启动车、运行、到站停车,售货员的动作是关门、售票、开门 ,他们各自有一套执行流程。这两个进程在同一台车上,为完成车辆的合理有序行驶,必须进行合作。
- 不合作的后果:如果二者执行顺序没有约束,比如售票员开门售票时,司机启动车辆,就会造成严重后果。所以,司机启动车辆不能随意进行,需要等待一个信号,比如售票员卖完票告知可以走了;同样,售票员开门也不是随便进行的,要等车辆到站停车的信号。
- 合作与同步的体现:司机等待售票员关门的信号再启动车辆,售票员在车辆到站后得到停车信号才开门,这就体现了进程间的合作。一个进程等待信号,另一个进程在合适的时候发送信号,从而使多个进程按照一定顺序向前推进,这就是同步。每个进程有自己的执行程序,但不是每条程序都能随便执行,有时需要停下来等待信号,当收到信号后再继续执行,这就是多进程合理有序的合作与同步。
技术案例:生产者 - 消费者模型中的同步问题
接下来以生产者 - 消费者模型为例进一步说明。有一个共享缓冲区,生产者不断向里放内容,每放完一个 counter
加一;消费者不断从里取内容,每取出一个 counter
减一 ,这是典型的多进程合作场景。
-
同步需求:在这个模型中,也需要合理有序的推进。当生产者发现
counter
等于缓冲区大小buff size
,即缓冲区满了,就不能继续放入,必须等待;同理,当缓冲区为空时,消费者也应该停止。
所以,进程同步的关键在于分析进程在哪些地方该停、什么时候该走。在生产者 - 消费者模型中,缓冲区满时生产者停,消费者消费后产生空闲缓冲区,就给生产者发信号让其继续;缓冲区空时消费者停,生产者生产后给消费者发信号。 -
信号的局限性:仅依靠信号存在问题。例如,当缓冲区满时,生产者
p1
尝试放入会因counter
等于buff size
而sleep
,之后另一个生产者p2
进来,同样会sleep
。此时若消费者执行一次循环,取出一个内容,counter
变为buff size - 1
,消费者判断缓冲区未满,认为无人等待缓冲区,不会再发信号唤醒p2
,导致p2
永远无法唤醒。这说明单纯依靠counter
进行语义判断不足,不仅需要知道缓冲区中空闲个数,还需知道有多少进程在睡眠等待。
信号量的引入与原理
为解决上述问题,引入信号量。信号量是一个整数,它能记录更多信息。例如信号量等于 -2
,表示有两个进程在等待 。当消费者执行时,发现信号量为 -2
,就会唤醒阻塞队列头部的进程(如 p1
),同时信号量变为 -1
;再次执行,唤醒 p2
,信号量变为 0
。
- 信号量的语义:信号量为负数时,表示有进程阻塞,其绝对值代表等待进程的数量;为
0
时,表示没有进程等待,但也没有可用资源;为正数时,表示有可用资源,数值代表资源数量 。如消费者执行使信号量变为1
,表示还有一个空闲缓冲区,此时若有新的生产者p3
来,无需睡眠可直接执行,执行后信号量变为0
;再有生产者来,信号量变为-1
,该生产者需阻塞等待。 - 基于信号量的进程决策:进程根据信号量的值决定是否等待或唤醒其他进程。生产者申请使用资源(如空闲缓冲区)时,若信号量为负或零,说明资源不足或已用完,需等待;消费者释放资源(产生空闲缓冲区)时,若信号量为负,说明有进程在等待,需唤醒一个等待进程。
信号量与资源等待的关系
我们可以根据这个习题来回答,对于一种数量为八的资源,思考进程等待的原因。进程等待肯定是因为申请资源时没有可用资源了。在进程同步中,竞争合作体现为走走停停,而“停滞”是其中的核心,所以明确进程何时等待至关重要。当一个进程访问资源却发现没有资源时,就会进入等待状态。
这种资源对应的信号量初值应该设为八,这表示初始状态下可以使用八个该资源。当信号量的值变为零时,意味着没有资源剩余,若值再变为负数,进程就需要等待。当信号量的值为二时,说明还有两个资源可供使用,此时没有进程在等待该资源;而当信号量的值为 -2 时,则表示有两个进程正在等待该资源 。
通过信号量的值,我们能够判断系统中有多少进程在等待资源,以及还有多少资源可供使用。基于这样的判断,我们可以控制进程的执行与暂停,从而实现进程同步,其核心就在于依据信号量的值来判断进程何时该“走”、何时该“停”。
信号量的核心概念与操作
-
信号量的定义与作用
进程之间的同步是多个进程走走停停的合理有序推进,判断何时停要看信号量的值。当信号量为负值或 0 时,进程申请信号量会变成负值,此时进程等待;其他进程根据信号量的值,若为负,在释放信号量时进行唤醒操作;若为正,直接累加,无需发信号。 -
信号量的实现方式
在编程实现中,判断进程是否需要等待资源是通过调用函数来完成的,这就涉及到信号量的具体实现。信号量的核心是一个整数,它记录着资源的相关信息。为了方便用户操作,我们通过定义P
、V
操作这两个接口函数来实现对信号量的控制。P
操作:当进程想要申请资源,判断自己是否应该暂停时,就调用P
操作。以P(sem)
为例,执行该操作时,首先将信号量sem
的值减 1。这是因为进程申请资源,相当于资源数量减少。如果减 1 后信号量的值小于 0,说明在本次申请之前,资源要么已经没有剩余(值为 0),要么已经处于供不应求的状态(值为负),当前进程无法获得资源,此时进程就会进入睡眠状态,并被放入与该信号量相关联的阻塞队列中。例如,生产者进程每次使用空闲缓冲区时,就需要对空闲缓冲区对应的信号量执行P
操作,以此判断是否有空闲缓冲区可供使用,如果没有则进入等待。V
操作:有进程等待,就需要有唤醒操作,这就是V
操作的作用。当进程释放资源时,会调用V
操作。执行V
操作时,将信号量的值加 1 ,这表示资源数量增加。如果加 1 后信号量的值仍然小于等于 0,说明在释放资源之前,有进程在等待该资源(信号量为负表示等待进程数,为 0 表示刚有进程等到资源),此时就需要调用wake up
函数,从阻塞队列中唤醒一个进程;如果加 1 后信号量的值大于 0 ,则表示没有进程在睡眠等待,无需进行唤醒操作。比如消费者进程产生空闲缓冲区后,就会对相应的信号量执行V
操作。- 系统调用:由于信号量操作涉及到进程睡眠等在内核态完成的操作,所以
P
和V
操作需要做成系统调用,这样上层应用程序就能通过调用系统调用来使用信号量。其中,P
操作源于荷兰语“test”,表示测试是否需要阻塞;V
操作源于荷兰语“increment”,表示增加资源数量,进而实现唤醒等待进程的功能 。
信号量解决生产者 - 消费者问题
利用信号量及其 P
、V
操作,可以有效解决生产者 - 消费者问题,实现进程间的同步与合作。在解决该问题时,关键在于分析生产者和消费者何时会暂停,并据此定义相应的信号量。
- 分析生产者与消费者的等待条件
- 生产者:当缓冲区满时会停,所以定义一个信号量
empty
表示空闲缓冲区个数,初值为buff_size
。生产者每次操作前先执行P(empty)
,测试empty
是否为 0 ,即缓冲区是否满,若满则等待。当消费者释放空闲缓冲区时,执行V(empty)
增加empty
的值 。 - 消费者:当缓冲区没有内容时会停,定义一个信号量
full
表示已生产内容的个数,初值为 0 。消费者每次操作前先执行P(full)
,测试full
是否为 0 ,即是否有内容,若无则等待。当生产者生产内容后,执行V(full)
增加full
的值 。
- 生产者:当缓冲区满时会停,所以定义一个信号量
- 互斥信号量实现共享资源互斥访问
共享缓冲区(可视为文件)的操作需要互斥,即同一时刻只能有一个进程访问。定义一个互斥信号量mutex
,初值为 1 。生产者和消费者在访问共享缓冲区前,先执行P(mutex)
,若mutex
等于 1 ,则变为 0 ,进程进入;访问结束后执行V(mutex)
释放资源,使其他进程可以进入 。
通过上述信号量的设置以及 P
、V
操作的合理运用,依据信号量数值所代表的语义,准确判断进程是否需要睡眠或唤醒其他进程,从而实现了生产者和消费者之间执行过程的合理有序,最终解决了进程同步问题,实现了二者的合作 。
相关文章:
进程与线程:09 进程同步与信号量
课程引入:进程同步与信号量 接下来这节课开始,我们再开始讲多进程图像。讲多进程图像的下一个点,前面我们讲清楚了多进程图像要想实现切换,调度是如何做的。同时,多个进程放在内存中,就会存在多进程合作的…...
鸿蒙 Core File Kit(文件基础服务)之简单使用文件
查看常用的沙箱目录 应用沙箱文件访问关系图 应用文件目录结构图 Entry Component struct Index {build() {Button(查看常用的沙箱目录).onClick(_>{let ctx getContext() // UI下只能使用这个方法,不能 this.contextconsole.log(--应用缓存文件保存目录&#x…...
游戏引擎学习第277天:稀疏实体系统
回顾并为今天定下基调 上次我们结束的时候,基本上已经控制住了跳跃的部分,达到了我想要的效果,现在我们主要是在等待一些新的艺术资源。因此,等新艺术资源到位后,我们可能会重新处理跳跃的部分,因为现在的…...
基于Win在VSCode部署运行OpenVINO模型
一、准备工作 1、Python 下载Win平台的Python安装包,添加环境变量,测试: python --version 在VSCode里( CtrlShiftP 打开命令面板),指定Python解释器为上面安装路径。写一个python脚本运行测试。 2、虚…...
关于maven的依赖下不下来的问题
相信大家对于maven下不下依赖会感到很烦,这里就来给大家进行解惑。 首先maven依赖报错基本是两种情况,一个是下载报错,这种情况就要考虑是否在maven的setting.xml文件中配了阿里云的相关配置没,其次就要检查是否真的存在这个依赖…...
按键精灵ios脚本新增元素功能助力辅助工具开发(一)
元素节点功能(iOSElement) 在按键精灵 iOS 新版 APP v2.2.0 中,新增了元素节点功能 iOSElement,该功能包含共 15 个函数。这一功能的出现,为开发者在处理 iOS 应用界面元素时提供了更为精准和高效的方式。通过这些函…...
【数据结构】——栈和队列OJ
一、有效的括号 题目链接: 20. 有效的括号 - 力扣(LeetCode) 题目的要求很简单,就是要求我们判断其输入的括号字符串是否是有效的括号,那么我们要如何判断呢? 我们可以这样,我们遍历出传入的…...
Windows部署LatentSync唇形同步(字节跳动北京交通大学联合开源)
#工作记录 一、前言 LatentSync:基于音频驱动的端到端唇形同步框架 LatentSync是由ByteDance开源的一个先进唇形同步框架,旨在通过音频条件驱动的潜在扩散模型实现高精度的唇形同步。与传统基于像素空间扩散或两阶段生成的方法不同,Late…...
MySQL:关系模型的基本理论
系列文章目录 1.关系模型的基本概念 2.数据库的完整性 文章目录 系列文章目录前言一、关系模型的基本概念 1.基本术语: 2.关系的特征二、数据库的完整性 1.常见用例:2.三类完整性原则3.MySQL提供的约束 三、触发器 1.触发器的定义 2.…...
9.1 C#控制SW中零件的变色与闪烁
本文介绍:装配件中某零件隐藏与显示、零件的颜色修改。 探讨本话题的目的是为了实现如下目的:如果某个气缸报警,那么3D中该气缸红色并闪烁。 目前,当勾选部件1闪烁时,零件1-1将在显示与隐藏之间闪烁。 示例代码放到如下位置: C#与solidworks示例1-零部件的显示与隐藏资源…...
Spring Boot 跨域问题全解:原理、解决方案与最佳实践
精心整理了最新的面试资料和简历模板,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 一、跨域问题的本质 1.1 什么是跨域? 跨域(Cross-Origin)问题源于浏览器的同源策略(Same-Origin Policy&…...
C++学习之路,从0到精通的征途:继承
目录 一.继承的概念及定义 1.继承的概念 2.继承的定义 (1)继承的定义格式 (2)继承基类成员访问方式的变化 二.基类与派生类间的转换 1.派生类对象赋值给基类的引用/指针 2. 派生类对象直接赋值给基类对象 三.继承的作用域 四.派生类的默认成员函数 1.构造函数 2.拷…...
从零开始掌握FreeRTOS(2)链表之节点的定义
目录 节点 节点定义 节点实现 根节点 根节点定义 精简节点定义 根节点实现 在上篇文章,我们完成了 FreeRTOS 的移植。在创建任务之前,我们需要先了解FreeRTOS的运转机制。 FreeRTOS是一个多任务系统,由操作系统来管理执行每个任务。这些任务全都挂载到一个双向循…...
C 语言_常见排序算法全解析
排序算法是计算机科学中的基础内容,本文将介绍 C 语言中几种常见的排序算法,包括实现代码、时间复杂度分析、适用场景和详细解析。 一、冒泡排序(Bubble Sort) 基本思想:重复遍历数组,比较相邻元素,将较大元素交换到右侧。 代码实现: void bubbleSort(int arr[], i…...
LamaIndex rag(增强检索)入门
LamaIndex RAG 搭建 lamaindex rag 的简单是例 from llama_index.embeddings.huggingface import HuggingFaceEmbedding from llama_index.core import Settings,SimpleDirectoryReader,VectorStoreIndex from llama_index.llms.huggingface import HuggingFaceLLM#初始化一个…...
七、深入 Hive DDL:管理表、分区与洞察元数据
作者:IvanCodes 日期:2025年5月13日 专栏:Hive教程 内容导航 一、表的 DDL 操作 (非创建)二、分区的 DDL 操作三、洞察元数据:SHOW 命令的威力结语:DDL 与 SHOW,Hive 管理的双翼练习题一、选择题二、代码题…...
SQLMesh信号机制详解:如何精准控制模型评估时机
SQLMesh的信号机制为数据工程师提供了更精细的模型评估控制能力。本文深入解析信号机制的工作原理,通过简单和高级示例展示如何自定义信号,并提供实用的使用技巧和测试方法,帮助读者优化数据管道的调度效率。 一、为什么需要信号机制…...
STM32 __main汇编分析
在STM32的启动流程中,__main是一个由编译器自动生成的C标准库函数,其汇编级调用逻辑可通过启动文件(如startup_stm32fxxx.s)观察到,但具体实现细节被封装在编译器的运行时库中。以下是其核心逻辑解析: 一、…...
Google Earth Engine(GEE) 代码详解:批量计算_年 NDVI 并导出(附 Landsat 8 数据处理全流程)
一、代码整体目标 基于 Landsat 8 卫星数据,批量计算 2013-2020 年研究区的 NDVI(归一化植被指数),实现去云处理、数据合成、可视化及批量导出为 GeoTIFF 格式,适用于植被动态监测、生态环境评估等场景。 二、代码分步解析(含核心原理与易错点) 1. 加载并显示研究区边…...
【漫话机器学习系列】257.填补缺失值(Imputing Missing Values)
数据科学必备技能:填补缺失值(Imputing Missing Values) 在数据分析和机器学习项目中,缺失值(Missing Values) 是非常常见的问题。缺失的数据如果处理不当,会严重影响模型的训练效果࿰…...
c 中的哈希表
哈希是一种可以接受各种类型、大小的输入,输出一个固定长度整数的过程。你可以将哈希理解成一种特殊的映射,哈希映射,将一个理论无限的集合A映射到有限整数集合B上。 哈希函数:哈希函数是哈希过程的核心,它决定了哈希映…...
AI空域调度系统的社会角色与伦理边界
当AI空域调度系统成为城市运行不可或缺的一部分,其角色已不再是单纯的技术工具,而逐步具备了社会属性。平台既作为智能基础设施的调度中枢,也承担起数据治理、行为规训和公共资源分配等功能。本章聚焦AI调度系统的“类政府性”角色崛起&#…...
pringboot3+vue3融合项目实战-大事件文章管理系统-文章分类列表
GetMappingpublic Result <List<Category>>list(){List<Category> list categoryService.list();return Result.success(list);}然后在categoryservice接口新增 List list(); 然后再categoryserviceimpl实现类里面加入 Overridepublic List<Category&g…...
关于cleanRL Q-learning
内置变量 内置变量是由编程语言解释器或运行时环境预定义的变量。它们通常用于提供程序的元信息(如文件路径、模块名称)或控制程序行为。在 Python 中,内置变量通常以双下划线开头和结尾,例如 __file__、__name__。 以下是一些常…...
Electron-Vue3、Electron-React、Electron-Angular打造舆情监控系统项目
Electron是一个跨平台的桌面应用开发框架,可以让我们用html css js的技术开发跨平台桌面上可以安装的软件。视频详解: Electron教程 ElectronVue跨平台桌面软件开发教程-2024年更新(大地老师) 从Electron环境搭建开始到手把手教你调试、Elect…...
STM32 修炼手册
第一章 计算机体系结构(了解) 后续在板子上开发的时候,需要考虑是否有操作系统 方式一:有操作系统,通过c库通过os api操作硬件方式二:无操作系统, 通过c库通过固件库操作硬件 第二章 STM32开发板概述 板子/开发板&…...
React vs Vue:点击外部事件处理的对比与实现
React vs Vue:点击外部事件处理的对比与实现 在 Web 应用中,“点击外部事件监听”是一种常见需求,典型应用如:点击弹窗外部关闭弹窗、点击下拉菜单外关闭菜单。虽然在 React 和 Vue 中实现的原理类似——都是通过监听 document 的…...
rk3576--- HDMI CEC唤醒
文章目录 一、CEC唤醒的相关概念二、CEC唤醒实现(一)内核配置(二)设备树dts(三)驱动注册中断(四)休眠后开启MCU(五)验证 一、CEC唤醒的相关概念 CEC 是一种在…...
榕壹云搭子系统技术解析:基于Spring Boot+MySQL+UniApp的同城社交平台开发实践
一、引言 本文将分享一款基于Spring Boot、MySQL和UniApp开发的同城社交平台的技术实现细节,重点探讨其架构设计、核心功能及开发过程中的技术考量。该项目旨在为开发者提供可扩展的社交平台解决方案,支持快速二次开发与独立部署。 二、技术选型与架构设计 1. 技术栈概览 …...
Node.js事件循环中的FIFO原则
1. Node.js事件循环中的FIFO原则 Node.js的事件循环确实遵循先进先出(FIFO)原则,但这个原则的适用范围需要明确。具体来说: FIFO原则的适用范围:FIFO原则主要适用于每个阶段内部的任务队列,而不是跨越不同…...
基于javaweb的SpringBoot爱游旅行平台设计和实现(源码+文档+部署讲解)
技术范围:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…...
服务器相关
虚拟机服务器搭建 virtualbox安装 下载地址:Downloads – Oracle VirtualBox centos镜像下载地址 centos-7-isos-x86_64安装包下载_开源镜像站-阿里云 阿里巴巴开源镜像站-OPSX镜像站-阿里云开发者社区 清华大学开源软件镜像站 | Tsinghua Open Source Mirror…...
Linux的文件查找与压缩
查找文件 find命令 # 命令:find 路径范围 选项1 选项1的值 \[选项2 选项2 的值…]# 作用:用于查找文档(其选项有55 个之多)# 选项:# -name:按照文档名称进行搜索(支持模糊搜索,\* &…...
Q1财报持续向好,腾讯音乐如何在不确定中寻找确定性?
最近一段时间,各家上市公司的财报都备受关注,腾讯音乐娱乐集团作为文娱类的头部企业也是备受市场关注的,今日腾讯音乐第一季度财报已公布,业绩持续向好。在这个不确定性的大环境下,腾讯音乐是如何寻找自己的确定性的&a…...
window 显示驱动开发-报告图形内存(一)
计算图形内存 在 VidMm 能够向客户端报告准确的帐户之前,它必须首先计算图形内存的总量。 VidMm 使用以下内存类型和公式来计算图形内存: 系统总内存 此值是操作系统可访问的系统内存总量。 BIOS 分配的内存不会出现在此数字中。 例如,一台…...
DELL R770 服务器,更换RAID卡教程!
今天的任务,是帮客户的一台戴尔DELL PowerEdge R770 服务器,更换RAID卡(也可以称之为PERC模块、阵列卡、RAID控制器等)。 根据我的个传统习惯,依然是顺便做一个教程,分享给有需要的粉丝们。如果看完教程&am…...
【Java】网络编程(Socket)
网络编程 Socket 我们开发的网络应用程序位于应用层,TCP和UDP属于传输层协议,在应用层如何使用传输层的服务呢?在应用层和传输层之间,则使用套接字Socket来进行分离 套接字就像是传输层为应用层开的一个小口,应用程…...
力扣-226.翻转二叉树
题目描述 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 class Solution { public:TreeNode *invertTree(TreeNode *root) {if (!root) {return NULL;}TreeNode *temp root->right;root->right root->left;root->left …...
数据结构——例题1
eg1:求解 S 1! 2! 3! ... n! #include<stdio.h> #include<stdlib.h>long sum(int n){long s 0,t,i,j;for(i1;i<n;i){t1;for(j1;j<i;j){t*j;}st;}return s; }int main(){int n;printf("请输入一个整数:");scanf("…...
INT202 Complexity of Algroithms 算法的复杂度 Pt.7 NP-Completeness NP完全性
文章目录 1.P与NP问题1.1 计算上难以解决的问题(Hard Computational Problems)1.2 决策问题和优化问题(Decision/Optimization problems)1.3 计算问题的正式定义1.4 复杂性类1.4.1 复杂性类 P P P1.4.2 证明(Certifica…...
K8s 图形界面管理kubesphere
1. 概述 KubeSphere 是一个开源的、基于 Kubernetes 的容器平台,旨在简化企业级 Kubernetes 集群的部署、管理和运维。KubeSphere 提供了丰富的功能,包括多租户管理、DevOps 流水线、应用商店、监控与日志、服务网格、网络策略等,帮助企业快…...
MCU程序加密保护(一)闪存读写保护法 加密与解密
MCU(微控制器单元)的加密方法可以从硬件、软件和通信协议三个层面来理解。以下是常见的MCU加密手段,按类型分类说明: 针对目前 STM32 系列微控制器在程序加密保护方面手段单一、保护效果有限的问题,本文介绍并分析了四…...
Windows下安装mysql8.0
一、下载安装离线安装包 (下载过了,可以跳过) 下载网站:MySQL :: Download MySQL Installerhttps://dev.mysql.com/downloads/installer/ 二、安装mysql 三、安装完成验证...
ubuntu----100,常用命令2
目录 文件与目录管理系统信息与管理用户与权限管理网络配置与管理软件包管理打包与压缩系统服务与任务调度硬件信息查看系统操作高级工具开发相关其他实用命令 在 Ubuntu 系统中,掌握常用命令可以大幅提升操作效率。以下是一些常用的命令,涵盖了文件管理…...
PYTHON训练营DAY24
# SO代码我们的感情好像跳楼机 # 元组创建时,可以省略括号:my_tuple4 10, 20, thirty # 字符串要加“ ” 元组 一、创建 my_tuple1 (1, 2, 3) my_tuple2 (a, b, c) my_tuple3 (1, hello, 3.14, [4, 5]) # 可以包含不同类型的元素 print(my_tupl…...
Element UI 双击事件(@cell-dblclick 与 @row-dblclick)
Element UI 双击事件(cell-dblclick 与 row-dblclick) 一、核心双击事件绑定 表格单元格双击 事件绑定: 通过 cell-dblclick 监听单元格双击,接收四个参数(row, column, cell, event)。 示…...
云原生|kubernetes|kubernetes的etcd集群备份策略
简介: 云原生|kubernetes|kubernetes的etcd集群备份策略 前言: etcd作为集群的关键组件之一,还是非常有必要进行定期备份的,本例将会就如何更快更好的备份etcd以及应该有哪些策略做一解析。(二进制部署的etcd集群&…...
永不收费的软件,离线可用
上次在推荐PC端证件照软件时,有小伙伴问是否有安卓端的版本。当时我说有,只是需要测试一下再给大家推荐。 今天就为大家带来一款安卓端的证件照软件,有需要的小伙伴可以赶紧收藏起来! 底色证件照(安卓) 之…...
解锁课程编辑器之独特风姿
(一)强大的编辑功能 课程编辑器的编辑功能堪称一绝,就像是一位全能的艺术大师。在文字编辑方面,它提供了丰富的字体、字号选择,还能对文字进行加粗、倾斜、下划线等格式设置,让重点知识一目了然。比如教师…...
在企业级智能体浪潮中,商业数据分析之王SAS或将王者归来
继LLM大模型与GenAI生成式AI应用之后,智能体正在成为下一个风口。与基于LLM的GenAI应用不同,智能体将LLM的智能涌现能力与智能决策的能力相结合,让智能体不仅能够认知、分析和总结,还能够进行决策和执行决策,将知识与智…...