[發明專利]分布式事務異庫模式反交易調用方法及裝置在審
| 申請號: | 202110540794.0 | 申請日: | 2021-05-18 |
| 公開(公告)號: | CN113515352A | 公開(公告)日: | 2021-10-19 |
| 發明(設計)人: | 唐冬雪;滕達;張丹楓;程沖 | 申請(專利權)人: | 中國工商銀行股份有限公司 |
| 主分類號: | G06F9/46 | 分類號: | G06F9/46;G06F9/54;G06F8/65 |
| 代理公司: | 北京三友知識產權代理有限公司 11127 | 代理人: | 任默聞;王濤 |
| 地址: | 100140 北*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 分布式 事務 模式 交易 調用 方法 裝置 | ||
本發明公開了一種分布式事務異庫模式反交易調用方法及裝置,可用于分布式技術領域,方法包括:客戶端主事務側生成主事務信息,將主事務信息登記到服務端,得到主事務ID,登記成功后發起RPC調用請求,RPC調用請求中設置灰度流量標簽,根據灰度流量標簽,查找對應的客戶端子事務側灰度提供方;客戶端子事務側根據RPC調用請求,獲取子事務信息和灰度流量標簽的屬性信息,根據主事務ID,將子事務信息登記到服務端,得到子事務ID;調用子事務業務方法過程中,在客戶端子事務側拋出異常時向服務端發起信息更新請求。本發明可以簡化操作復雜度,實現全鏈路灰度。
技術領域
本發明涉及分布式技術領域,尤其涉及分布式事務異庫模式反交易調用方法及裝置。
背景技術
在分布式事務中,saga模型由于性能業務流程不鎖數據庫資源,按交易流程順序運行和高性能的特點在銀行金融機構中得到廣泛應用。該模型基于沖正補償,一個事務有多個參與者,每個參與者有正向操作(T)和反向補償操作(C),業務流程中執行各參與者正向操作(T),當出現失敗時則補償前面一致性參與者的逆向操作(C)。其中在每個正向操作(T)前,需要遠端的事務管理器登記事務信息,正向操作(T)執行結束發送更新事務狀態的請求到遠端事務管理器進行該事務狀態的更新,如果失敗或出現異常則由遠端的事務管理器發起反交易方法的調用(C)。
為了支持事務應用的灰度版本試點功能,提供版本發布的可靠性,事務框架需要支持全鏈路灰度。當前,異庫模式支持灰度的方式主要是應用增加集群,令灰度服務單獨部署一個集群,而擴增集群會給應用帶來額外的服務管理負擔,增加操作復雜度,同時也只能實現單個節點的灰度無法實現全鏈路上的灰度。
因此,亟需一種可以克服上述問題的分布式事務異庫模式反交易調用方案。
發明內容
本發明實施例提供一種分布式事務異庫模式反交易調用方法,用以簡化操作復雜度,實現全鏈路灰度,該方法包括:
客戶端主事務側生成主事務信息;
客戶端主事務側將所述主事務信息登記到服務端,得到主事務ID;
登記成功后客戶端主事務側發起RPC調用請求,所述RPC調用請求中設置灰度流量標簽;
客戶端主事務側根據所述灰度流量標簽,查找對應的客戶端子事務側灰度提供方;
客戶端子事務側根據所述RPC調用請求,獲取子事務信息和灰度流量標簽的屬性信息;
客戶端子事務側根據所述主事務ID,將子事務信息登記到服務端,得到子事務ID;
調用子事務業務方法過程中,在客戶端子事務側拋出異常時向服務端發起信息更新請求,所述信息更新請求用于服務端進行主事務信息和子事務信息更新后,根據所述主事務ID查詢主事務下的所有子事務,根據灰度流量標簽的屬性信息查找灰度提供方注冊的回調接口,并根據所述回調接口進行分布式事務異庫模式反交易調用。
本發明實施例提供一種分布式事務異庫模式反交易調用裝置,用以簡化操作復雜度,實現全鏈路灰度,該裝置包括:
信息生成模塊,用于客戶端主事務側生成主事務信息;
第一信息登記模塊,用于客戶端主事務側將所述主事務信息登記到服務端,得到主事務ID;
調用請求發起模塊,用于登記成功后客戶端主事務側發起RPC調用請求,所述RPC調用請求中設置灰度流量標簽;
提供方查找模塊,用于客戶端主事務側根據所述灰度流量標簽,查找對應的客戶端子事務側灰度提供方;
信息獲取模塊,用于客戶端子事務側根據所述RPC調用請求,獲取子事務信息和灰度流量標簽的屬性信息;
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于中國工商銀行股份有限公司,未經中國工商銀行股份有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202110540794.0/2.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:一種ROV絞車線纜輔助牽引裝置
- 下一篇:一種防撞桿裝置





