前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一份完整的亿级消息中心架构方案

一份完整的亿级消息中心架构方案

作者头像
用户4283147
发布2022-10-27 14:54:38
4380
发布2022-10-27 14:54:38
举报
文章被收录于专栏:对线JAVA面试对线JAVA面试

目标

技术目标: 上行到消息队列api吞吐量10000条/秒,下发第三方平台1000条/秒(仅平台自身处理能力,第三方看第三方处理能力极限指标为准);保证消息中心100%高可用。

业务目标: 对接新需求,明确消息中心的负责人(架构组),及时响应业务处理或者反馈。

产品目标: 支持消息处理状态查询,简单的消息规范消息对接(初级开发5分钟实现接入成本),规范化消息模板办理。

需求原型

功能需求

支持阿里云短信,微信公众号,app推送,统一站内信,企业微信(应用,个人)等第三方推送。包含消息模板管理,账户管理,消息搜索,批量消息发送等。

技术方案

业务部署交互图

业务核心逻辑交互图

技术选型

优势

缺点

rocketmq

【性能好】单个吞吐量能达10万/秒,并行推送能力(消费能力)可以通过rocketmq的分区(分区细节需要设计)数量进行扩展。性能上面是一个亮点和优势

【部分功能不支持】一旦进入rocketmq队列,推送消息不可撤回。很多数据库层面的功能特性(mq不支持)在设计上就会舍弃。

es

【性能好】可以支撑上亿的数据量的关键词搜索,实时同步的性能和吞吐量都还可以。

【并发插入能力略差】假设消息下发吞吐量高,需要批量对消息进行同步,这样可以优化es吞吐量。高并发对es同步,es承载能力可能会出问题(可以投入测试进行验证)。

概要设计描述

  1. rocketmq 设计正常消息队列(正常投递消息),重试消息队列(支持多种延迟机制,发送失败重试的消息),发送结果消息队列(发送超限或者成功的消息)。
  2. es 同步以上三种队列的消息,以最终一致性(最晚时间戳校验)保持消息信息最新。
  3. mysql 仅支持管理模板,账号等基础管理功能。

底层框架设计、运维层面描述

  1. 统一网关: spring cloud gateway/kong,仅做api层面的路由支持。
  2. 基础框架: 选定jar包版本,es,rocketmq,实时报警,性能监控 对这些接口做二次封装,es支持sql模式插入查询;rocketmq做底层实现剥离。参考: bsf 统一基础框架 https://gitee.com/yhcsx/csx-bsf-all
  3. 业务框架: 标准输入输出http rpc等业务框架工具或协议层面支持。
  4. 服务高可用:k8s&docker 及devops 线上一体化部署的支持,要做到一键发布,一键回滚,滚动发布,不停机发版。
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-04-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 对线JAVA面试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 目标
  • 需求原型
  • 功能需求
  • 技术方案
  • 概要设计描述
  • 底层框架设计、运维层面描述
相关产品与服务
消息队列
腾讯云消息队列 TDMQ 是分布式架构中的重要组件,提供异步通信的基础能力,通过应用解耦降低系统复杂度,提升系统可用性和可扩展性。TDMQ 产品系列提供丰富的产品形态,包含 CKafka、RocketMQ、RabbitMQ、Pulsar、CMQ 五大产品,覆盖在线和离线场景,满足金融、互联网、教育、物流、能源等不同行业和场景的需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档