专栏首页程序通事支付渠道路由系统进化史

支付渠道路由系统进化史

支付系统一般需要对接多个支付渠道,一是为了保证系统的可靠性,不能因为单一渠道的问题影响整个支付系统。二是为了提高支付能力,不同渠道提供支付能力不同。三是为了降低支付成本。

对接多个支付渠道以后,为了可以正确选择支付渠道支付,因此设计渠道路由系统。

从上图可以看到路由系统功能其实很简单,分发支付请求到正确的渠道。但就是这个简单系统,也经过几次系统改造升级,最终才成为现在的样子。下面就来说说这个系统是如何演进。

下面假设对接支付渠道为支付宝与微信。

初期

支付系统初期,这个阶段业务需求较简单,仅仅需要满足一个支付场景(例如使用支付宝支付)。为了快速上线,设计方案就简单粗暴,对外直接暴露支付服务接口,由业务系统发起直接调用。

系统设计图如下:

这个阶段由于只有一个支付渠道,所以也不需要有路由系统,直接由业务系统调用支付服务接口发起支付。

这个设计方案存在很多问题:

  1. 业务系统与支付系统位于同一个系统,系统任何一次变更都会影响整个系统。
  2. 扩展性问题。接入新支付渠道,如微信,需要新暴露一个微信支付服务接口。业务系统需要改动代码。从另一方面讲,业务系统承担路由系统的功能。
  3. 复用性。新支付渠道,其实除了与支付渠道交互相关代码之外,其他代码可以复用。

针对以上问题,将系统进行了相应改造。

首先是将支付系统与业务系统单独拆分出来,成为两套单独的系统。支付系统对外暴露一组通用接口。业务系统仅对接这组接口。业务系统若想指定支付渠道支付,接口参数传入渠道标识即可。这样就将耦合在业务系统中路由功下沉到支付系统。

其次梳理渠道接口文档,抽象出共性接口。接入新支付渠道,只要继承接口,实现相关方法即可,简化渠道开发难度。

改版后的系统实现图如下:

此时,路由系统知识支付系统的一个模块,具体实现如下。

首先定义通用渠道接口,其中 channelName 方法,返回渠道渠道唯一标识,如支付宝渠道返回 aliPay

然后根据 Spring ApplicationContext getBeansOfType 方法,获取实现同一个接口的所有 Bean.最后将其放入 Map 缓存中,其中键值为 channelName 方法返回渠道标识。

这个阶段方案的问题在于支付系统所有模块位于同一工程。有些模块需要频繁发布,而有些模块,如渠道模块,路由模块改动就很少。这样就导致系统任一改动发布,影响整个支付系统可用性。

中期

针对初期后面的问题,进行了相应改造。

首先还是进行拆分,将支付系统按照模块拆分。路由系统,渠道系统,成为独立系统,独立部署维护。

系统之间调用采用 RPC 通讯,使用 Dubbo 框架。

相关实现如下:

相关接口逻辑不变,只是将同一进程内调用变成跨系统的调用。

渠道系统提供服务:

这里改动,将渠道标识放入 Dubbo 服务 group 字段,借助 Dubbo 分组功能标识中唯一的渠道系统。

路由系统引用渠道系统的服务:

这里同样需要设置 group 且需要和服务提供者一致。然后在路由系统中将服务注册到缓存中,使用渠道标识为 key,渠道服务名为 value。

最后路由系统借助 Spring ApplicationContext getBean 获取具体的服务。

这个设计的问题在于:

路由系统中需要手动引用渠道系统服务,然后再注册。这样在增加渠道系统就比较繁琐。那是不是可以做到增加渠道系统时,无需修改路由系统,路由系统自动发现服务?

借助 Dubbo API

后期

查看 Dubbo 文档,可以直接使用 ReferenceConfig 直接查找服务提供者。

官方文档建议:

ReferenceConfig 实例很重,封装了与注册中心的连接以及与提供者的连接,需要缓存。否则重复生成 ReferenceConfig 可能造成性能问题并且会有内存和连接泄漏。在 API 方式编程时,容易忽略此问题。

这里使用ReferenceConfigCache,用于缓存 ReferenceConfig 实例。

去除之前所有引用服务配置文件以及缓存注册代码,引入 ReferenceConfigCache,改造如下。

总结

回顾上文路由系统,可以看到初期没有路由系统,整个系统可以运行下去。但是随着系统复杂度提高,初期系统架构已经不能满足系统的高效运行,所以才一步步改进系统。改进的过程中,不断发现方案不足处,然后一步步迭代演进。这个过程中,要善于利用现有框架的功能,加速功能的开发。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 手把手教你实现热更新功能,带你了解 Arthas 热更新背后的原理

    一天下午正在摸鱼的时候,测试小姐姐走了过来求助,说是需要改动测试环境 mock 应用。但是这个应用一时半会又找不到源代码存在何处。但是测试小姐姐的活还是一定要帮...

    andyxh
  • 从零开始设计对账系统

    对账系统作为支付系统中的基石系统,处于整个支付环节中的最后一层,主要用来保证我方支付数据与第三方支付渠道或银行的数据一致性。

    andyxh
  • IDEA 小技巧之书签与收藏

    最近翻阅 Spring 源码,由于源码调用链路很长,等看了十几类方法之后,想看前面调用方法就很不方便,需要查找历史的查看记录。还有时候看着看着就忘了中间某个方法...

    andyxh
  • App渠道统计基础知识(Android、iOS详解)

    App推广运营人员每天最关心的就是渠道数据的变化,毕竟这是衡量工作效果的直接方法。但渠道数据的获取有哪些要点,你真的清楚吗?今天让我们简单了解一下App渠道统计...

    走在河边的小鹿
  • Python爬虫入门教程 23-100 石家庄链家租房数据抓取

    作为一个活跃在京津冀地区的开发者,要闲着没事就看看石家庄这个国际化大都市的一些数据,这篇博客爬取了链家网的租房信息,爬取到的数据在后面的博客中可以作为一些数据分...

    梦想橡皮擦
  • 学界 | 图像识别攻击还没完全解决,语音识别攻击又来了!

    AI 科技评论按:当前的语音识别技术发展良好,各大公司的语音识别率也到了非常高的水平。语音识别技术落地场景也很多,比如智能音箱,还有近期的谷歌 IO 大会上爆红...

    AI科技评论
  • (七十九)c#Winform自定义控件-导航菜单

    GitHub:https://github.com/kwwwvagaa/NetWinformControl

    冰封一夏
  • Redis:MySQL 算老几?

    我知道 MySQL 看我不顺眼,不就是他的好基友 Tomcat 不怎么搭理他了吗? 这能怪我? 谁让他那么慢?

    CSDN技术头条
  • 男女程序员的差别在哪?

     劳伦斯 · 布雷福德(Laurence Bradford)是编程教育网站「Learn to Code With Me」的创办人,她依托自己的网站对 504 名...

    程序员互动联盟
  • think-cell chart系列5——堆积不等宽柱形图

    今天要分享的是think-cell chart系列的第五篇——堆积不等宽柱形图。 其实要问我为什么对think-cell chart这么情有独钟,现在给出答案—...

    数据小磨坊

扫码关注云+社区

领取腾讯云代金券

玩转腾讯云 有奖征文活动