来自:阿里巴巴中间件

导读:

近年来,随着微服务架构的流行,分布式消息引擎在物联网、分布式事务、实时计算和大规模缓存同步等场景中的应用日益增多。本文将分享微众银行基于RocketMQ构建消息服务平台的实践,并通过添加诸多高级特性来解决消息收发过程中遇到的各种问题,通过此文,您将了解到:

  • 金融行业服务架构的演进历程

  • 微众银行的消息服务架构

  • 基于RocketMQ定制的消息高级特性

银行应用架构的演进历史

不管是银行的系统还是其他一些传统企业的系统,他们在最早的时候都使用到了服务总线,即ESB或者某种形式存在于SOA架构中,目的是把所有的服务都串起来,让服务之间能够形成一个调用。但这类服务架构其实是比较重的,所有的服务架构都要经过总线,总线成为了架构上的瓶颈。很多商业化的ESB总线大家可能都用过,像Oracle、IBM等都有。从服务调用的维度来看,银行的应用架构的演进经历了以下3个阶段。

  • 第一阶段:90年代中后期分布式架构

这个阶段的架构具有以下3个特点:

1. 将总行的集中式系统在各个省分行分别都部署一套,每天晚上再以批量处理的方式将各省数据进行集中。

2. 这种架构的方式能够最快的解决联机性能问题, 但存在跨省转账交易无法实时到账的问题。

3. 系统发布的实时性是硬伤。

  • 第二阶段:2000-2010年集中式总线架构

这个阶段引入了ESB总线的理念:

ESB总线为渠道、核心和外围系统建立了一座桥梁,提供完全统一的接口标准协议,提升了系统发布的实时性。但同时,ESB成为了最大的单点,要支持大并发高TPS低延时,所以HA和性能要求非常高,变更需要相当谨慎。

  • 第三阶段:2010年之后的互联网金融服务架构

到了2012年以后,随着Facebook、Amazon等开放平台获得的巨大成功,BAT都逐步将自己的接口开放出来,并实施了开放平台生态圈战略,从而推动了SOA服务化的快速发展。

  • 左边是之前的传统银行集中式总线架构,右边是互联网服务化架构,包含了开放平台、服务注册和发现,以及服务化产品系统。

  • 通过开放平台对外提供接口暴露,可以发现这种架构在保障传统银行系统稳定性的同时也可以满足互联网金融需求的快速迭代实施,并且也使用了新兴的互联网分布式技术,来降低开发和运维的成本。

众银行的消息服务架构

微众银行的消息服务架构

微众银行基于Apache RocketMQ构建了自己的分布式消息服务架构,我们以RMB(Reliable Message Bus)为接入层,以基于Apache RocketMQ定制开发的WeMQ(WeBank Message Queue)为消息服务核心,通过GSL(Global Service Location)进行服务定位,通过SGS(Service Governance System)进行服务请求和服务响应的服务治理,整个分布式链路的追踪日志会上报到Log中。

接下来,我们来看看我们基于RocketMQ改造使用到的常见的消息服务模式:

  • 单播/多播pub-sub模式

Consumer可以是一个或者多个,但是一个消息会被多个不同系统的其中一个consumer收到。

  • 广播pub-sub模式

多个在线的Consumer会同时收到广播消息。

  • Active/Standby消费模式

生产者只有一个,消费者有多个,但是作为HA,只有一个Active,其他都是StandBy。当Active挂掉一个,Standby会迅速接管。

  • request-reply模式

发送请求-等待响应结果。在发送方做了一个线程的等待,要等待结果的notify。

在分布式消息系统的构建过程中,基于业务的需求,我们在RocketMQ的消息系统中添加了多项高级特性,包括多中心多活、灰度发布、熔断机制、消息存活期、流量的权重、消息去重、惊群效应问题的解决、背压模式、消息服务治理、MQTT消息服务等。

基于RocketMQ添加的一些消息高级特性

  • 同城多活

DC级别的多活希望解决的问题是,不仅消息不能丢,还要保证服务不能中断。这里有两个层面的故障,一个是应用全部宕机,那么希望被其他IDC的应用能够迅速来接管消息,另外一个是消息中间件宕机,那么希望生产者能够切换到其他IDC的中间件进行发送,并且这个中间件的消息在其他IDC有备份,能够进行消费。微众已经通过IDC断网演练检验同城多活能力。

  • 灰度发布

灰度发布希望解决的问题是,同一个消费组内不同的实例有监听不一样的topic时,能保证不同topic的消息被正确的实例消费。

灰度发布示意图

  • 熔断机制

当希望消息的堆积到一定程度时,可能是消费者出现了故障,我们希望能够提醒生产者。

熔断机制示意图

  • 流量权重(自动伸缩Q)

说到流量的权重,有一个问题是,Topic的Q值是在使用过程中手动设置的,当实例的数量超过Q的数量,那么超过部分的实例是收不到消息的。但是,如果你的实例数量小于Q的话,它们之间会由于负载均衡分Q。根据负载均衡算法,分到的Q可能是不一致的。比如有的分到2个,有的分到3个。在这种集群消费的情况下,就会出现处理的不对等。比如当大流量到来的时候,分到3个Q的那个实例可能会出现一些问题,比如挂掉了。

所以我们希望,不同的实例拿到的消息量应该是对等的。所以,流量权重希望解决的问题是,随着实例数的动态增加和减少,能够动态调整consumeQueue的数量,不至于出现流量不均匀的情况。因此,我们做了一个自动伸缩Q的功能。默认Topic建成时,Q的数量是1,当启动一个新的实例的时候,会自动扩展一个,停掉一个实例的时候会自动缩一个。从而达到Q个数量和实例的数量是一一对等的。这解决了实例和消息量不对等的问题。

  • 消息去重

在负载均衡的一个很短时间内,当新上一个实例的时候,由于大家分到的Q都是相同的,当前一个分到Q的还在继续拉消息,下一个实例由于负载均衡很快做完,也分到Q,就会去拿这个Q的消息,这个时候就会出现消息的重复。此时,通常会通过Redis等缓存方式进行去重,也可以在Broker上做一个简单的处理,例如用互斥锁,在竞争消费的短时间内,对其进行加锁,抢到锁的才能进行消费,同时占有锁的时间有限制,从而解决消息去重的问题。

消息服务去重原理图

  • 消息的背压消费模式

背压模式示意图

在一些特殊场景下,需要对消息引擎做一些加强,例如背压模式。当消息拉到本地的消费线程池时,会出现一个问题。当要做一些例如DB的写的操作导致出现线程卡死,处理能力会下降,服务出现降级,但是消息还在不停地往本地拉。

这个时候,我们希望达到一种效果,能够根据后续服务的治理能力决定拉的消息数量。当然RocketMQ的ProcessQ也能达到这个效果,但是还不够精细化。因为在金融场景下,交易一旦出现不一致或者超时,会很麻烦。所以我们希望在实时的交易链路上去解决这个问题。于是我们做了一个类似Reactor框架的背压处理,能够根据处理能力实时拉取消息。

  • 消息存活期

当对消息的有效期有要求时,可以在消费消息时对存活时间进行判断,超时则丢弃。

  • 内存模式

对于存活期非常短和对延时要求比较低的消息,我们通过内存模式(不落盘)进行加速,降低延时。

  • 惊群效应问题

因为负载均衡算法在客户端,客户端的连接和断开都会触发消费组内的所有实例会收到notification做负载均衡。比较理想的情况是,一个实例的掉线不能影响到其他实例,当监听的topic比较多时,会出现负载均衡慢的问题,因此我们希望负载均衡收敛到服务端来做,客户端只需要关注topic,不需要关注consumeQueue。

目前,我们团队已经参与到Apache RocketMQ的社区建设中,并对自用的消息服务以社区分支的形式在维护,希望各行业更多的开发者可以一起参与进来,以打造适用范围更广、更好用的分布式消息引擎。

作者介绍

陈广胜,Apache RocketMQ资深Contributor,曾就职于IBM和华为,现任职于微众银行,曾参与过运营商云和大数据平台的建设,以及银行的基础架构建设等。

长按订阅更多精彩▼

如有收获,点个在看,诚挚感谢

微众银行的金融级消息服务平台建设实践和思考相关推荐

  1. 金融资讯数据服务平台建设实践

    本文选自<交易技术前沿>总第四十五期文章(2021年6月) 林剑青.王施.刘存光.曹叙风.王伟利.熊友根.王洪涛 海通证券股份有限公司/软件开发中心 来源丨公众号:上交所技术服务(ID:S ...

  2. 46W 奖金池等你来战!微众银行第三届金融科技高校技术大赛火热报名中!

    青春是什么? 张爱玲曾说过,青春是个奇形怪状的玩意儿,短短的身子偏偏拖了一个长长的尾巴,像翅膀一样的招摇着,久久不肯离去. 对于你我而言,青春是什么? 青春也许是大学里点点滴滴的记忆:读书.生活.交友 ...

  3. 再领高校前沿科技风潮,微众银行第三届金融科技大赛落下帷幕

    11月8日, 2021年微众银行第三届金融科技高校技术大赛(以下简称"大赛")在深圳成功落下帷幕. 本届大赛历时80天,共有220余支队伍,总计800余名海内外高校学生参与.在人工 ...

  4. 阿里PB级Kubernetes日志平台建设实践

    阿里PB级Kubernetes日志平台建设实践 QCon是由InfoQ主办的综合性技术盛会,每年在伦敦.北京.纽约.圣保罗.上海.旧金山召开.有幸参加这次QCon10周年大会,作为分享嘉宾在刘宇老师的 ...

  5. 干货分享 | 阿里PB级Kubernetes日志平台建设实践

    嘉宾 | 元乙 随着近两年的发展,Kubernetes 早已成为容器编排领域的标准,现在非常多的企业基于 Kubernetes 构建整个微服务的开发.运维平台,而日志是其中必不可少的核心功能.本文整理 ...

  6. 企业金融App评测系列——微众银行以App构筑企业金融服务新生态,成为企业的随身数字银行

    易观分析:近年来,疫情驱动小微企业线上化需求不断提升,经营面临的财力.人力.信息获取的紧迫性进一步提升.为更好发展普惠小微金融的商业银行对公服务,正聚焦更好满足小微企业的数字化需求,加快打造企业手机银 ...

  7. 对话微众银行马智涛:数据可携带权对金融意味着什么

     关注ITValue,看企业级最新鲜.最价值报道! 图片来源@视觉中国 2021年8月20日,全国人大第十三届常务委员会第三十次会议表决通过<中华人民共和国个人信息保护法>(以下简称&qu ...

  8. 46 万奖金等你拿 | 微众银行第二届金融科技高校技术大赛报名中

    听说你是算法界的"最强大脑" 算法调优难不倒! 听说你是班级里的"链圈"极客 产品设计最在行! 那么,机会来了!2020 微众银行第二届金融科技高校技术大赛已经 ...

  9. 微众银行:分布式架构之高可用

    作者:Noe来源:51CTO [51CTO.com原创稿件]导言 在互联网金融快速发展的当下,面对爆发式增长的数据量.高并发海量交易场景,传统集中式架构的性能瓶颈愈发凸显.基于此,越来越多的银行等金融 ...

最新文章

  1. 自定义mac的ll命令
  2. 腾讯首次公布微信最全用户数据【完整版】
  3. 全国首家工资总额负面清单管理试点企业获批
  4. SAP成都研究院2018年年会之前的技术讲座
  5. sqrt()函数的注意事项
  6. javascript 学习笔记(一)
  7. c语言10个数如何求最大值,C语言,输入10个数怎样输出10个数中最大值,最小值(大一计算机)...
  8. 不信不能雷倒你!超牛高考作文
  9. 【分享-EasyRecovery】删除的文件找不回?不存在的!
  10. Go将数字转换为字符串的正确姿势
  11. java 线程安全性_Java线程安全性问题摘要_Power Node Java Academy的组织
  12. assertion failed:Path for IClasspathEntry must be absolute
  13. Zebra-VTYSH源码分析和改造
  14. Android开发-无法新建Activity及新建后编译错误
  15. JQuery插件iScroll实现下拉刷新,滚动翻页特效
  16. 代码之美~Func让构造方法为属性赋值更灵活
  17. 5G信令7——Service Request
  18. 【AI视野·今日NLP 自然语言处理论文速览 第十七期】Thu, 1 Jul 2021
  19. 两台计算机如何共享文档,两台电脑怎么共享文件夹?
  20. 测试工程师的福利!各远程移动测试平台对比分析

热门文章

  1. 2021牛客寒假算法基础集训营1 题解
  2. 【USACO training】Chapter 1 入门
  3. 2016 linux发行版排行_灵越7590 安装 linux (manjaro-gnome)
  4. 早上起来收到两个消息
  5. java B2B2C 源码 多级分销Springcloud多租户电子商城系统- 整合企业架构的技术点(二)...
  6. [UOJ55]紫荆花之恋
  7. swift和OC - 拆分数组 和 拆分字符串
  8. hdu3790 最短路径问题(spfa)
  9. 机器学习处理流程、特征工程,模型设计实例
  10. C#开发微信门户及应用(24)-微信小店货架信息管理