[發明專利]數據庫狀態的檢測方法、裝置、電子設備及其存儲介質有效
| 申請號: | 202010310910.5 | 申請日: | 2020-04-20 |
| 公開(公告)號: | CN111552637B | 公開(公告)日: | 2023-05-19 |
| 發明(設計)人: | 任冠亞 | 申請(專利權)人: | 北京順達同行科技有限公司 |
| 主分類號: | G06F11/36 | 分類號: | G06F11/36 |
| 代理公司: | 深圳紫藤知識產權代理有限公司 44570 | 代理人: | 遠明 |
| 地址: | 100089 北京市海淀區*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 數據庫 狀態 檢測 方法 裝置 電子設備 及其 存儲 介質 | ||
1.一種數據庫狀態的檢測方法,其特征在于,應用于應用服務器,所述應用服務器對應連接有主數據庫和至少一個從屬數據庫,包括:
獲取應用服務器中的中間件的運行狀態;
當獲取到所述中間件的運行狀態為啟動狀態時,在所述中間件中創建檢驗數據庫的多個校驗協程,所述多個校驗協程包括第一校驗協程,其中第一校驗協程用于等待中間件中其他協程的調用;
根據所述多個校驗協程確定主數據庫的狀態,其包括:
根據多個校驗協程進行數據庫校驗得到多個校驗狀態,所述多個校驗狀態為除了第一校驗協程外的多個校驗協程分別進行數據庫檢驗得到的狀態;
當所述多個校驗狀態中任一校驗狀態為異常狀態時,則根據所述第一校驗協程獲取并校驗所述多個校驗狀態;
如果第一校驗協程檢測到任意一個校驗協程的狀態為正常狀態時,則確定主數據庫未發生故障,第一校驗協程放棄繼續對其他校驗協程的校驗,如果第一校驗協程檢驗到其他所有校驗協程的狀態都為異常狀態時,則確定主數據庫故障。
2.如權利要求1所述的方法,其特征在于,所述多個校驗協程包括第二校驗協程,所述多個校驗狀態包括第一校驗狀態,所述第一校驗狀態為第二校驗協程檢驗數據庫得到的狀態;
所述根據所述多個校驗狀態確定主數據庫的狀態的步驟,包括:
根據所述第二校驗協程獲取第一值、第二值以及第三值,所述第一值為所述第二校驗協程將數據寫入請求發送到數據庫的主數據庫節點上的次數,所述第二值為所述第二校驗協程接收到的數據寫入請求返回所述主數據庫節點上的次數,所述第三值為根據所述第一值和第二值得到的第三值;
將所述第三值和第一預設閾值進行比較,得到比較結果;
根據所述比較結果得到所述第一校驗狀態。
3.如權利要求2所述的方法,其特征在于,所述多個校驗協程包括第三校驗協程,所述多個校驗狀態包括第二校驗狀態,所述第二校驗狀態為第三校驗協程檢驗數據庫得到的狀態;
所述根據所述多個校驗狀態確定主數據庫的狀態的步驟,包括:
根據所述第三校驗協程將檢驗數據插入主數據庫的請求發送至所述主數據庫節點,得到第一結果和第二結果,所述第一結果為將所述數據是否成功插入主數據庫的結果,所述第二結果為請求發送是否成功的結果;
根據所述第一結果和第二結果,得到所述第二校驗狀態。
4.如權利要求2-3任一權利要求所述的方法,其特征在于,所述多個校驗協程包括第四校驗協程,所述多個校驗狀態包括第四校驗狀態,所述第四校驗狀態為第三校驗協程檢驗數據庫得到的狀態;
所述根據所述多個校驗狀態確定主數據庫的狀態的步驟,包括:
根據所述第四校驗協程獲取從屬數據庫的讀寫線程的狀態,所述讀寫線程的狀態為所述從屬數據庫通過所述讀寫線程與所述主數據庫的連接狀態;
根據所述讀寫線程的狀態得到第三校驗狀態。
5.如權利要求4所述的方法,其特征在于,所述根據所述多個校驗狀態確定主數據庫的狀態的步驟,包括:
當第一校驗狀態、第二校驗狀態以及第三校驗狀態均為異常狀態時,確定所述數據庫的狀態為異常狀態;
當第一校驗狀態、第二校驗狀態、第三校驗狀態中的任一校驗狀態為正常狀態時,確定所述數據庫的狀態為正常狀態。
6.如權利要求5所述的方法,其特征在于,所述確定所述數據庫的狀態為異常狀態的步驟之后,還包括:
當確定所述數據庫的狀態為異常狀態時,在所述至少一個從屬數據庫中選擇目標數據庫,將所述目標數據庫調整為主數據庫。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于北京順達同行科技有限公司,未經北京順達同行科技有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202010310910.5/1.html,轉載請聲明來源鉆瓜專利網。





