中间件有哪些分类?
中间件的分类
中间件是位于操作系统和应用程序之间的软件,它提供了一系列服务来简化分布式系统中的应用程序开发和集成。中间件可以根据其功能和用途被分为不同的类别。以下是中间件的一些主要分类:
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…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘
美国西海岸的夏天,再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至,这不仅是开发者的盛宴,更是全球数亿苹果用户翘首以盼的科技春晚。今年,苹果依旧为我们带来了全家桶式的系统更新,包括 iOS 26、iPadOS 26…...
基于Flask实现的医疗保险欺诈识别监测模型
基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施,由雇主和个人按一定比例缴纳保险费,建立社会医疗保险基金,支付雇员医疗费用的一种医疗保险制度, 它是促进社会文明和进步的…...
解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八
现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet,点击确认后如下提示 最终上报fail 解决方法 内核升级导致,需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...
python爬虫:Newspaper3k 的详细使用(好用的新闻网站文章抓取和解析的Python库)
更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、Newspaper3k 概述1.1 Newspaper3k 介绍1.2 主要功能1.3 典型应用场景1.4 安装二、基本用法2.2 提取单篇文章的内容2.2 处理多篇文档三、高级选项3.1 自定义配置3.2 分析文章情感四、实战案例4.1 构建新闻摘要聚合器…...
Python如何给视频添加音频和字幕
在Python中,给视频添加音频和字幕可以使用电影文件处理库MoviePy和字幕处理库Subtitles。下面将详细介绍如何使用这些库来实现视频的音频和字幕添加,包括必要的代码示例和详细解释。 环境准备 在开始之前,需要安装以下Python库:…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...
根目录0xa0属性对应的Ntfs!_SCB中的FileObject是什么时候被建立的----NTFS源代码分析--重要
根目录0xa0属性对应的Ntfs!_SCB中的FileObject是什么时候被建立的 第一部分: 0: kd> g Breakpoint 9 hit Ntfs!ReadIndexBuffer: f7173886 55 push ebp 0: kd> kc # 00 Ntfs!ReadIndexBuffer 01 Ntfs!FindFirstIndexEntry 02 Ntfs!NtfsUpda…...
手机平板能效生态设计指令EU 2023/1670标准解读
手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读,综合法规核心要求、最新修正及企业合规要点: 一、法规背景与目标 生效与强制时间 发布于2023年8月31日(OJ公报&…...
Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析
Java求职者面试指南:Spring、Spring Boot、Spring MVC与MyBatis技术解析 一、第一轮基础概念问题 1. Spring框架的核心容器是什么?它的作用是什么? Spring框架的核心容器是IoC(控制反转)容器。它的主要作用是管理对…...
