中间件有哪些分类?
中间件的分类
中间件是位于操作系统和应用程序之间的软件,它提供了一系列服务来简化分布式系统中的应用程序开发和集成。中间件可以根据其功能和用途被分为不同的类别。以下是中间件的一些主要分类:
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…...

智慧医疗能源事业线深度画像分析(上)
引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合
强化学习(Reinforcement Learning, RL)是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程,然后使用强化学习的Actor-Critic机制(中文译作“知行互动”机制),逐步迭代求解…...

shell脚本--常见案例
1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...
uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖
在前面的练习中,每个页面需要使用ref,onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入,需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...

CocosCreator 之 JavaScript/TypeScript和Java的相互交互
引擎版本: 3.8.1 语言: JavaScript/TypeScript、C、Java 环境:Window 参考:Java原生反射机制 您好,我是鹤九日! 回顾 在上篇文章中:CocosCreator Android项目接入UnityAds 广告SDK。 我们简单讲…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

全志A40i android7.1 调试信息打印串口由uart0改为uart3
一,概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本:2014.07; Kernel版本:Linux-3.10; 二,Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01),并让boo…...

面向无人机海岸带生态系统监测的语义分割基准数据集
描述:海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而,目前该领域仍面临一个挑战,即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...

[大语言模型]在个人电脑上部署ollama 并进行管理,最后配置AI程序开发助手.
ollama官网: 下载 https://ollama.com/ 安装 查看可以使用的模型 https://ollama.com/search 例如 https://ollama.com/library/deepseek-r1/tags # deepseek-r1:7bollama pull deepseek-r1:7b改token数量为409622 16384 ollama命令说明 ollama serve #:…...