• 分享一例同一系统里不同服务之间通信的设计方案


    优付系统结构如下。一个数据库之上,有商户接口(RestAPI)、运营后台(OMS)、商户门户这3个独立SSM应用,三者有各自不同的功能处理逻辑。

     

    现在呢,要做一个补偿工具。当付款单下发因为系统发版等意外导致失败时,要通过这个工具,来人工重发。

    工具要做到运用后台(OMS)系统。

    但是,付款单下发逻辑在商户接口服务里。

    那么,如何实现这个小小的优化需求呢?

    方案如下:

    1. 商户接口服务新增一个RestAPI,供OMS调用。这样的话,要做好RestAPI的接口认证,保证接口安全,防止误访问。那么,OMS对接就会有这些工作量。

    2. 考虑到是同一个数据库,所以,可以建一个表,OMS保存要补偿的订单。商户接口服务定时轮询这个表进行处理。不足:定时任务,处理时效慢。

    3. 利用MQ。这是最好也是最可靠的方案。OMS作为消息生产者,商户接口服务是消息消费者。保证了处理时效,局域网也不需要考虑接口安全。RabbitMQ消息中间件当前在系统里有使用,接入成本很小。

    4. RPC也是不错的选择,例如dubbo。当前这个系统未有效使用RPC,暂不考虑。

    以上每一种方案,幂等是必不可少的。

  • 相关阅读:
    js 对象克隆的三种方式
    css超出行数隐藏
    express 中的登录-注册
    Git 常用命令
    mongodb 基本操作
    【服务器】阿里云
    【mongoDb进阶】mongoDb中的聚合管道
    express中操作数据库--Mongoose
    vuex常见问题
    ADC采样时间
  • 原文地址:https://www.cnblogs.com/buguge/p/16417574.html
Copyright © 2020-2023  润新知