`

海外系统与国内系统api通信确保畅通方案

阅读更多
由于海外业务需求,服务器部署在新加坡。但是互相同步的业务部署在国内。
生产环境经常遇到海外api同步业务接口到国内运用掉包(国内调海外api很少出这种问题!)
为了解决这个问题,尝试了两种方案:
方案一:
在海外服务器,链接调用国内的redis-sidekiq写入任务,在国内服务器响应任务再链接海外数据库去取数据写到国内服务器。
这样貌似效果还不错,但是,海外调国内的任务队列,国内再写逻辑链接处理海外数据库。互相之间耦合太大。

方案二:
在海外api调用时,添加状态表记录,接口名称和参数以及反馈状态。
调用状态返回成功,则不再重复调用,否则5分钟轮询调用。
配合redis-sidekiq海外任务队列基本重复调用3次也可以解决问题了。
注意的就是,在国内接口要做一些唯一性创建同步的逻辑判断,应为重复调用可能录入重复数据。好处就是解耦合。
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics