中间件有哪些分类?
中间件的分类
中间件是位于操作系统和应用程序之间的软件,它提供了一系列服务来简化分布式系统中的应用程序开发和集成。中间件可以根据其功能和用途被分为不同的类别。以下是中间件的一些主要分类:
1. 通信处理(消息)中间件:
- 这种中间件支持异步通信,允许应用程序之间通过消息传递进行交互,确保了分布式系统中的可靠、高效和实时的跨平台数据传输。
- 支持发布/订阅模式、点对点模式等。
- 示例:RabbitMQ、Apache Kafka、RocketMQ等。

2. 事务处理(交易)中间件:
- 该类中间件管理分布式事务,确保事务的ACID属性,支持大量并发事务的处理,并提供故障恢复和系统自动切换的功能。
- 保证分布式环境下的数据一致性。
- 例如两阶段提交协议(2PC)就是一种典型的事务处理机制。
- 示例:Java事务API(JTA)、Seata、Microsoft分布式事务协调器(MSDTC)等。

3. 数据存取管理中间件:
- 提供数据库的统一访问接口,简化数据库操作,支持数据的缓存、格式转换和解压等。
- 用于管理和访问数据库,提供连接池、缓存和查询优化等服务,以提高数据库性能和管理数据访问。
- 提供统一的数据访问接口,屏蔽底层数据库的具体实现细节。
- 示例:MySQL Proxy、PostgreSQL PgBouncer、MyBatis、Hibernate、Oracle TimesTen等。

4. Web服务器或应用服务器中间件:
- 提供面向基于Web的应用程序的服务,包括处理HTTP请求、会话管理和安全性。
- 提供HTTP服务,支持动态内容生成。
- 如Apache HTTP Server, Nginx, Tomcat、WebLogic、Jboss等。

5. 安全中间件:
- 提供认证、授权、加密和访问控制等安全服务,保护应用程序和数据的安全。
- 提供身份验证、授权等功能,保护应用程序的安全性。
- 如OAuth、OpenID Connect、SAML, Kerberos等协议相关的实现。

6. 跨平台和架构的中间件:
- 支持跨不同操作系统和硬件平台的应用开发,如Java虚拟机和.NET Framework。

7. 专用平台中间件:
- 针对特定应用或平台提供优化的中间件服务,如Android SDK和iOS SDK。

8. 网络中间件:
- 提供网络通信的基础设施,如协议转换和网络连接管理。

9. 集成中间件:
- 促进异构系统和数据格式的集成,提供路由、转换和中介功能,如企业服务总线(ESB)。
- 用来集成不同应用和服务,提供松耦合的服务交互。
- MuleSoft, IBM Integration Bus,MuleSoft Anypoint Platform、Apache Camel等。

10. 数据库中间件:
- 在应用程序和数据库之间提供服务,如连接池、缓存和查询优化。
以下是一些常见的数据库中间件分类及其代表产品:
1.读写分离中间件
- MyCAT:一个开源的分布式数据库中间件,实现了MySQL协议,支持读写分离、分库分表等功能。
- Atlas:由360公司开发的MySQL协议数据库中间件,提供读写分离、负载均衡、故障切换等核心功能。
2.数据分片中间件
- Sharding-JDBC:阿里巴巴开源的轻量级Java框架,专门用于数据库分片,支持JDBC级别的透明读写分离。
- DRDS:阿里云提供的分布式关系型数据库服务,支持分库分表、平滑扩容、服务升降配等特性。
3.数据库连接池中间件
- C3P0:一个为Java应用程序提供数据库连接池功能的开源框架。
- HikariCP:一个高性能的Java JDBC连接池,以其速度快和资源占用少而著称。
4.数据库代理中间件
- ProxySQL:一个高性能的数据库代理,支持连接池、读写分离、负载均衡、故障切换等特性。
- MaxScale:MariaDB Corporation开发的数据库智能代理,提供高可用性、可伸缩性和安全性。
5.数据库统一访问中间件
- OpenDDAL:一个开源的数据库中间件,提供统一的数据访问接口,支持多种异构数据库系统。
6.数据库监控和管理中间件
- 阿里云EDAS:提供应用托管与服务治理,支持Dubbo应用,包括数据库性能监控和管理功能。

11. 缓存中间件:
- 用于管理和提供缓存服务,以加快数据访问速度并减轻后端系统的负载。
- 通过将常用数据存储在内存中来提高数据访问速度。
- 例如Redis, Memcached等。

12. API网关中间件:
- 管理和控制API的访问和调用,提供安全性、限流、监控等功能。
- 作为系统的单一入口点,管理API的访问,并可能包含认证、限流、日志记录等功能。
- Kong、Apigee、AWS API Gateway等。

13. 搜索中间件:
- 用于构建搜索功能和实现全文搜索,提供索引和搜索引擎功能。
- 示例:Elasticsearch、Apache Solr等。

14. 虚拟化中间件:
- 提供虚拟化技术,将物理资源抽象为虚拟资源,以实现资源的灵活管理和利用。
- 示例:VMware、KVM等。
15. 流程中间件:
- 用于管理和协调业务流程和工作流程,提供流程引擎和工作流引擎来定义、执行和监控流程。
- 示例:Activiti、Camunda等。
16. 对象请求代理(ORB)中间件:
- 用于支持面向对象的分布式计算。
- CORBA (Common Object Request Broker Architecture)是一个标准的ORB架构。
17. 远程过程调用(RPC)中间件:
- 允许一个程序在另一台计算机上执行子程序。
- gRPC, Apache Thrift, Java RMI (Remote Method Invocation)都是RPC中间件的例子。
中间件的分类并不是固定不变的,随着技术的发展和创新,新的中间件类型可能会出现,因此中间件的分类是一个不断演变的领域。在选择中间件时,应根据具体的需求和应用场景来挑选合适的中间件产品。
相关文章:
中间件有哪些分类?
中间件的分类 中间件是位于操作系统和应用程序之间的软件,它提供了一系列服务来简化分布式系统中的应用程序开发和集成。中间件可以根据其功能和用途被分为不同的类别。以下是中间件的一些主要分类: 1. 通信处理(消息)中间件&am…...
开始新征程__10.13
好久没有更新 csdn 了,身边的人都说 csdn 水,但是在我看来,它在我大一这一年里对我的帮助很大,最近上账号看看,看见了网友评论,哈哈,决定以后还是继续更新,分享自己的学习心得。...
SAP 联合创始人谈Home Office
软件公司 SAP 的家庭办公室规定继续引发激烈争论,其联合创始人哈索-普拉特纳(Hasso Plattner)对此也有明确看法。 沃尔多夫--年初,SAP 首席执行官克里斯蒂安-克莱因(Christian Klein)向员工宣誓 "努力…...
基于Jenkins+K8S构建DevOps自动化运维管理平台
目录 1.k8s助力DevOps在企业落地实践 1.1 传统方式部署项目为什么发布慢,效率低? 1.2 上线一个功能,有多少时间被浪费了? 1.3 如何解决发布慢,效率低的问题呢? 1.5 什么是DevOps? 1.5.1 敏…...
【OpenCV】(一)—— 安装opencv环境
【OpenCV】(一)—— 安装opencv环境 OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库。OpenCV 是用 C 编写的,但它也有 Python、Java 和 MATLAB 接口,并支持 Windows…...
MybatisPlus操作符和运算值
好久没有更新了,这次更新一个当前端需要对运算符和运算值都需要前端传递给后端,动态拼接运算条件时的处理方法。 1、踩雷 查询年龄 >20,其中>前端下拉框选择,20值前端下拉框选择 1)用户表: CREAT…...
Index-1.9B模型部署教程
一、介绍 Index-1.9B 系列是 Index 系列型号的轻量级版本,包含以下型号: Index-1.9B 基础:具有 19 亿个非嵌入参数的基础模型,在 2.8T 主要为中文和英文的语料上进行预训练,在多个评测基准上与同级别模型相比领先。I…...
C语言 | Leetcode C语言题解之第468题验证IP地址
题目: 题解: char * validIPAddress(char * queryIP) {int len strlen(queryIP);if (strchr(queryIP, .)) {// IPv4int last -1;for (int i 0; i < 4; i) {int cur -1;if (i 3) {cur len;} else {char * p strchr(queryIP last 1, .);if (p…...
Qt自定义一个圆角对话框
如何得到一个圆角对话框? 步骤: 1、继承自QDiaglog 2、去掉系统自带的边框 3、设置背景透明,不设置4个角会有多余的部分出现颜色 4、对话框内部添加1个QWidget,给这个widget设置圆角,并添加到布局中让他充满对话框 5、后续对…...
C++ 中的自旋锁应用:SpinLockManual、SpinLockGuard 和 SpinLockTryGuard
在多线程编程中,同步机制是确保线程安全的关键。自旋锁(Spin Lock)是一种常见的同步机制,它通过忙等待(busy-waiting)的方式来实现线程间的互斥访问。在 C++ 中,我们可以使用 std::atomic_flag 来实现自旋锁。本文将介绍如何使用 SpinLockManual、SpinLockGuard 和 Spin…...
计算机网络 tcp和udp
目录 一、TCP 建立连接-TCP 三次握手 1) 什么是半连接队列和全连接队列? 2) 为什么要三次握手? 3) 三次握手过程中可以携带数据吗? 断开连接-TCP 四次挥手 1) 为什么要四次挥手? 2&…...
React(一) 认识React、熟悉类组件、JSX书写规范、嵌入变量表达式、绑定属性
文章目录 一、初始React1. React的基本认识2. Hello案例2.1 三个依赖2.2 渲染页面2.3 hello案例完整代码 二、类组件1. 封装类组件2. 组件里的数据3. 组件里的函数 (重点)4. 案例练习(1) 展示电影列表 三、JSX语法1. 认识JSX2. JSX书写规范及注释3. JSX嵌入变量作为子元素4. JS…...
计算机网络 2024 11 10
计算机网络 - 知乎计算机网络(四)—— 网络层(1、2):网络层概述、网络层提供的两种服务_以下属于网络层范畴的是a透明传输比特流b媒体接入控制c ip地址d-CSDN博客 湖科大教书匠的个人空间-湖科大教书匠个人主页-哔哩哔…...
King3399(ubuntu文件系统)风扇驱动
该文章仅供参考,编写人不对任何实验设备、人员及测量结果负责!!! 0 引言 文章主要介绍King3399(ubuntu文件系统)风扇控制(GPIO),涉及king-rk3399.dts设备树修改&#x…...
前端开发笔记--html 黑马程序员2
文章目录 前端常用标签一、标题标签二、段落标签和换行标签和水平线标签三、文本格式化标签四、盒子标签五、图像标签六、连接标签七、注释和特殊字符 八、表格标签的基本使用九、列…...
django(二):定义第一个函数及url介绍
1.定义index函数 """ django里的第一个函数必须是request,不写会报错 """def index(request):return HttpResponse("Hello, world. Youre at the index of djangoProject.")注意! ①.index函数里的形参必须为request ②.r…...
66 消息队列
66 消息队列 基础概念 参考资料:消息队列MQ快速入门(概念、RPC、MQ实质思路、队列介绍、队列对比、应用场景) 消息队列就是一个使用队列来通信的组件;为什么需要消息队列? 在实际的商业项目中,它这么做肯…...
【系统分析师】-案例篇-信息系统安全
1、信息系统的安全威胁 来自于物理环境、通信链路、网络系统、操作系统、应用系统以及管理等多个方面。 物理安全威胁是指对系统所用设备的威胁,如自然灾害、电源故障、数据库故障和设备被盗等造成数据丢失或信息泄漏。 通信链路安全威胁是指在传输线路上安装窃…...
基于极光优化算法(Polar Lights Optimization, PLO)的多无人机协同三维路径规划(提供MATLAB代码)
一、极光优化算法介绍 极光优化算法(Polar Lights Optimization, PLO)是2024年提出的一种新型的元启发式优化算法,它从极光这一自然现象中汲取灵感。极光是由太阳风中的带电粒子在地球磁场的作用下,与地球大气层中的气体分子碰撞…...
TypeScript类型体操5
类型编程主要的目的就是对类型做各种转换,如何对类型做修改? TypeScript 类型系统支持 3 种可以声明任意类型的变量: type、infer、类型参数。 type:类型别名,声明一个变量存储某个类型。type t Promise<number&g…...
Flash内容重生:CefFlashBrowser如何让经典Flash游戏与课件重获新生
Flash内容重生:CefFlashBrowser如何让经典Flash游戏与课件重获新生 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 你是否还在怀念那些曾经风靡一时的Flash游戏?是…...
用STM32F411+LVGL+FreeRTOS做个小玩意:从零打造一个桌面级健康监测仪(附完整源码和PCB)
从零打造桌面级健康监测仪:STM32F411LVGLFreeRTOS全栈实战 在创客圈里,把一堆传感器和屏幕拼凑成能用的设备不算难事,但要做成能长期摆在桌面上、看着不违和的实用工具,完全是另一个维度的挑战。去年我用了三个月时间迭代了四版原…...
YimMenu终极指南:5大核心功能打造安全的GTA5增强体验
YimMenu终极指南:5大核心功能打造安全的GTA5增强体验 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/YimMe…...
ESP8266轻量Web服务器库myWebServerESP深度解析
1. myWebServerESP:面向ESP8266/NODEMCU的轻量级嵌入式Web服务器库深度解析1.1 项目定位与工程价值myWebServerESP是一个专为 ESP8266 系列芯片(含 NodeMCU 开发板)设计的轻量级、可配置 Web 服务框架,运行于 Arduino IDE 生态下。…...
ESP32高精度低延迟ADC自定义库:寄存器级模拟读取优化
1. 项目概述ESP32AnalogRead Custom是由嵌入式开发者 Khrisna Ijlal Bachri 针对 ESP32 系列微控制器定制优化的模拟输入读取库。该库并非官方 ESP-IDF ADC 驱动的简单封装,而是聚焦于解决实际工程中高频采样、多通道同步、噪声抑制与低功耗场景下的典型痛点。其核心…...
网盘直链下载助手:告别限速困扰,八大平台一键高速下载终极指南
网盘直链下载助手:告别限速困扰,八大平台一键高速下载终极指南 【免费下载链接】Online-disk-direct-link-download-assistant 可以获取网盘文件真实下载地址。基于【网盘直链下载助手】修改(改自6.1.4版本) ,自用&…...
Python AI部署效能革命(Cuvil编译器内核逆向工程实录)
第一章:Python AI部署效能革命的底层驱动力Python 已成为 AI 模型开发的事实标准,但其在生产环境中的部署效能长期受限于解释执行、全局解释器锁(GIL)及内存管理机制。近年来,一场静默却深刻的效能革命正在重塑 Python…...
LingBot-Depth部署教程:Docker Compose编排+模型缓存卷自动初始化
LingBot-Depth部署教程:Docker Compose编排模型缓存卷自动初始化 1. 引言:从稀疏数据到精准3D测量 你有没有遇到过这样的场景?手头有一个深度摄像头,但采集到的深度图总是零零散散,像一张被撕破的旧地图,…...
腾讯验证码攻防新篇:六宫格、滑块与文字识别的毫秒级破解实战
1. 腾讯验证码体系深度解析 腾讯验证码作为当前互联网安全防护的重要组成部分,已经发展出包括六宫格、图标点选、滑块验证和文字识别在内的多种形式。这些验证码在设计时充分考虑了人机交互的特点,通过视觉识别和行为分析双重机制来区分真实用户和自动化…...
ONNX Runtime C++部署踩坑记:GetInputName已弃用,手把手教你改用GetInputNameAllocated
ONNX Runtime C部署实战:从GetInputName到GetInputNameAllocated的平滑迁移指南 在深度学习模型部署的生态系统中,ONNX Runtime凭借其跨平台特性和高性能推理能力,已成为工业界广泛采用的推理引擎。然而,随着其C API的迭代升级&a…...
