什么是基础设施中间件

前言

本文说说基础设施中间件这个概念,英文是 infrastructure middleware

正文

1. 什么是基础设施中间件?

简单说,基础设施中间件就是软件的"公共设施"

它不直接处理你的业务(比如"下单"或"支付"),但它为所有处理业务的软件提供基础支撑 ,让它们能互相通信、存储数据、协调工作

2. 它主要涉及哪些知识?(四大件)

你可以把它想象成软件世界的四大基础设施:

  1. 消息队列

    • 是啥:软件 A 把消息(比如一个"新订单")扔到一个地方,就溜了;软件 B 在有空的时候,从"这个地方"取出数据来处理。
    • 作用解耦削峰填谷。防止一个系统忙死,另一个系统闲死。
    • 🌰:Kafka, RabbitMQ
  2. 缓存

    • 是啥:一个"高速工作台"。把最常用、最热门的数据(比如商品信息、热门文章)放在这里,读取速度极快。为什么快?因为数据存放在内存里,避免了缓慢的磁盘读写,实现了纳秒级的直接访问。
    • 作用提速。减少去慢速的"大仓库"(数据库)里翻找的次数。
    • 🌰 :Redis, Memcached 📚 补充知识 1:Memcached 和 Redis 的区别是什么?📚:

      Memcached 是追求简单高效的分布式内存缓存,仅支持键值对数据结构; Redis 是功能更丰富的内存数据存储,支持多种数据结构、持久化及复杂操作,在满足缓存需求的同时能处理更多场景。

      📚 补充知识 2:磁盘和内存的区别是什么?📚:

      磁盘是数据的"仓库",用于长期、海量存储;内存是数据的"工作台",CPU 直接从这里高速处理当前任务的数据。程序和数据平时存放在磁盘这个"仓库"里,当需要运行时,就会被加载到内存这个"工作台"上,供 CPU 快速取用和处理,处理完的结果如果需要长期保存,再写回磁盘。🍃

  3. 配置中心

    • 是啥:一个"中央控制面板"。所有软件的配置信息(比如开关、参数)都放在这里统一管理。
    • 作用集中管理动态调整。想改个参数,不用一个个去改每个软件,在这里改一下,所有软件自动生效。
    • 🌰:Nacos, Apollo, Consul
  4. 分布式协调/服务发现

    • 是啥:一个"电话总机"或"服务注册簿"。当你有成百上千个服务时,服务 A 想找服务 B,不用记 IP 地址,直接问这个"总机"就行。
    • 作用服务治理。让众多服务能互相找到、协同工作,并管理它们的状态。
    • 🌰:Zookeeper, Nacos, Etcd

最后

文章的最后,简单总结一下基础设施中间件 ✨:

  • 它是什么:软件的"公共设施"和"粘合剂"。
  • 它的目的 :让复杂的软件系统能更稳定、更快速、更灵活地协同工作。
  • 核心知识 ⭐ :主要围绕 消息、缓存、配置、服务协调 这四大方面。

大多数业务场景下,你不需要知道它们内部具体怎么造,只需要知道它们是构建现代大型软件(比如淘宝、微信)的基石就行了,现代社会离不开他们的。

就像我们用水用电,不需要知道发电厂和自来水厂怎么工作一样。

相关推荐
知识分享小能手3 小时前
微信小程序入门学习教程,从入门到精通,WXML(WeiXin Markup Language)语法基础(8)
前端·学习·react.js·微信小程序·小程序·vue·个人开发
海绵宝龙3 小时前
将若依(RuoYi)项目创建为私有Gitee仓库的完整步骤
前端·gitee
ps_xiaowang4 小时前
React Query入门指南:简化React应用中的数据获取
前端·其他·react native·react.js
知识分享小能手5 小时前
微信小程序入门学习教程,从入门到精通,微信小程序开发进阶(7)
前端·javascript·学习·程序人生·微信小程序·小程序·vue3
canonical_entropy6 小时前
NopGraphQL 的设计创新:从 API 协议到通用信息操作引擎
后端·低代码·graphql
sophie旭6 小时前
一道面试题,开始性能优化之旅(8)-- 构建工具和性能
前端·面试·性能优化
市民中心的蟋蟀6 小时前
第三章 钩入React 【上】
前端·react.js·架构
Holin_浩霖7 小时前
为什么typeof null 返回 "object" ?
前端
PanZonghui7 小时前
Zustand 实战指南:从基础到高级,构建类型安全的状态管理
前端·react.js