[發明專利]一種存儲系統數據的一致性保障方法、系統及緩存裝置有效
| 申請號: | 201610709272.8 | 申請日: | 2016-08-23 |
| 公開(公告)號: | CN106325773B | 公開(公告)日: | 2019-05-28 |
| 發明(設計)人: | 葛冬玲 | 申請(專利權)人: | 浪潮(北京)電子信息產業有限公司 |
| 主分類號: | G06F3/06 | 分類號: | G06F3/06 |
| 代理公司: | 北京集佳知識產權代理有限公司 11227 | 代理人: | 羅滿 |
| 地址: | 100085 北京市海*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 目標數據 校驗 回滾段 一致性保障 數據校驗 寫入 不一致 磁盤 緩存 存儲系統數據 緩存裝置 數據寫入磁盤 數據存儲 校驗數據 寫入過程 寫操作 回滾 回寫 存儲 指令 檢測 重建 | ||
1.一種存儲系統數據的一致性保障方法,其特征在于,包括:
在緩存中設置回滾段和數據校驗段;
接收第一目標數據刷寫指令,并將所述第一目標數據寫入所述回滾段中,計算所述第一目標數據的第一校驗值并存入所述數據校驗段;
將所述第一目標數據刷寫入磁盤,計算刷寫入磁盤的第一目標數據的第二校驗值;
若所述第一校驗值與所述第二校驗值不一致,則將所述回滾段中存儲的第一目標數據重新刷寫入磁盤;
其中,若所述第一校驗值與所述第二校驗值不一致,則將所述回滾段中存儲的目標數據重新刷寫入磁盤,包括:
若所述第一校驗值與所述第二校驗值不一致,則根據預設工具及所述回滾段中存儲的目標數據,檢測所述寫入磁盤的第一目標數據被修改的數據塊;
根據所述回滾段中存儲的第一目標數據重建所述被修改的數據塊,并以重建后的數據塊代替被修改的數據塊。
2.根據權利要求1所述的一致性保障方法,其特征在于,若所述第一校驗值與所述第二校驗值一致,則清空所述回滾段中存儲的所述第一目標數據、所述第一校驗值和所述第二校驗值。
3.根據權利要求1所述的一致性保障方法,其特征在于,在緩存中設置回滾段之后,還包括:
接收第二目標數據修改指令;
將要被修改的所述第二目標數據寫入所述回滾段;
若檢測到所述第二目標數據修改指令執行失敗,則將所述回滾段中存儲的所述第二目標數據刷寫入磁盤原位置。
4.根據權利要求3所述的一致性保障方法,其特征在于,所述接收第二目標數據修改指令之后,還包括:
計算所述第二目標數據的第三校驗值并存入所述數據校驗段;
若檢測到所述第二目標數據修改指令執行失敗之后,且檢測到所述回滾段中存儲的所述第二目標數據存在部分丟失現象,則根據所述第二目標數據未丟失部分和所述第三校驗值恢復第二目標數據,并將恢復的第二目標數據刷寫入磁盤原位置。
5.根據權利要求4所述的一致性保障方法,其特征在于,若檢測到所述第二目標數據修改指令執行成功,則清空所述回滾段中存儲的所述第二目標數據和所述第三校驗值。
6.一種存儲系統數據的一致性保障系統,其特征在于,包括:
設置模塊,用于在緩存中設置回滾段和數據校驗段;
第一寫入模塊,用于接收第一目標數據刷寫指令,并將所述第一目標數據寫入所述回滾段中;
第一計算模塊,用于計算所述第一目標數據的第一校驗值并存入所述數據校驗段;
數據刷寫模塊,用于將所述第一目標數據刷寫入磁盤;其中,所述數據刷寫模塊具體用于:若所述第一校驗值與第二校驗值不一致,則根據預設工具及所述回滾段中存儲的目標數據,檢測寫入磁盤的第一目標數據被修改的數據塊;根據所述回滾段中存儲的第一目標數據重建所述被修改的數據塊,并以重建后的數據塊代替被修改的數據塊;
第二計算模塊,用于計算刷寫入磁盤的第一目標數據的第二校驗值;
判斷模塊,用于判斷所述第一校驗值與所述第二校驗值不一致時,觸發所述數據刷寫模塊將所述回滾段中存儲的第一目標數據重新刷寫入磁盤。
7.根據權利要求6所述的一致性保障系統,其特征在于,還包括:
接收模塊,用于接收第二目標數據修改指令;
第二寫入模塊,用于將要被修改的所述第二目標數據寫入所述回滾段;
第一檢測模塊,用于檢測到所述第二目標數據修改指令執行失敗時,觸發所述數據刷寫模塊將所述回滾段中存儲的所述第二目標數據刷寫入磁盤原位置。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于浪潮(北京)電子信息產業有限公司,未經浪潮(北京)電子信息產業有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201610709272.8/1.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:一種數據存儲的方法及裝置
- 下一篇:一種局部視覺特征選擇方法及裝置





