当前位置: 首页 > article >正文

Java 面试高频题:通知平台整体架构一般怎么拆?

消息实时通知平台架构总览怎么搭一次讲清渠道、模板、推送、回执、偏好与治理闭环大家好我是一名有 4 年工作经验的 Java 后端开发。从第129天开始我连续围绕消息实时通知系统写了整体设计、渠道抽象、模板中心、实时推送、异步投递、偏好订阅、已读回执、权限审计和监控告警这些内容。这一篇我想做一个阶段性的收束从整体架构视角把消息通知平台再完整梳理一遍。个人主页文章目录消息实时通知平台架构总览怎么搭一次讲清渠道、模板、推送、回执、偏好与治理闭环一、为什么通知平台最怕“能发消息但闭环不完整”二、通知平台的完整链路是什么三、最核心的模块怎么拆四、最值得强调的技术亮点五、最容易被低估的几个能力实战案例放到真实项目里会怎么跑Java 代码示例SQL 示例六、面试中怎么回答七、总结八、结尾一、为什么通知平台最怕“能发消息但闭环不完整”很多团队做通知平台时通常会一个个补功能先接短信再接邮件后面加 Push再补模板再补已读功能看起来越来越多但如果没有整体架构思维最后很容易变成渠道有了但没有统一模型模板有了但版本和灰度没做好推送有了但没有回执已读有了但和实时推送没打通所以真正成熟的通知平台不是“功能列表很长”而是渠道、模板、推送、回执、偏好、审计、监控这些能力真正形成闭环。二、通知平台的完整链路是什么我更建议把它理解成这条完整链路业务触发通知事件通知平台接入模板渲染渠道选择异步投递发送结果回写回执 / 已读更新偏好控制日志审计监控告警这条链路里每一层都不应该缺。三、最核心的模块怎么拆我更推荐拆成这些模块通知接入层模板中心渠道适配层实时推送层异步投递层回执与已读中心偏好与订阅中心审计权限中心监控告警中心这些模块共同构成一个成熟的消息通知平台。四、最值得强调的技术亮点如果你要把这个平台拿来讲项目亮点我觉得最有价值的点通常有这些多渠道统一抽象模板配置化和版本化实时推送和持久化消息双层协同MQ 异步投递与重试补偿已读回执体系用户偏好与免打扰权限与审计治理渠道级监控告警这些点拼起来才像真正的平台能力。五、最容易被低估的几个能力很多团队最开始只关注渠道接入模板渲染但后面最容易补得很痛苦的往往是偏好控制回执与已读手工补发审计和监控而这些恰恰决定了通知平台能不能长期稳定跑起来。实战案例放到真实项目里会怎么跑比如订单支付成功后平台要判断用户偏好、选模板、走实时推送还是短信补发、落发送日志、回收回执这就是通知平台总览最值得讲的一条主链路。业务事件先进入通知编排层。编排层根据场景挑模板、验变量、判偏好。发送层优先走实时连接失败后降级短信或站内信。治理层统一接日志、回执、监控和告警。Java 代码示例ServiceRequiredArgsConstructorpublicclassNotificationOrchestrator{privatefinalPreferenceDecisionServicepreferenceDecisionService;privatefinalTemplateRenderServicetemplateRenderService;privatefinalRealtimePushServicerealtimePushService;privatefinalNotifyTaskRepositorynotifyTaskRepository;publicvoidhandle(OrderPaidEventevent){if(!preferenceDecisionService.shouldSend(event.getUserId(),ORDER_PAID,IN_APP,true)){return;}RenderResultrenderResulttemplateRenderService.render(ORDER_PAID,IN_APP,event.toTemplateParams(),event.getUserId());booleanpushedrealtimePushService.push(event.getUserId(),renderResult.content());if(!pushed){notifyTaskRepository.save(NotifyTask.forOfflineInbox(event.getUserId(),renderResult));}}}SQL 示例CREATETABLEnotification_outbox(idBIGINTPRIMARYKEY,biz_idVARCHAR(64)NOTNULL,scene_codeVARCHAR(64)NOTNULL,user_idBIGINTNOTNULL,channelVARCHAR(32)NOTNULL,statusVARCHAR(16)NOTNULL,created_atDATETIMENOTNULL);SELECTscene_code,channel,status,COUNT(*)AStotal_countFROMnotification_outboxWHEREcreated_atCURDATE()GROUPBYscene_code,channel,status;六、面试中怎么回答如果面试官问你消息实时通知平台整体架构一般怎么搭你可以这样回答第一我会把通知平台理解成一条完整的“业务触发 - 模板渲染 - 渠道选择 - 异步投递 - 结果回写 - 回执更新 - 偏好控制 - 审计监控”链路而不是单纯的发短信服务。第二模块拆分上我会重点强调通知接入、模板中心、渠道适配、实时推送、异步投递、回执已读中心、偏好订阅、权限审计和监控告警几层因为这些模块共同构成完整闭环。第三真正体现平台价值的不是“支持几种通知渠道”而是让通知能力可扩展、可追踪、可治理、可控打扰并且能稳定支撑多个业务线。七、总结消息通知平台真正难的不是“把消息发出去”而是如何让发得出发得准发得稳发得可追真正组成一套平台能力。如果只记一句结论我觉得可以记住这句一个成熟的通知平台不是短信邮件 Push 的集合而是“渠道、模板、推送、回执、偏好、治理”六层一起跑顺。八、结尾如果你觉得这篇文章对你有帮助欢迎点赞、收藏、关注。这一阶段我把消息实时通知系统从总览到细节拆了一遍后面如果你愿意我还可以继续往客服工单系统、IM 消息系统、消息中台这些方向继续展开。

相关文章:

Java 面试高频题:通知平台整体架构一般怎么拆?

消息实时通知平台架构总览怎么搭?一次讲清渠道、模板、推送、回执、偏好与治理闭环 大家好,我是一名有 4 年工作经验的 Java 后端开发。 从第129天开始,我连续围绕消息实时通知系统写了整体设计、渠道抽象、模板中心、实时推送、异步投递、偏…...

openCode 是什么?你电脑里常驻的 AI 开发搭档

凌晨一点,你正在改一个棘手的 Bug。 控制台里报错信息刷了一屏,你盯着那段陌生的代码——是上周同事写的,没注释,没文档。你下意识选中代码,复制,打开浏览器,粘贴到 ChatGPT 的对话框里。 等等。…...

全面战争模组制作新纪元:RPFM工具让你的创意无限延伸

全面战争模组制作新纪元:RPFM工具让你的创意无限延伸 【免费下载链接】rpfm Rusted PackFile Manager (RPFM) is a... reimplementation in Rust and Qt6 of PackFile Manager (PFM), one of the best modding tools for Total War Games. 项目地址: https://gitc…...

VisDrone2019数据集转换COCO格式实战:手把手教你用Python脚本搞定YOLOX训练数据准备

VisDrone2019数据集转换COCO格式全流程解析:从数据清洗到YOLOX适配 无人机视角下的目标检测一直是计算机视觉领域的特殊挑战。VisDrone2019作为该领域最具代表性的开源数据集,包含了10个类别、超过26万张标注图像,但原始数据格式与主流框架的…...

从膨胀腐蚀到Hough变换:图像处理面试官最爱问的10个核心概念,一次讲透

从膨胀腐蚀到Hough变换:图像处理面试官最爱问的10个核心概念,一次讲透 在计算机视觉和图像处理领域的技术面试中,某些核心概念几乎成为必考题。这些概念不仅是理论基础,更是实际项目中的常见工具。本文将深入解析面试中最常被问及…...

不止于获取数据:用baostock+Pandas+Matplotlib打造你的第一个股票分析仪表盘

从数据获取到洞察生成:构建股票分析仪表盘的全流程实战 在金融数据分析领域,获取原始数据只是万里长征的第一步。真正有价值的是如何将这些数据转化为可操作的洞察。本文将带你使用Python生态中的baostock、Pandas和Matplotlib等工具,构建一个…...

YOLOv8在Jetson上导出TensorRT引擎(.engine)全流程实操:从ONNX转换到INT8/FP16量化加速

YOLOv8在Jetson平台上的TensorRT引擎部署与量化加速实战指南 当目标检测模型需要部署到边缘计算设备时,性能优化往往成为最关键的技术挑战。本文将深入探讨如何将YOLOv8模型高效转换为Jetson平台专用的TensorRT引擎,并通过INT8/FP16量化技术实现推理速度…...

XC7Z010-2CLG400I Xilinx Zynq-7000 FPGA

XC7Z010-2CLG400I 可以理解为一颗“ARM 处理器 FPGA 可编程逻辑”合在一起的 SoC。它属于 Xilinx (赛灵思 AMD )Zynq-7000 家族里的 Z-7010 器件,核心特点就是把 双核 Arm Cortex-A9 MPCore 处理系统(PS) 和 7 系列可编程逻辑&am…...

别再死磕流程图了!用PAD图搞定详细设计,代码自动生成不是梦

别再死磕流程图了!用PAD图搞定详细设计,代码自动生成不是梦 如果你还在用传统流程图做详细设计,每次修改需求都要重画半张图;如果你受够了N-S图方框套方框的视觉折磨,连个简单循环都要画成俄罗斯套娃——是时候认识PAD…...

终极Visual C++运行库修复指南:如何一次性解决所有DLL缺失问题

终极Visual C运行库修复指南:如何一次性解决所有DLL缺失问题 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾因"找不到MSVCP140.dll&qu…...

meituan 民宿 mtgsig1.2

声明 本文章中所有内容仅供学习交流使用,不用于其他任何目的,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!逆向分析cp execjs.compile(open(民宿-…...

LLaMA论文里的三个关键技术点:SwiGLU、RoPE和RMSNorm,到底在解决什么问题?

LLaMA架构三大核心技术解析:SwiGLU、RoPE与RMSNorm的工程智慧 当ChatGPT掀起大模型浪潮时,Meta开源的LLaMA系列却以更小的参数量展现出惊人性能。这背后离不开三个关键技术点的精妙设计:SwiGLU激活函数、旋转位置编码(RoPE)和RMSNorm层归一化…...

数据库备份与恢复策略

数据库备份与恢复策略 1. 技术分析 1.1 备份概述 备份是数据安全的基石: 备份类型完全备份: 全部数据增量备份: 变化数据差异备份: 上次完全备份后的变化备份策略:定期完全备份增量备份补充实时备份1.2 恢复策略 恢复类型完全恢复: 恢复到最新状态时间点恢复: 恢复到…...

从AstraPro深度相机到机械臂抓取:ROS2三维手眼标定全流程实战(含D2C配准)

从AstraPro深度相机到机械臂抓取:ROS2三维手眼标定全流程实战 在工业自动化和机器人研究领域,三维手眼标定是实现精准视觉引导操作的核心技术。当我们需要让机械臂在复杂环境中自主完成分拣、装配或检测任务时,如何确保相机"看到"的…...

D3KeyHelper:暗黑3终极宏工具完整指南 - 5分钟快速上手

D3KeyHelper:暗黑3终极宏工具完整指南 - 5分钟快速上手 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper D3KeyHelper是一款专为《暗黑破坏…...

更全面的 Token 套餐来了:Agent Plan

作为一名 Token 消耗大户,各模型厂商和云厂商的套餐我基本都有入手:智谱、MiniMax、小米 Mimo,以及最早推出 Coding Plan 的火山引擎,这些都是我目前在订的。以前 Coding Plan 基本能够覆盖日常工作,但是随着越来越多场…...

别再手动拼接数据了!用ONNXRuntime和TensorRT实现多Batch推理的Python/C++实战对比

多Batch推理实战:ONNXRuntime与TensorRT的高效对决 在计算机视觉项目的实际部署中,我们常常会遇到这样的场景:摄像头持续采集图像,或者需要同时处理来自多个传感器的数据。如果每次只处理单张图片,就像用吸管喝一大桶…...

在数据预处理流水线中集成 Taotoken 进行文本摘要与分类

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 在数据预处理流水线中集成 Taotoken 进行文本摘要与分类 对于数据工程师和算法工程师而言,构建一个稳定、高效且成本可…...

从 API 调用到工具链:梳理 AI 介入测试流程的 5 个成熟度等级

2026年,AI正在以前所未有的速度重构软件测试行业。但“AI测试”并非一个开关——从简单调用ChatGPT生成几条用例,到构建完整的Agent自愈测试体系,中间存在一条清晰的能力进化路径。本文将这条路径梳理为5个成熟度等级,结合2026年最新工具、开源项目与行业数据,帮你准确评估…...

IS6201A多相PWM控制器:从架构解析到PCB布局的电源设计实战

1. 项目概述:为什么我们需要关注IS6201A?在电源设计领域,尤其是面对高性能计算、数据中心服务器、高端显卡以及工业自动化设备时,工程师们常常面临一个核心挑战:如何为那些“电老虎”级别的核心芯片(比如CP…...

Jable视频下载神器:3分钟掌握Chrome插件+本地下载器完美方案

Jable视频下载神器:3分钟掌握Chrome插件本地下载器完美方案 【免费下载链接】jable-download 方便下载jable的小工具 项目地址: https://gitcode.com/gh_mirrors/ja/jable-download 还在为无法保存Jable.tv上的精彩视频而烦恼吗?想要轻松将喜欢的…...

HPM6750 LVGL性能优化:片内SRAM帧缓冲实战解析

1. 项目概述:当LVGL遇上HPM6750的片内“新大陆”最近在嵌入式图形界面开发的圈子里,一个关于HPM6750的话题热度不低。起因是有开发者发现,在基于HPM6750这款高性能RISC-V MCU进行LVGL(Light and Versatile Graphics Library&#…...

NAS-FPN里的GP和Sum Cell到底怎么工作的?手把手图解MMCV源码实现

NAS-FPN中的GP与Sum Cell工作机制解析:从理论到MMCV源码实现 在目标检测领域,特征金字塔网络(FPN)已经成为处理多尺度目标的标配组件。然而传统FPN采用固定的人工设计结构,难以适应不同检测任务的需求。NAS-FPN通过神经网络结构搜索技术&…...

STM32串口调试玄学翻车?从XCOM 2.3到2.0的降级避坑实录

STM32串口调试的版本陷阱:当XCOM 2.3让你的开发板"沉默"时 调试嵌入式系统时,最令人抓狂的莫过于硬件一切正常,代码毫无问题,但串口就是拒绝工作。最近在STM32F103ZET6开发板上遇到了一个诡异现象:同一块板子…...

WinForm窗体最小化与还原(右下角)

最小化按钮private void btnMinimize_Click( object sender, EventArgs e ) {this.WindowState FormWindowState.Minimized;notifyIcon1 new NotifyIcon( );notifyIcon1.Icon this.Icon;notifyIcon1.MouseDoubleClick NotifyIcon1_MouseDoubleClick; }窗体最小化与还原触发…...

ESP32任务看门狗(TWDT)实战:从配置到调试,手把手教你防止程序‘饿死’

ESP32任务看门狗深度实战:构建高可靠多任务系统的关键技巧 在物联网设备开发中,系统稳定性往往决定着产品的成败。想象一下这样的场景:你的智能家居网关在凌晨3点突然停止响应,或者工业传感器节点在关键时刻丢失数据——这些问题的…...

从‘过拟合陷阱’到可靠评估:手把手教你用Python和Scikit-learn玩转交叉验证(含RepeatedKFold/LeaveOneOut)

从‘过拟合陷阱’到可靠评估:手把手教你用Python和Scikit-learn玩转交叉验证(含RepeatedKFold/LeaveOneOut) 当你满怀期待地将训练集上准确率高达98%的模型部署到生产环境,却发现实际预测效果惨不忍睹时,那种落差感就…...

protobufjs 编译命令选错就报错?一文搞懂 pbjs 的 -w 参数(es6 vs commonjs 实战解析)

ProtobufJS编译模块类型选型指南:ES6与CommonJS的深度对比与实战避坑 最近在Vite项目中集成Protobuf时,编译后的模块导入总是抛出The requested module does not provide an export named错误。这个问题困扰了我整整两天,最终发现根源在于pbj…...

地平线6地图有哪些 地平线6可以在手机上玩吗

很多玩家都在关注地平线6地图的细节,想知道这款即将上线的竞速大作究竟有哪些可探索的场景,而地平线6地图的丰富度也直接决定了游戏的可玩性。不少玩家习惯用手机碎片时间想体验游戏,却受设备限制无法解锁地平线6地图的全部风光,这…...

UE5实战:手把手教你用AIController和PathFollowingComponent实现NPC智能移动(含源码解析)

UE5智能寻路实战:从零构建NPC导航系统 在虚幻引擎5的游戏开发中,AI角色的自主移动能力直接影响着游戏体验的真实感。许多开发者初次接触UE5的AI系统时,往往会被NavigationSystem、AIController和PathFollowingComponent等模块的复杂关系所困扰…...