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

ceph文件系统

ceph文件系统:

使用设备:4台机器

高度可扩展,分布式的存储文件系统,旨在提供高性能,高可靠性和高可用的对象存储,块存储,文件系统的存储

使用分布式的算法保证数据的高可用和一致性

ceph的架构:

  • 1、ceph minitor
    MON负责存储和维护整个ceph集群的状态信息,主要是集群的成员的信息,存储状态和配置数据等等

确保集群的一致性,处理选举和状态的更新,集群内部成员的通信,包括故障转移

ceph当中mon至少要有3个节点,确保高可用

  • 2、OSD (object storage daemon)
    ceph存储系统的核心组件,负责存储数据,处理读写请求,数据复制,数据恢复

每个OSD节点管理一个或者多个硬盘驱动

存储实际的数据和副本

处理对象级别的数据操作,读,写,删

在节点付账时,进行数据恢复

  • 3、ceph mds metadata server
    对ceph的文件系统的元数据进行管理,文件和目录的结构,文件的权限,mds提供元数据服务

管理集群的元数据信息

处理客户端对文件系统的请求

ceph集群中至少要有一个mds节点

  • 4、存储池和pg

存储池(pool):ceph存储数据对象的容器每个存储池可以定义数据冗余的策略(副本数,默认都是3)crush映射规则等等

存储池是一个逻辑上的概念

管理和组织数据的对象

定义数据的冗余方式,只要是开副本 ----- 3个

配置crush映射,数据如何在OSD之间分布

pg:placement group

pg也是ceph当中的一个逻辑概念,用于数据分布的基本单位,创建存储池,定义好pg的数量

pg是由一组对象(object)组成的逻辑集合,每个对象都会映射到一个或者多个pg

数据分布:数据写入集群,映射到存储池中的一个pg,crush算法决定将pg分布到哪些OSD

在ceph当中,pg的数量和OSD的数量是相关的,设置一个合理的pg数,有助于提高集群的性能

以3个OSD为例
pg数量 = (OSD 数量 * 100)/ 存储池的副本数300/3 =100
pg的数量应该是2的幂值pg的数量一般都是OSD数量的一百倍左右

存储池,pg和OSD之间的关系:

  • 1、存储池(pool),管理数据的基本单位,组成和配置数据的存储和冗余的方式

  • 2、pg存储池中的数据被划分成多个pg,每个pg是数据分布的最小单位,pg负责对象存储的位置,通过crush的算法把数据分布到OSD上

  • 3、OSD是负责存储数据的基于物理设备的虚拟概念

在这里插入图片描述

crush算法,ceph自带的一种算法:
数据分布的算法,把对象分配到集群的OSD节点当中

crush算法使用hash算法来决定数据的存储位置,确保数据是均匀的分布在集群的OSD上

在这里插入图片描述

对象存储,云平台存储,基于apt接口,通过http(s)来对目标发起请求的方式获取数据

块存储 RBD:
文件系统 cephfs

集群的架构:

test1 192.168.31.10 mon osd admin
test2 192.168.31.11 mon osd
test3 192.168.31.12 mon osd
test4 192.168.31.13 客户端

ceph 17版本:2024 17.2.4 新版 依赖于docker 和 python3 ------- Ubuntu自带,lvm2

cephadm bootstrap --mon-ip 192.168.233.10 --cluster-network 192.168.233.0/24 --allow-fqdn-hostname

–mon-ip 指定mon进程的节点地址,先指定admin节点

–cluster-network: 集群网络的范围,ceph节点内部通信

集群和客户端之间进行免密登录
↓
添加OSD
ceph orch host add test2 / test3
↓
Ceph Dashboard is now available at:
URL: https://test1:8443/
User: admin
Password: 47cqqsv839
作为Ceph集群的底层的硬盘必须满足两个条件:1、容量必须大于5G2、不能对硬盘做任何分区和文件系统

ceph的RBD模式

RBD:rados block device
用于虚拟化环境,openstack,kvm

数据库:性能高,延迟低的块存储方式

优点:
1、支持动态扩展
2、支持快照和克隆

缺点:
1、RBD的方式必须要先创建文件系统
使用方式:在云计算平台当中使用,尤其是大规模存储和高性能存储场景

ceph osd pool create rbd1 128 128 #创建存储池的命令ceph osd pool rbd1 这是存储池的名称
128 128
128 pg_num pg的数量
128 pgp_num 的数量rbd create myrbd1 -size 2G --pool rbd1 创建镜像的命令:
镜像RBD存储的基本单位,他是一个虚拟的磁盘
镜像提供了一个虚拟的块设备的接口,可以挂载的方式进行使用

创建RBD镜像,实际上就是类似磁盘的一个分区

root@test4:/etc/ceph# rbd create myrbd1 --size 2G --pool rbd1
创建镜像root@test4:/etc/ceph# rbd map myrbd1 --pool rbd1
映射之后,会虚拟出一个逻辑上的硬盘,要创建文件系统,然后挂载才可以使用

2、cephfs的存储方式:

分件系统分布式存储方式,基于内核实现共享文件的存储方式

大数据存储,文件服务器(文件共享,企业的镜像服务源)

优点:内核兼容,NFS方式也可以实现,部署速度比较快,跨节点实现

缺点:配置比RBD复杂,在大集群当中比较复杂

ceph需要两个存储池

  • 数据池:cephfs.data,用来存储数据,根据OSD的数量和总空间的大小,创建cephfs时,系统自动分配给cephfs文件系统的大小,按照一般情况是总大小的3分之1左右

  • 元数据池:保存数据的元信息,cephfs.meta

ceph fs volunme create cephfs:创建ceph文件系统

NFS方式:

在这里插入图片描述

在这里插入图片描述

3、ceph object storge 对象存储

云计算的后台的存储方式一般都是用对象存储

对象存储:高扩展,处理文件的级别可以达到PB级别


ceph需要使用分布式文件系统的企业一般都是需要存储海量数据,以及保证数据的高可用非常严禁的场景

ceph的存储方式的数据流向

存储池 pg osd

创建存储池,分配pg
数据按照对象分配给pg
pg再把数据分配到osd

相关文章:

ceph文件系统

ceph文件系统: 使用设备:4台机器 高度可扩展,分布式的存储文件系统,旨在提供高性能,高可靠性和高可用的对象存储,块存储,文件系统的存储 使用分布式的算法保证数据的高可用和一致性 ceph的架…...

模型创新、论文复现、科研辅导、论文代码定制

建模先锋团队长期致力于为用户提供优质的代码定制服务。团队提供全网最低价格的服务,同时保证高性价比和高质量的代码交付,为您提供个性化定制的服务。 以下是定制服务范围: 通过深度学习和信号处理技术,我们能够针对不同行业和场…...

【flink-cdc】flink-cdc 3版本debug启动pipeline任务,mysql-doris

官方文档 github仓库地址 Flink cdc debug调试动态变更表结构 经过测试使用,在启动任务配置Modify classpath添加jar的方式,容易出错classNotFoundException等等。 一、build project flink-cdc版本:3.2.1 mvn clean package "-Dma…...

mybatisX插件的使用,以及打包成配置

装mybatisX插件; idea连接数据库; 点击mybatisx-generator,设置自己装mybatisX插件; idea连接数据库; 点击mybatisx-generator,设置自己要的包和类; 如果要把自己的配置设置成一个自定义模板&a…...

pip下载包出现SSLError

报错: ERROR: Could not install packages due to an OSError: HTTPSConnectionPool(host‘files.pythonhosted.org’, port443): Max retries exceeded with url: /packages/8a/c2/ae7227e4b089c6a8210920db9d5ac59186b0a84eb1e6d96b9218916cdaf1/taming_transform…...

Linux下查看文件和文件夹占用空间大小

使用Linux命令,查看文件磁盘所占的空间大小,下面可以通过以下命令进行操作 df 可以查看一级文件夹大小、使用比例、档案系统及其挂入点,但对文件束手无策du 查看文件和文件夹的磁盘使用空间 在使用中,一般是df命令和du命令一起联…...

【论文+源码】基于Spring和Spring MVC的汉服文化宣传网站

为了实现一个基于Spring和Spring MVC的汉服文化宣传网站,我们需要创建一个简单的Web应用程序来展示汉服文化和相关信息。这个系统将包括以下几个部分: 数据库表设计:定义文章、用户和评论的相关表。实体类:表示数据库中的数据。DAO层接口及MyBatis映射文件:用于与数据库交…...

C++语言的学习路线

C语言的学习路线 C是一门复杂而强大的编程语言,由于其高性能和灵活性,受到了许多开发者和企业的青睐。无论是系统软件、嵌入式系统还是游戏开发,C都有非常广泛的应用。要掌握C这门语言,需要合理制定学习路线,并结合实…...

【OpenCV】使用Python和OpenCV实现火焰检测

1、 项目源码和结构(转) https://github.com/mushfiq1998/fire-detection-python-opencv 2、 运行环境 # 安装playsound:用于播放报警声音 pip install playsound # 安装opencv-python:cv2用于图像和视频处理,特别是…...

【ArcGISPro/GeoScenePro】解决常见的空间参考和投影问题

修复空间参考缺失的图像 数据 https://arcgis.com/sharing/rest/content/items/535efce0e3a04c8790ed7cc7ea96d02d/data 查看属性坐标 查看属性范围 范围值并不是零或接近于零。 这意味着栅格具有范围,因此其已正确进行...

Ruby语言的语法

Ruby语言的语法之美 Ruby是一种动态、开放源代码的编程语言,由日本的松本行弘(Yukihiro Matsumoto)于1995年首次发布。Ruby语言以其简洁、优雅和易于阅读的语法而闻名。它不仅适合初学者,还被广泛应用于Web开发、数据分析和其他领…...

概述(讲讲python基本语法和第三方库)

我是北子,这是我自己写的python教程,主要是记录自己的学习成果方便自己日后复习, 我先学了C/C,所以这套教程中可能会将很多概念和C/C去对比,所以该教程大概不适合零基础的人。 it seems that python nowadays 只在人工…...

程序包org.springframework.boot不存在

springBoot项目启动报错 程序包org.springframework.boot不存在 1、检查依赖 首先检查pom文件判断依赖是否存在 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId><version>2.4.5…...

.NET Core FluentAPI

目录 约定配置 主要规则 两种配置方式 Data Annotation Fluent API Fluent API配置 Fluent API众多方法 选择 约定配置 主要规则 表名采用DbContext中的对应的DbSet的属性名。数据表列的名字采用实体类属性的名字&#xff0c;列的数据类型采用和实体类属性类型最兼容…...

浙江省自然资源厅:基于“浙里办”的自然资源移动政务服务创新实践——“浙里自然资源”

摘 要&#xff1a;本文基于浙江省自然资源移动政务服务的创新实践&#xff0c;设计和实现“浙里自然资源”应用&#xff0c;依托浙江省省域空间治理数字化平台特有的架构基础&#xff0c;在提升功能性和可用性、加强运营力度、丰富服务内容等方面采取了管理举措和技术创新。通…...

【Astro】如何在Astro上借助Cloudflare D1和Drizzle ORM打造全栈应用?一文带你搞定!

如何在Astro上借助Cloudflare D1和Drizzle ORM打造全栈应用&#xff1f;一文带你搞定&#xff01; 文章目录 如何在Astro上借助Cloudflare D1和Drizzle ORM打造全栈应用&#xff1f;一文带你搞定&#xff01;前言一、Astro简介与优势二、Cloudflare D1简介三、Drizzle ORM简介四…...

【Axios使用手册】如何使用axios向后端发送请求并进行数据交互

axios 是一个基于 Promise 的 HTTP 客户端&#xff0c;用于浏览器和 Node.js。它支持请求和响应拦截、取消请求、自动转换 JSON 数据等功能&#xff0c;非常适合在现代 JavaScript 应用中进行网络请求。以下是对 axios 的详细讲解&#xff0c;包括安装、基本用法、高级功能等。…...

边缘计算应用十大领域

边缘计算解决了互联网的网速问题&#xff0c;作为实现边缘计算的基础&#xff0c;那边缘计算是5G与产业互联网、物联网时代的重要技术支撑&#xff0c;也正迎来广阔的增长空间。那么现在我们生活中有哪些领域正在使用边缘计算呢&#xff1f;今天我们来盘点一下我们身边正在使用…...

CSS 学习之 padding 与图形绘制

padding 属性和 background-clip 属性配合&#xff0c;可以在有限的标签下实现一些 CSS 图形绘制效果&#xff0c;我这里举两个小例子&#xff0c;重在展示可行性。 例 1:不使用伪元素&#xff0c;仅一层标签实现大队长的“三道杠”分类图标效果。此效果在移动端比较常见&…...

熔断器模式如何进入半开状态的

熔断器模式在进入打开状态并经过一段冷却时间后&#xff0c;会自动进入半开状态。这个过程是熔断器模式自我恢复机制的一部分&#xff0c;旨在测试下游服务是否已经恢复正常&#xff0c;从而决定是否重新允许请求通过。 1. 进入打开状态&#xff1a; • 当服务调用失败次数达到…...

数据结构:双向循环链表

双向循环链表&#xff08;Doubly Circular Linked List&#xff09; 双向循环链表是双向链表的一种变体&#xff0c;其特点是链表的头节点和尾节点相连&#xff0c;形成一个闭环。这种结构允许在链表中进行无缝的双向遍历&#xff0c;并且由于循环特性&#xff0c;可以从任何节…...

宝安湾区之光附近的钓鱼点

工作日的午休我经常在公司附近骑行&#xff0c;有时候也会骑行到宝安的湾区之光。但是我最感兴趣的除了湾区之光摩天轮&#xff0c;还有雷打不动的快乐钓鱼佬。 上图红框区域的河岸每天都会出现零零散散的快乐钓鱼佬&#xff0c;他们好像都有自己的钓鱼窝点。我发现来这里钓鱼也…...

【计算机网络】什么是AC和AP?

在现代的无线网络中&#xff0c;AC&#xff08;Access Controller&#xff0c;接入控制器&#xff09;和AP&#xff08;Access Point&#xff0c;无线接入点&#xff09;是两个至关重要的设备&#xff0c;它们在网络的管理、连接和优化中扮演着重要角色。理解它们的功能和区别&…...

python 词法分析

词法分析&#xff08;Lexical Analysis&#xff09;是编译器的第一步&#xff0c;它的任务是将源代码文本分割成一系列有意义的单元&#xff08;称为“词法单元”或“Token”&#xff09;。这些词法单元通常包括关键字、标识符、常量、运算符、分隔符等。 import re# 定义词法单…...

JUC--CAS原理(以Atomic报下类的实现来了解CAS的原理)

以Atomic来了解CAS的原理 六、无锁6.1CAS&#xff08;Compare-And-Swap&#xff09;原理6.2CAS与synchronized6.3Atomic&#xff08;原子类&#xff09;原理分析 6.4ABA问题6.4unsafe 六、无锁 6.1CAS&#xff08;Compare-And-Swap&#xff09;原理 CAS原理&#xff1a;CAS是…...

对比显式启用-u_printf_float和-u_scanf_float前后的代码内存体量实验

本文的嵌入式编译器基于GCC for ARM&#xff0c;构建文件基于Makefile。 main.c不编写任何代码&#xff0c;保证实验的其他变量统一。源文件main.c&#xff1a; 优化等级固定为 -Og &#xff1a; syscalls.c 系统调用库函数文件参考&#xff1a;基于GCC for ARM交叉编译工具链…...

嵌入式 Linux LED 驱动开发实验

一、Linux 下 LED 灯驱动原理 a)地址映射 在编写驱动之前,我们需要先简单了解一下 MMU 这个神器, MMU 全称叫做 Memory Manage Unit,也就是内存管理单元。在老版本的 Linux 中要求处理器必须有 MMU,但是现在 Linux 内核已经支持无 MMU 的处理器了。 MMU 主要完成的功能如…...

qml PathView详解

1、概述 PathView 是 Qt Quick 中一个非常强大的视图组件&#xff0c;它基于一个 Path 来展示视图项&#xff08;如 Item、Rectangle 等&#xff09;。PathView 可以让你按照定义的路径动态地显示多个元素&#xff0c;并且支持动画、滑动等功能。这个视图控件的最大特点是能够…...

Spring源码分析之事件机制——观察者模式(一)

目录 事件基类定义 事件监听器接口 事件发布者接口及实现 事件广播器实现 小小总结 Spring源码分析之事件机制——观察者模式&#xff08;一&#xff09;-CSDN博客 Spring源码分析之事件机制——观察者模式&#xff08;二&#xff09;-CSDN博客 Spring源码分析之事件机制…...

安卓14无法安装应用解决历程

客户手机基本情况&#xff1a; 安卓14&#xff0c;对应的 targetSdkVersion 34 前天遇到了安卓14适配问题&#xff0c;客户发来的截图是这样的 描述&#xff1a;无法安装我们公司的B应用。 型号&#xff1a;三星google美版 解决步骤&#xff1a; 1、寻找其他安卓14手机测试…...

BGP(Border Gateway Protocol)路由收集器

全球 BGP&#xff08;边界网关协议&#xff09;路由收集器的分布情况以及相关数据。以下是主要的信息解读&#xff1a; 地图标记&#xff1a; 每个绿色点代表一个路由收集器的位置。路由收集器分布在全球不同的地区&#xff0c;覆盖了五大区域&#xff1a; ARIN&#xff08;美…...

Vue.js与其他框架有哪些兼容性?

Vue.js的兼容性主要体现在几个方面&#xff0c;包括浏览器支持、运行环境适应性、与其他库和框架的集成能力等。以下是更详细的解释&#xff1a; 浏览器兼容性 现代浏览器&#xff1a;Vue.js广泛支持所有主流的现代浏览器&#xff0c;如Google Chrome, Firefox, Safari, Edge…...

深度解析与实践:HTTP 协议

一、引言 HTTP&#xff08;HyperText Transfer Protocol&#xff0c;超文本传输协议&#xff09;是 Web 应用程序、API、微服务以及几乎所有互联网通信的核心协议。虽然它是我们日常使用的基础技术&#xff0c;但要深刻理解其高效使用、优化以及如何避免性能瓶颈&#xff0c;我…...

MyBatis 配置文件全解析

一、MyBatis 配置文件为何至关重要&#xff1f; 在 Java 后端开发领域&#xff0c;MyBatis 作为一款广受欢迎的持久层框架&#xff0c;极大地简化了数据库操作。而 MyBatis 配置文件&#xff0c;恰似整个框架的 “神经中枢”&#xff0c;掌控着其运行的方方面面&#xff0c;对…...

redis Redis内存缓存过期机制

起因&#xff1a;随着项目的进一步推广&#xff0c;数据量的增大&#xff0c;直接访问mysql数据库获取数据所使用的时间越来越长&#xff0c;为解决当前主要矛盾&#xff0c;决定引入redis非关系型数据库作为缓存层&#xff0c;使得数据并不能直接命中数据库&#xff0c;减少访…...

游戏关卡设计的常用模式

游戏关卡分为很多种&#xff0c;但常用的有固定套路&#xff0c;分为若干种类型。 关卡是主角与怪物、敌方战斗的场所&#xff0c;包括装饰物、通道。 单人游戏的关卡较小&#xff0c;偏线性&#xff1b; 联机/MMO的关卡较大&#xff0c;通道多&#xff0c;自由度高&#xf…...

计算机网络常见面试题及解答

以下是计算机网络中常见的面试题及解答&#xff0c;按主题分类&#xff1a; --- ## **一、基础概念** ### **1. OSI 七层模型和 TCP/IP 模型的区别是什么&#xff1f;** **答&#xff1a;** - **OSI 七层模型&#xff1a;** - 应用层、表示层、会话层、传输层、网络层、数…...

SUB输入5V升压充电16.8V芯片HU5912

HU5912芯片&#xff0c;作为航誉微电子有限公司推出的一款高性能升压充电管理IC&#xff0c;自其面世以来&#xff0c;便以其出色的性能和广泛的应用领域&#xff0c;受到了业界的高度关注和赞誉。本文将详细介绍HU5912芯片的技术特点、应用优势、市场定位以及其在各类电子设备…...

基于Informer网络实现电力负荷时序预测——cross validation交叉验证与Hyperopt超参数调优

前言 系列专栏:【深度学习&#xff1a;算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域&#xff0c;讨论了各种复杂的深度神经网络思想&#xff0c;如卷积神经网络、循环神经网络、生成对…...

linux ubantu重启桌面

在 Ubuntu 系统中&#xff0c;重启桌面环境通常有几种方法&#xff0c;具体取决于你所使用的桌面环境&#xff08;如 GNOME、KDE 等&#xff09;。下面是几种常用的重启桌面的方法&#xff1a; 重启 GNOME 桌面环境 如果你使用的是 GNOME 桌面环境&#xff08;Ubuntu 默认桌面…...

C++Primer const限定符

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…...

【机器学习】机器学习的基本分类-自监督学习(Self-supervised Learning)

自监督学习是一种机器学习方法&#xff0c;介于监督学习和无监督学习之间。它通过数据本身生成标签&#xff0c;创建训练任务&#xff0c;从而学习数据的表征&#xff0c;而不需要人工标注的标签。这种方法在减少标注数据依赖、提高模型通用性等方面具有重要意义。 自监督学习的…...

python基础案例

#一个年份如果能被4整除但不能被 100整除&#xff0c;或能被 400整除&#xff0c;那么这个年份就是闰年。 year int(input(请输入年份&#xff1a;)) if (year %40 and year %100!0) or year %4000:print("这个年份就是闰年") else:print("这个年份不是闰…...

ARP(地址解析协议)攻击;TCP SYN Flood(SYN洪流)攻击

ARP&#xff08;地址解析协议&#xff09;攻击 是一种网络攻击类型&#xff0c;攻击者利用ARP协议的缺陷对目标网络实施攻击。ARP协议用于在局域网&#xff08;LAN&#xff09;中将IP地址解析为MAC地址&#xff0c;它是无认证机制的&#xff0c;这为攻击者提供了可利用的机会。…...

基于大数据爬虫+Python+数据可视化大屏的慧游数据爬虫与推荐分析系统(源码+论文+PPT+部署文档教程等)

博主介绍&#xff1a;**CSDN毕设辅导第一人、**全网粉丝50W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流 **技术范围&#xff1a;**S…...

Linux系统安装es详细教程

一、下载es及插件 从下面的网址进行对应es版本的下载https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.15.2-linux-x86_64.tar.gz &#xff0c;想要不同版本的es只需更换对应的版本号即可。 插件下载地址&#xff08;ik分词器、pinyin等&#xff09;es…...

分布式搜索引擎之elasticsearch基本使用3

分布式搜索引擎之elasticsearch基本使用3 1.部署单点es 1.1.创建网络 因为我们还需要部署kibana容器&#xff0c;因此需要让es和kibana容器互联。这里先创建一个网络&#xff1a; docker network create es-net1.2.加载镜像 这里我们采用elasticsearch的7.12.1版本的镜像&…...

进程间通信-----信号

进程间通信-----信号 信号&#xff1a;进程间异步通知的机制。是一种在操作系统中用于进程间通信和控制的机制。它可以用于多种场景&#xff0c;例如进程间通信、异常处理、线程同步等。常见的信号有SIGINT&#xff08;中断信号&#xff09;、SIGTERM&#xff08;终止信号&…...

机器学习基础-线性回归和逻辑回归

目录 基本概念和定义 线性回归 逻辑回归 线性回归中的最小二乘法和梯度下降法 最小二乘法 梯度下降法 参数调整策略 梯度下降类型 梯度下降的调参的基本操作 过拟合和欠拟合的概念及处理方法 过拟合&#xff08;Overfitting&#xff09; 欠拟合&#xff08;Underfi…...

低代码引擎插件开发:开启开发的便捷与创新之路

OneCode授权演示 一、低代码引擎与插件开发的概述 在当今快节奏的软件开发领域&#xff0c;低代码引擎正逐渐崭露头角。低代码引擎旨在让开发人员能够以最少的代码量创建功能丰富的应用程序&#xff0c;而其中的关键组成部分便是插件开发。低代码引擎通过提供可视化的开发环境…...