[發明專利]一種數據更新的方法及裝置有效
| 申請號: | 201811212070.8 | 申請日: | 2018-10-18 |
| 公開(公告)號: | CN109542636B | 公開(公告)日: | 2020-12-25 |
| 發明(設計)人: | 黃旭 | 申請(專利權)人: | 新浪網技術(中國)有限公司 |
| 主分類號: | G06F9/54 | 分類號: | G06F9/54;G06F16/9535 |
| 代理公司: | 北京卓嵐智財知識產權代理事務所(特殊普通合伙) 11624 | 代理人: | 任漱晨 |
| 地址: | 100193 北京市海淀區東北旺西路中關村*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 一種 數據 更新 方法 裝置 | ||
本發明實施例提供了一種數據更新的方法及裝置,該方法包括:當接收到更新數據的指令時,確定所述指令中待更新數據對應的預定數據結構,讀取所述預定數據結構,并確定待更新數據在所述預定數據結構更新隊列中的第一內存區域和索引信息;根據已確定的第一內存區域,更新所述更新隊列中的待更新數據;確定與所述待更新數據的索引信息一一對應的存儲地址,根據已確定的所述存儲地址,更新數據庫的所述存儲地址中存儲的數據。通過本發明,能夠在更新數據時極大地節約了系統的內存,實現了高效、準確地完成數據更新的操作,同時,在一寫多讀時讀數據的時間不確定的情況下,實現了讀寫數據的過程中,使得讀取數據的性能最大化且節約內存。
技術領域
本發明涉及計算機技術領域,尤其涉及一種數據更新的方法及裝置。
背景技術
訂閱/更新(Pub/Sub)模型是向一個內容節點發布和訂閱消息的模型。消息發布者將消息發布到內容節點,消息訂閱者從內容節點訂閱消息。訂閱/更新的消息由消息關鍵字(key)和該消息對應的數據值(value)組成,一般該消息key不變或較少變動,與該消息對應的value是頻繁變化的,因此需要及時的更新value值,使得消息訂閱者能夠及時準確地讀取所訂閱的消息內容。
目前,現有的Pub/Sub模型中的KV(key-value)數據更新的主要方法包括以下幾種:
1、將數據鎖住后再更新,無論用mutex(常規的互斥鎖)還是CAS(Compareswap,比較交換)都是有鎖的方法;
2、數據復制多份后分別進行更新;
3、使用隊列更新數據,寫者寫入數據編號后各個讀者讀取數據編號,寫者等待一個預設的時間后默認寫者已經完成數據處理,隨后清除舊數據。
在實現本發明過程中,發明人發現現有技術中存在如下問題:浪費內存;用延遲一段時間再清除舊數據的方法,在很多時候固然運行良好,但是難以控制、內存利用率不高,另一方面,一旦讀取程序執行時間過長,如被調試或者有其他異常情況出現導致無法及時處理數據更新隊列,超過了預訂的延遲的時間,則有極大可能導致數據錯誤的情況發生。
發明內容
本發明實施例提供一種數據更新的方法及裝置,實現了在保證數據一致性的前提下用較少的內存,高效地完成數據更新。
一方面,本發明實施例提供了一種數據更新的方法,包括:
當接收到更新數據的指令時,確定所述指令中待更新數據對應的預定數據結構,讀取所述預定數據結構,并確定待更新數據在所述預定數據結構更新隊列中的第一內存區域和索引信息;
根據已確定的第一內存區域,更新所述更新隊列中的待更新數據;
確定與所述待更新數據的索引信息一一對應的存儲地址,根據已確定的所述存儲地址,更新數據庫的所述存儲地址中存儲的數據。
另一方面,本發明實施例提供了一種數據更新的裝置,包括:
確定及讀取單元,用于當接收到更新數據的指令時,確定所述指令中待更新數據對應的預定數據結構,讀取所述預定數據結構,并確定待更新數據在所述預定數據結構的更新隊列中的第一內存區域和索引信息;
第一更新單元,用于根據已確定的第一內存區域,更新所述更新隊列中的待更新數據;
第二更新單元,用于確定與所述待更新數據的索引信息一一對應的存儲地址,根據已確定的所述存儲地址,更新數據庫的所述存儲地址中存儲的數據。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于新浪網技術(中國)有限公司,未經新浪網技術(中國)有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201811212070.8/2.html,轉載請聲明來源鉆瓜專利網。
- 數據顯示系統、數據中繼設備、數據中繼方法、數據系統、接收設備和數據讀取方法
- 數據記錄方法、數據記錄裝置、數據記錄媒體、數據重播方法和數據重播裝置
- 數據發送方法、數據發送系統、數據發送裝置以及數據結構
- 數據顯示系統、數據中繼設備、數據中繼方法及數據系統
- 數據嵌入裝置、數據嵌入方法、數據提取裝置及數據提取方法
- 數據管理裝置、數據編輯裝置、數據閱覽裝置、數據管理方法、數據編輯方法以及數據閱覽方法
- 數據發送和數據接收設備、數據發送和數據接收方法
- 數據發送裝置、數據接收裝置、數據收發系統、數據發送方法、數據接收方法和數據收發方法
- 數據發送方法、數據再現方法、數據發送裝置及數據再現裝置
- 數據發送方法、數據再現方法、數據發送裝置及數據再現裝置





