系统架构设计(四):架构风格总结
黑板
概念
黑板体系架构是一种用于求解复杂问题的软件架构风格,尤其适合知识密集型、推理驱动、数据不确定性大的场景。
它模拟了人类专家协同解决问题的方式,通过一个共享的“黑板”协同多个模块(专家)逐步构建解决方案。
组成结构
黑板架构通常包含三个主要部分:
- 黑板(Blackboard)
- 一个全局共享的内存数据结构,存放系统当前的状态、假设、中间结果等。
- 所有模块都可以读取和写入,但通常通过控制组件协调。
- 知识源/专家模块(Knowledge Sources,KS)
- 一组独立的、专注于特定任务的功能模块。
- 被动响应型:监听黑板变化,当发现适合自身处理的状态时激活,执行操作并更新黑板。
- 控制组件(Control Component)
- 负责管理各个知识源的执行顺序,选择最合适的模块在当前状态下执行。
- 可实现调度策略,如优先级驱动、数据依赖驱动等。
工作机制(流程)
- 初始化黑板,写入初始数据;
- 控制组件调度合适的知识源;
- 被调度的知识源处理黑板中的数据并写回结果;
- 黑板变化后再次触发新的知识源;
- 如此循环,直到满足终止条件或达到目标状态。
优缺点
优点
- 模块高度解耦,方便扩展与维护
- 易于处理复杂、开放性问题
- 支持多专家协作解决方案,适合并行处理
- 灵活应对动态变化的问题环境
缺点
- 控制策略复杂,实现难度高
- 系统调试和性能优化不易
- 不适用于结构简单或问题流程确定性强的系统
典型应用场景
- 语音识别系统
- 图像处理与目标识别
- 智能决策支持系统
- 自动推理系统(如专家系统)
管道-过滤器
概念
元素 | 描述 |
---|---|
过滤器(Filter) | 自包含的处理单元,接收输入、处理后输出结果,不依赖上下文。 |
管道(Pipe) | 连接过滤器的数据传输通道,负责传递数据流。 |
架构特点
优点:
- 高内聚低耦合:每个过滤器职责单一,易于重用和维护。
- 易扩展:可通过添加或替换过滤器轻松扩展功能。
- 支持并行处理:过滤器可以并行运行,提升系统性能。
- 可复用性强:过滤器模块可以在不同系统中重复使用。
缺点:
- 数据格式统一要求高:管道中传递的数据格式必须兼容。
- 处理时延可能大:数据需依次通过多个过滤器,可能带来延迟。
- 状态管理困难:不适合需要复杂状态共享的处理逻辑。
应用场景
- 编译器(词法分析 → 语法分析 → 语义分析 → 代码生成)
- 图像处理(读入 → 灰度化 → 边缘检测 → 渲染)
- 多媒体流处理(如 FFmpeg)
- 日志处理与数据清洗
- 数据管道(ETL:Extract → Transform → Load)
示意图
数据源 → [过滤器1] → [过滤器2] → [过滤器3] → 输出↓ ↓ ↓Pipe1 Pipe2 Pipe3
设计要点
- 过滤器接口标准化:统一输入/输出格式,定义处理协议。
- 解耦设计:过滤器不应感知管道或其他过滤器的存在。
- 错误处理:提供统一的异常传递或中断机制。
- 可组合性:过滤器应支持任意组合使用。
客户端-服务器
概念
客户端-服务器架构 是一种分布式应用模型,系统被划分为两部分:
- 客户端(Client):发起请求,处理用户交互。
- 服务器(Server):接收请求,提供服务与资源。
客户端与服务器通过网络通信,通常使用 HTTP、TCP/IP 等协议。
结构图
[客户端1] [客户端2] [客户端N]| | |+---------------+---------------+↓[服务器 / 服务端]
特点
特点 | 描述 |
---|---|
分离关注点 | 客户端负责表示和交互,服务器负责数据和逻辑处理。 |
集中管理 | 服务器统一管理资源、用户、权限等,便于维护。 |
可扩展性 | 客户端可随时接入多个,服务器可扩容或负载均衡。 |
可维护性强 | 服务器逻辑更新无需更改客户端。 |
优缺点
优点
- 结构清晰、职责分离。
- 资源集中,便于管理和备份。
- 支持多客户端接入。
- 安全性好,权限统一控制。
缺点
- 单点瓶颈:服务器若出故障,所有客户端都受影响。
- 维护成本高:服务器需高可用、并发处理能力强。
- 网络依赖:客户端对网络连接有一定要求。
应用场景
- Web 应用(浏览器 ⇄ Web 服务器)
- 移动 App(App ⇄ 后端 API)
- 网络游戏(玩家 ⇄ 游戏服务器)
- 数据库系统(客户端 ⇄ 数据库服务器)
- 邮件系统、FTP 等
设计要点
- 接口设计:统一请求格式(如 REST、gRPC)。
- 权限认证:如 OAuth、Token、Session。
- 并发处理:服务器需支持高并发访问(线程池、协程等)。
- 负载均衡与扩展性:使用反向代理、集群。
- 故障恢复:部署容错机制与备份服务器。
发布-订阅
概念
发布-订阅架构(Pub/Sub)是一种消息驱动的通信模式,通信双方通过事件(消息)中介进行交互:
- 发布者(Publisher):产生消息,不直接指定接收者。
- 订阅者(Subscriber):注册感兴趣的消息类型。
- 消息代理(Broker):中间件,负责路由消息给所有符合条件的订阅者。
结构图
[Publisher1] [Publisher2]| |+--------+-----------+↓[消息代理 / Broker]↓+--------+--------+| |
[Subscriber1] [Subscriber2]
特点
特点 | 描述 |
---|---|
解耦合 | 发布者和订阅者互不感知,只依赖消息代理。 |
异步通信 | 发布后立即返回,不等待响应。 |
多对多通信 | 一条消息可被多个订阅者接收。 |
事件驱动 | 系统围绕事件(消息)流动进行运作。 |
优缺点
优点
- 高解耦:系统模块间零耦合,便于扩展和替换。
- 可扩展性强:容易水平扩展发布者/订阅者。
- 灵活性高:支持动态订阅、动态扩展功能。
缺点
- 调试困难:消息异步、分布式,难定位问题。
- 消息可靠性需保障:需要处理丢失、重复、顺序等问题。
- 依赖中间件:系统强依赖消息代理的稳定性和吞吐能力。
应用场景
- 日志收集系统(如 ELK、Fluentd)
- 事件驱动系统(如用户注册事件 → 发邮件、统计日志)
- 微服务通信(如 Kafka、RabbitMQ、Redis Pub/Sub)
- IoT 设备数据推送
- 聊天系统 / 通知系统
关键设计要点
- 主题(Topic)/频道(Channel)机制:消息分类基础。
- 消息传递语义:
- 至少一次(At least once)
- 至多一次(At most once)
- 精确一次(Exactly once)
- 持久化与重放:是否保存历史消息、支持离线订阅者。
- 顺序保证:是否要求消息有序。
- 容错与高可用性:中间件的高可用部署(集群、主从、分片)。
常见实现
中间件 | 特点 |
---|---|
Kafka | 高吞吐、可持久化、支持消息重放和分区顺序 |
RabbitMQ | 高灵活性、路由机制丰富、支持事务 |
Redis Pub/Sub | 轻量级,适用于内网通知,不支持持久化 |
MQTT | 面向 IoT,轻量协议,支持断线续传 |
NATS | 高性能、云原生友好 |
总结
架构风格 | 特点 | 适用场景 |
---|---|---|
黑板架构 | 多模块协作、共享数据驱动、控制策略灵活 | 不确定性问题求解 |
管道-过滤器 | 数据流动线性,模块串联 | 数据处理流水线 |
客户端-服务器 | 明确的请求/响应模式 | 网络服务、Web系统 |
发布-订阅 | 解耦事件通知机制 | 实时系统、消息中间件 |
相关文章:
系统架构设计(四):架构风格总结
黑板 概念 黑板体系架构是一种用于求解复杂问题的软件架构风格,尤其适合知识密集型、推理驱动、数据不确定性大的场景。 它模拟了人类专家协同解决问题的方式,通过一个共享的“黑板”协同多个模块(专家)逐步构建解决方案。 组…...
ElasticSearch进阶
一、文档批量操作 1.批量获取文档数据 批量获取文档数据是通过_mget的API来实现的 (1)在URL中不指定index和type 请求方式:GET请求地址:_mget功能说明 : 可以通过ID批量获取不同index和type的数据请求参数: docs : 文档数组参…...
0基础 | L298N电机驱动模块 | 使用指南
引言 在嵌入式系统开发中,电机驱动是一个常见且重要的功能。L298N是一款高电压、大电流电机驱动芯片,广泛应用于各种电机控制场景,如直流电机的正反转、调速,以及步进电机的驱动等。本文将详细介绍如何使用51单片机来控制L298N电…...
Synchronized与锁升级
一、面试题 1)谈谈你对Synchronized的理解 2)Sychronized的锁升级你聊聊 3)Synchronized实现原理,monitor对象什么时候生成的?知道monitor的monitorenter和monitorexit这两个是怎么保证同步的嘛&#…...
MNIST DDP 分布式数据并行
Distributed Data Parallel 转自我的个人博客:https://shar-pen.github.io/2025/05/04/torch-distributed-series/3.MNIST_DDP/ The difference between DistributedDataParallel and DataParallel is: DistributedDataParallel uses multiprocessing where a proc…...
语音合成之十三 中文文本归一化在现代语音合成系统中的应用与实践
中文文本归一化在现代语音合成系统中的应用与实践 引言理解中文文本归一化(TN)3 主流LLM驱动的TTS系统及其对中文文本归一化的需求分析A. SparkTTS(基于Qwen2.5)与文本归一化B. CosyVoice(基于Qwen)与文本归…...
9.1.领域驱动设计
目录 一、领域驱动设计核心哲学 战略设计与战术设计的分野 • 战略设计:限界上下文(Bounded Context)与上下文映射(Context Mapping) • 战术设计:实体、值对象、聚合根、领域服务的构建原则 统一语言&am…...
如何配置光猫+路由器实现外网IP访问内部网络?
文章目录 前言一、网络拓扑理解二、准备工作三、光猫配置3.1 光猫工作模式3.2 光猫端口转发配置(路由模式时) 四、路由器配置4.1 路由器WAN口配置4.2 端口转发配置4.3 动态DNS配置(可选) 五、防火墙设置六、测试配置七、安全注意事…...
C++题题题题题题题题题踢踢踢
后缀表达式求值 #include<bits/stdc.h> #include<algorithm> using namespace std; string a[100]; string b[100]; stack<string> op; int la0,lb0; int main(){while(true){cin>>a[la];if(a[la]".") break;la;}for(int i0;i<la;i){if(…...
M. Moving Both Hands(反向图+Dijkstra)
Problem - 1725M - Codeforces 题目大意:给你一个有向图,起始点在1,问起始点分别与另外n-1个 点相遇的最短时间,无法相遇输出-1。 思路:反向建图,第一层建原图,第二层建反向图,两层…...
11、参数化三维产品设计组件 - /设计与仿真组件/parametric-3d-product-design
76个工业组件库示例汇总 参数化三维产品设计组件 (注塑模具与公差分析) 概述 这是一个交互式的 Web 组件,旨在演示简单的三维零件(如带凸台的方块)的参数化设计过程,并结合注塑模具设计(如开模动画)与公…...
智能座舱开发工程师面试题
一、基础知识类 简述智能座舱的核心组成部分及其功能 要求从硬件(如显示屏、传感器、控制器)和软件(操作系统、中间件、应用程序)层面展开,阐述各部分如何协同实现座舱的智能化体验。 对比 Android Automotive、QNX…...
【连载14】基础智能体的进展与挑战综述-多智能体系统设计
基础智能体的进展与挑战综述 从类脑智能到具备可进化性、协作性和安全性的系统 【翻译团队】刘军(liujunbupt.edu.cn) 钱雨欣玥 冯梓哲 李正博 李冠谕 朱宇晗 张霄天 孙大壮 黄若溪 在基于大语言模型的多智能体系统(LLM-MAS)中,合作目标和合…...
06.three官方示例+编辑器+AI快速学习webgl_animation_skinning_additive_blending
本实例主要讲解内容 这个Three.js示例展示了**骨骼动画(Skinning)和变形动画(Morphing)**的结合应用。通过加载一个机器人模型,演示了如何同时控制角色的肢体动作和面部表情,实现更加丰富的角色动画效果。 核心技术包括: 多动画混合与淡入…...
【Java学习日记36】:javabeen学生系统
ideal快捷键...
.Net HttpClient 使用请求数据
HttpClient 使用请求数据 0、初始化及全局设置 //初始化:必须先执行一次 #!import ./ini.ipynb1、使用url 传参 参数放在Url里,形如:http://www.baidu.com?namezhangsan&age18, GET、Head请求用的比较多。优点是简单、方便࿰…...
详解 Java 并发编程 synchronized 关键字
synchronized 关键字的作用 synchronized 是 Java 中用于实现线程同步的关键字,主要用于解决多线程环境下的资源竞争问题。它可以修饰方法或代码块,确保同一时间只有一个线程可以执行被修饰的代码,从而避免数据不一致的问题。 synchronized…...
《Go小技巧易错点100例》第三十二篇
本期分享: 1.sync.Map的原理和使用方式 2.实现有序的Map sync.Map的原理和使用方式 sync.Map的底层结构是通过读写分离和无锁读设计实现高并发安全: 1)双存储结构: 包含原子化的 read(只读缓存,无锁快…...
时序约束高级进阶使用详解四:Set_False_Path
目录 一、背景 二、Set_False_Path 2.1 Set_false_path常用场景 2.2 Set_false_path的优势 2.3 Set_false_path设置项 2.4 细节区分 三、工程示例 3.1 工程代码 3.2 时序约束如下 3.3 时序报告 3.4 常规场景 3.4.1 设计代码 3.4.2 约束场景 3.4.3 约束对象总结…...
每日定投40刀BTC(16)20250428 - 20250511
定投 坚持 《恒道》 长河九曲本微流,岱岳摩云起累丘。 铁杵十年销作刃,寒窗五鼓淬成钩。已谙蜀栈盘空险,更蓄湘竹带泪遒。 莫问枯荣何日证,星霜满鬓亦从头。...
C# 高效处理海量数据:解决嵌套并行的性能陷阱
C# 高效处理海量数据:解决嵌套并行的性能陷阱 问题场景 假设我们需要在 10万条ID 和 1万个目录路径 中,快速找到所有满足以下条件的路径: 路径本身包含ID字符串该路径的子目录中也包含同名ID 初始代码采用Parallel.ForEach嵌套Task.Run&am…...
【Java EE初阶 --- 多线程(初阶)】线程安全问题
乐观学习,乐观生活,才能不断前进啊!!! 我的主页:optimistic_chen 我的专栏:c语言 ,Java 欢迎大家访问~ 创作不易,大佬们点赞鼓励下吧~ 文章目录 线程不安全的原因根本原因…...
从InfluxDB到StarRocks:Grab实现Spark监控平台10倍性能提升
Grab 是东南亚领先的超级应用,业务涵盖外卖配送、出行服务和数字金融,覆盖东南亚八个国家的 800 多个城市,每天为数百万用户提供一站式服务,包括点餐、购物、寄送包裹、打车、在线支付等。 为了优化 Spark 监控性能,Gr…...
《Redis应用实例》学习笔记,第一章:缓存文本数据
前言 最近在学习《Redis应用实例》,这本书并没有讲任何底层,而是聚焦实战用法,梳理了 32 种 Redis 的常见用法。我的笔记在 Github 上,用 Jupyter 记录,会有更好的阅读体验,作者的源码在这里:h…...
Redis 缓存
缓存介绍 Redis 最主要三个用途: 1)存储数据(内存数据库) 2)消息队列 3)缓存 对于硬件的访问速度,通常有以下情况: CPU 寄存器 > 内存 > 硬盘 > 网络 缓存的核心…...
Apache Flink 与 Flink CDC:概念、联系、区别及版本演进解析
Apache Flink 与 Flink CDC:概念、联系、区别及版本演进解析 在实时数据处理和流式计算领域,Apache Flink 已成为行业标杆。而 Flink CDC(Change Data Capture) 作为其生态中的重要组件,为数据库的实时变更捕获提供了强大的能力。 本文将从以下几个方面进行深入讲解: 什…...
缓存(4):常见缓存 概念、问题、现象 及 预防问题
常见缓存概念 缓存特征: 命中率、最大元素、清空策略 命中率:命中率返回正确结果数/请求缓存次数 它是衡量缓存有效性的重要指标。命中率越高,表明缓存的使用率越高。 最大元素(最大空间):缓存中可以存放的最大元素的…...
实战项目6(09)
目录 任务场景一 【r1配置】 【r2配置】 【r3配置】 任务场景二 【r1配置】 【r2配置】 【r3配置】 任务场景三 【r1配置】 【r2配置】 【r3配置】 任务场景一 按照下图完成网络拓扑搭建和配置 任务要求:在…...
MySQL 数据库故障排查指南
MySQL 数据库故障排查指南 本指南旨在帮助您识别和解决常见的 MySQL 数据库故障。我们将从问题识别开始,逐步深入到具体的故障类型和排查步骤。 1. 问题识别与信息收集 在开始排查之前,首先需要清晰地了解问题的现象和范围。 故障现象: 数…...
MacOS Python3安装
python一般在Mac上会自带,但是大多都是python2。 python2和python3并不存在上下版本兼容的情况,所以python2和python3可以同时安装在一台设备上,并且python3的一些语法和python2并不互通。 所以在Mac电脑上即使有自带python,想要使…...
锁相放大技术:从噪声中提取微弱信号的利器
锁相放大技术:从噪声中提取微弱信号的利器 一、什么是锁相放大? 锁相放大(Lock-in Amplification)是一种用于检测微弱信号的技术,它能够从强噪声背景中提取出我们感兴趣的特定信号。想象一下在嘈杂的派对上听清某个人…...
机器学习总结
1.BN【batch normalization】 https://zhuanlan.zhihu.com/p/93643523 减少 2.L1L2正则化 l1:稀疏 l2:权重减小 3.泛化误差 训练误差计算了训练集的误差,而泛化误差是计算全集的误差。 4.dropout 训练过程中神经元p的概率失活 一文彻底搞懂深度学习&#x…...
基于神经网络的无源雷达测向系统仿真实现
基于神经网络的无源雷达测向系统仿真实现 项目概述 本项目实现了基于卷积神经网络(CNN)的无源雷达方向到达角(DOA)估计系统。通过深度学习方法,系统能够从接收到的雷达信号中准确估计出信号源的方向,适用于单目标和多目标场景。相比传统的DOA估计算法&…...
《用MATLAB玩转游戏开发》Flappy Bird:小鸟飞行大战MATLAB趣味实现
《用MATLAB玩转游戏开发:从零开始打造你的数字乐园》基础篇(2D图形交互)-Flappy Bird:小鸟飞行大战MATLAB趣味实现 文章目录 《用MATLAB玩转游戏开发:从零开始打造你的数字乐园》基础篇(2D图形交互…...
【C/C++】跟我一起学_C++同步机制效率对比与优化策略
文章目录 C同步机制效率对比与优化策略1 效率对比2 核心同步机制详解与适用场景3 性能优化建议4 场景对比表5 总结 C同步机制效率对比与优化策略 多线程编程中,同步机制的选择直接影响程序性能与资源利用率。 主流同步方式: 互斥锁原子操作读写锁条件变量无锁数据…...
linux 三剑客命令学习
grep Grep 是一个命令行工具,用于在文本文件中搜索打印匹配指定模式的行。它的名称来自于 “Global Regular Expression Print”(全局正则表达式打印),它最初是由 Unix 系统上的一种工具实现的。Grep 工具在 Linux 和其他类 Unix…...
【js基础笔记] - 包含es6 类的使用
文章目录 js基础js 预解析js变量提升 DOM相关知识节点选择器获取属性节点创建节点插入节点替换节点克隆节点获取节点属性获取元素尺寸获取元素偏移量标准的dom事件流阻止事件传播阻止默认行为事件委托 正则表达式js复杂类型元字符 - 基本元字符元字符 - 边界符元字符 - 限定符元…...
《Linux命令行大全(第2版)》PDF下载
内容简介 本书对Linux命令行进行详细的介绍,全书内容包括4个部分,第一部分由Shell的介绍开启命令行基础知识的学习之旅;第二部分讲述配置文件的编辑,如何通过命令行控制计算机;第三部分探讨常见的任务与必备工具&…...
补补表面粗糙度的相关知识(一)
表面粗糙度,或简称粗糙度,是指表面不光滑的特性。这个在机械加工行业内可以说是绝绝的必备知识之一,但往往也是最容易被忽略的,因为往往天天接触的反而不怎么关心,或者没有真正的去认真学习掌握。对于像我一样…...
Python实用工具:pdf转doc
该工具只能使用在英文目录下,且无法转换出图片,以及文本特殊格式。 下载依赖项 pip install PyPDF2 升级依赖项 pip install PyPDF2 --upgrade 查看库版本 python -c "import PyPDF2; print(PyPDF2.__version__)" 下载第二个依赖项 pip i…...
基于Dify实现对Excel的数据分析
在dify部署完成后,大家就可以基于此进行各种应用场景建设,目前dify支持聊天助手(包括对话工作流)、工作流、agent等模式的场景建设,我们在日常工作中经常会遇到各种各样的数据清洗、格式转换处理、数据统计成图等数据分…...
Win全兼容!五五 Excel Word 转 PDF 工具解决多场景转换难题
各位办公小能手们!今天给你们介绍一款超牛的工具——五五Excel Word批量转PDF工具V5.5版。这玩意儿专注搞批量格式转换,能把Excel(.xls/.xlsx)和Word(.doc/.docx)文档唰唰地变成PDF格式。 先说说它的核心功…...
java加强 -Collection集合
集合是一种容器,类似于数组,但集合的大小可变,开发中也非常常用。Collection代表单列集合,每个元素(数据)只包含1个值。Collection集合分为两类,List集合与set集合。 特点 List系列集合&#…...
BGP实验练习1
需求: 要求五台路由器的环回地址均可以相互访问 需求分析: 1.图中存在五个路由器 AR1、AR2、AR3、AR4、AR5,分属不同自治系统(AS),AR1 在 AS 100,AR2 - AR4 在 AS 200,AR5 在 AS …...
Nginx location静态文件映射配置
遇到问题? 以下这个Nginx的配置,愿意为访问https://abc.com会指向一个动态网站,访问https://abc.com/tongsongzj时会访问静态网站,但是配置之后(注意看后面那个location /tongsongzj/静态文件映射的配置)&…...
四、Hive DDL表定义、数据类型、SerDe 与分隔符核心
在理解了 Hive 数据库的基本操作后,本篇笔记将深入到数据存储的核心单元——表 (Table) 的定义和管理。掌握如何创建表、选择合适的数据类型、以及配置数据的读写方式 (特别是 SerDe 和分隔符),是高效使用 Hive 的关键。 一、创建表 (CREATE TABLE)&…...
每日脚本 5.11 - 进制转换和ascii字符
前置知识 python中各个进制的开头 二进制 : 0b 八进制 : 0o 十六进制 : 0x 进制转换函数 : bin() 转为2进制 oct() 转换为八进制的函数 hex() 转换为16进制的函数 ascii码和字符之间的转换 : chr(97) 码转为字符 …...
cookie和session的区别
一、基本概念 1. Cookie 定义:Cookie 是服务器发送到用户浏览器并保存在本地的一小块数据(通常小于4KB),浏览器会在后续请求中自动携带该数据。作用:用于跟踪用户状态(如登录状态)、记…...
Kotlin Multiplatform--03:项目实战
Kotlin Multiplatform--03:项目实战 引言配置iOS开发环境配置项目环境运行程序 引言 本章将会带领读者进行项目实战,了解如何从零开始编译一个能同时在Android和iOS运行的App。开发环境一般来说需要使用Macbook,笔者没试过Windows是否能开发。…...
图形学、人机交互、VR/AR领域文献速读【持续更新中...】
(1)笔者在时间有限的情况下,想要多积累一些自身课题之外的新文献、新知识,所以开了这一篇文章。 (2)想通过将文献喂给大模型,并向大模型提问的方式来快速理解文献的重要信息(如基础i…...