[發(fā)明專利]內(nèi)存數(shù)據(jù)庫同步方法、系統(tǒng)、設(shè)備及存儲介質(zhì)在審
| 申請?zhí)枺?/td> | 202011376922.4 | 申請日: | 2020-11-30 |
| 公開(公告)號: | CN114579662A | 公開(公告)日: | 2022-06-03 |
| 發(fā)明(設(shè)計)人: | 孫奇;王月;葉志欣;黃文曉;覃強;吳志強 | 申請(專利權(quán))人: | 中移動信息技術(shù)有限公司;中國移動通信集團有限公司 |
| 主分類號: | G06F16/27 | 分類號: | G06F16/27 |
| 代理公司: | 北京東方億思知識產(chǎn)權(quán)代理有限責(zé)任公司 11258 | 代理人: | 趙秀芹 |
| 地址: | 100000 北京市昌平區(qū)未來*** | 國省代碼: | 北京;11 |
| 權(quán)利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關(guān)鍵詞: | 內(nèi)存 數(shù)據(jù)庫 同步 方法 系統(tǒng) 設(shè)備 存儲 介質(zhì) | ||
本發(fā)明實施例提供了一種內(nèi)存數(shù)據(jù)庫同步方法、系統(tǒng)、設(shè)備及存儲介質(zhì),方法包括:接收來自第一內(nèi)存數(shù)據(jù)庫的第一數(shù)據(jù);基于第一數(shù)據(jù)對第二內(nèi)存數(shù)據(jù)庫進行數(shù)據(jù)更新;將第一數(shù)據(jù)確定為需要發(fā)送給第一內(nèi)存數(shù)據(jù)庫的第二數(shù)據(jù);解析第二數(shù)據(jù),得到解析結(jié)果;在解析結(jié)果中包括第一標識指令的情況下,刪除第一標識指令,并禁止將第二數(shù)據(jù)發(fā)送至第一內(nèi)存數(shù)據(jù)庫,第一標識指令為第一內(nèi)存數(shù)據(jù)庫在發(fā)送第一數(shù)據(jù)時插入到第一數(shù)據(jù)的指令數(shù)據(jù)。根據(jù)本發(fā)明實施例的方法,能夠?qū)崿F(xiàn)內(nèi)存數(shù)據(jù)庫的雙向同步,并且避免在同步時出現(xiàn)死循環(huán)。
技術(shù)領(lǐng)域
本發(fā)明屬于數(shù)據(jù)庫技術(shù)領(lǐng)域,尤其涉及一種內(nèi)存數(shù)據(jù)庫同步方法、系統(tǒng)、設(shè)備及存儲介質(zhì)。
背景技術(shù)
隨著互聯(lián)網(wǎng)時代的不斷發(fā)展,互聯(lián)網(wǎng)系統(tǒng)都在進行“雙中心”建設(shè),雙中心一般有“災(zāi)備”(單機房承載業(yè)務(wù))和“雙活”(雙機房同時承載業(yè)務(wù))兩種類型。在雙中心的系統(tǒng)部署架構(gòu)下,會面臨著數(shù)據(jù)遷移、數(shù)據(jù)共享、實時同步等問題。
數(shù)據(jù)庫官方提供了一些數(shù)據(jù)遷移的功能,但并不適用于“雙中心”的部署架構(gòu)。市面上的內(nèi)存數(shù)據(jù)庫數(shù)據(jù)同步中間件,一般更適用于“災(zāi)備”雙中心,而不適合“雙活”雙中心,僅支持單向同步,不能解決雙向同步的問題,在雙向同步時兩個內(nèi)存數(shù)據(jù)庫之間會出現(xiàn)死循環(huán)同步的情況。例如,第一內(nèi)存數(shù)據(jù)庫中發(fā)生數(shù)據(jù)變更時,需要同步到第二內(nèi)存數(shù)據(jù)庫,同樣,第二內(nèi)存數(shù)據(jù)庫中發(fā)生數(shù)據(jù)變更時,也要同步到第一內(nèi)存數(shù)據(jù)庫,但是,第一內(nèi)存數(shù)據(jù)庫同步至第二內(nèi)存數(shù)據(jù)庫的數(shù)據(jù),不能再從第二內(nèi)存數(shù)據(jù)庫回到第一內(nèi)存數(shù)據(jù)庫,否則就會出現(xiàn)死循環(huán)同步的情況。
發(fā)明內(nèi)容
本發(fā)明實施例提供一種內(nèi)存數(shù)據(jù)庫同步方法、系統(tǒng)、設(shè)備及存儲介質(zhì),能夠在內(nèi)存數(shù)據(jù)庫雙向同步中,避免出現(xiàn)死循環(huán)同步的情況。
第一方面,本發(fā)明實施例提供一種內(nèi)存數(shù)據(jù)庫同步方法,方法包括:接收來自第一內(nèi)存數(shù)據(jù)庫的第一數(shù)據(jù);基于第一數(shù)據(jù)對第二內(nèi)存數(shù)據(jù)庫進行數(shù)據(jù)更新;將第一數(shù)據(jù)確定為需要發(fā)送給第一內(nèi)存數(shù)據(jù)庫的第二數(shù)據(jù);解析第二數(shù)據(jù),得到解析結(jié)果;在解析結(jié)果中包括第一標識指令的情況下,刪除第一標識指令,并禁止將第二數(shù)據(jù)發(fā)送至第一內(nèi)存數(shù)據(jù)庫,第一標識指令為第一內(nèi)存數(shù)據(jù)庫在發(fā)送第一數(shù)據(jù)時插入到第一數(shù)據(jù)的指令數(shù)據(jù)。
在一種可選的實施方式中,該方法還包括:
獲取第三數(shù)據(jù),第三數(shù)據(jù)為需要同步至第一內(nèi)存數(shù)據(jù)庫的數(shù)據(jù);
在第三數(shù)據(jù)中插入第二標識指令;
將攜帶第二標識指令的第三數(shù)據(jù)發(fā)送至第一內(nèi)存數(shù)據(jù)庫,以使第一內(nèi)存數(shù)據(jù)庫基于第三數(shù)據(jù)完成數(shù)據(jù)更新。
在一種可選的實施方式中,在第三數(shù)據(jù)為事務(wù)操作指令集時,第二標識指令包括第一子指令和第二子指令;
在第三數(shù)據(jù)中,插入第二標識指令,包括:
在第三數(shù)據(jù)的頭部和尾部分別插入第一子指令和第二子指令,以使第二內(nèi)存數(shù)據(jù)庫在解析到第二子指令時刪除第一子指令和第二子指令,并且不將第三數(shù)據(jù)確定為需要同步至第一內(nèi)存數(shù)據(jù)庫的數(shù)據(jù)。
在一種可選的實施方式中,在第三數(shù)據(jù)為基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)指令時,在第三數(shù)據(jù)中,插入第二標識指令,包括:
在第三數(shù)據(jù)的頭部插入第二標識指令。
在一種可選的實施方式中,基于第一數(shù)據(jù)對第二內(nèi)存數(shù)據(jù)庫進行數(shù)據(jù)更新,具體包括:
解析第一數(shù)據(jù),得到第一解析數(shù)據(jù);
在第一解析數(shù)據(jù)包括第一標識指令、第三標識指令和第一目標數(shù)據(jù)時,存儲第一目標數(shù)據(jù),第一目標數(shù)據(jù)為第一內(nèi)存數(shù)據(jù)庫中更新的數(shù)據(jù),以及
刪除第一標識指令和第三標識指令,并且不將第一數(shù)據(jù)確定為需要發(fā)送給第一內(nèi)存數(shù)據(jù)庫的第二數(shù)據(jù);
在第一解析數(shù)據(jù)僅包括第一標識指令和第一目標數(shù)據(jù)時,存儲第一標識指令和第一目標數(shù)據(jù),第一目標數(shù)據(jù)為第一內(nèi)存數(shù)據(jù)庫中更新的數(shù)據(jù)。
該專利技術(shù)資料僅供研究查看技術(shù)是否侵權(quán)等信息,商用須獲得專利權(quán)人授權(quán)。該專利全部權(quán)利屬于中移動信息技術(shù)有限公司;中國移動通信集團有限公司,未經(jīng)中移動信息技術(shù)有限公司;中國移動通信集團有限公司許可,擅自商用是侵權(quán)行為。如果您想購買此專利、獲得商業(yè)授權(quán)和技術(shù)合作,請聯(lián)系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202011376922.4/2.html,轉(zhuǎn)載請聲明來源鉆瓜專利網(wǎng)。
- 數(shù)據(jù)庫
- 數(shù)據(jù)庫管理系統(tǒng)及數(shù)據(jù)庫
- 數(shù)據(jù)庫構(gòu)筑裝置、數(shù)據(jù)庫檢索裝置、數(shù)據(jù)庫裝置、數(shù)據(jù)庫構(gòu)筑方法、以及數(shù)據(jù)庫檢索方法
- 數(shù)據(jù)庫和數(shù)據(jù)庫處理方法
- 數(shù)據(jù)庫系統(tǒng)、數(shù)據(jù)庫更新方法、數(shù)據(jù)庫以及數(shù)據(jù)庫更新程序
- 容器數(shù)據(jù)庫
- 數(shù)據(jù)庫同步方法及數(shù)據(jù)庫
- 一種MongoDB數(shù)據(jù)庫對象復(fù)制延遲監(jiān)控方法和裝置
- 數(shù)據(jù)分布式存儲方法、裝置、電子設(shè)備及存儲介質(zhì)
- 數(shù)據(jù)庫語句執(zhí)行方法及裝置





