[發明專利]負載均衡的方法、裝置、可讀存儲介質及電子設備有效
| 申請號: | 202110733246.X | 申請日: | 2021-06-29 |
| 公開(公告)號: | CN113467720B | 公開(公告)日: | 2023-05-23 |
| 發明(設計)人: | 孫成思;孫日欣;胡偉 | 申請(專利權)人: | 成都佰維存儲科技有限公司 |
| 主分類號: | G06F3/06 | 分類號: | G06F3/06;G06F9/50;G06F12/02 |
| 代理公司: | 深圳市博銳專利事務所 44275 | 代理人: | 歐陽燕明 |
| 地址: | 610000 四川省成都市高新*** | 國省代碼: | 四川;51 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 負載 均衡 方法 裝置 可讀 存儲 介質 電子設備 | ||
本發明公開一種負載均衡的方法、裝置、可讀存儲介質及電子設備,獲取主機對應的當前可用塊條帶數量;根據所述當前可用塊條帶數量與預設最低寫帶寬確定當前限流寫帶寬;基于所述當前限流寫帶寬按照預設周期發送令牌至所述主機,并根據所述令牌執行數據寫入操作,通過當前可用塊條帶數量與預設最低寫帶寬確定當前限流寫帶寬,當前限流寫帶寬會隨著當前可用塊條帶數量的變化而變化,基于當前限流寫帶寬使用周期令牌機制對主機的寫入速率進行實時控制,均衡主機的寫入速率和空間釋放速率,同時,通過周期發送令牌至主機,能夠最大程度地縮小最大寫時延,減少超時請求的產生,有利于穩定主機性能。
技術領域
本發明涉及固態硬盤技術領域,尤其涉及一種負載均衡的方法、裝置、可讀存儲介質及電子設備。
背景技術
目前在主流的企業級SSD(Solid?State?Drive,固態硬盤)固件開發中,主要存在兩個問題,一是如何保證啟動GC(Garbage?Collect,垃圾回收)場景的情況下,讀寫請求的最大時延不超過預設閾值,二是如何均衡主機的數據寫入速率和空間釋放速率,即避免出現空間耗盡的情況,這兩個問題是固件開發中的重點和難點。
針對這些問題,目前大部分廠商都是只優先保證空間第一時間釋放,而針對GC場景下的最大寫時延和性能的考慮比較少。
發明內容
本發明所要解決的技術問題是:提供了一種負載均衡的方法、裝置、可讀存儲介質及電子設備,能夠在均衡主機的寫入速率和空間釋放速率的同時,縮小最大寫時延。
為了解決上述技術問題,本發明采用的一種技術方案為:
一種負載均衡的方法,包括:
獲取主機對應的當前可用塊條帶數量;
根據所述當前可用塊條帶數量與預設最低寫帶寬確定當前限流寫帶寬;
基于所述當前限流寫帶寬按照預設周期發送令牌至所述主機,并根據所述令牌執行數據寫入操作。
為了解決上述技術問題,本發明采用的另一種技術方案為:
一種負載均衡的裝置,包括:
獲取模塊,用于獲取主機對應的當前可用塊條帶數量;
限流寫帶寬確定模塊,用于根據所述當前可用塊條帶數量與預設最低寫帶寬確定當前限流寫帶寬;
負載均衡模塊,用于基于所述當前限流寫帶寬按照預設周期發送令牌至所述主機,并根據所述令牌執行數據寫入操作。
為了解決上述技術問題,本發明采用的另一種技術方案為:
一種計算機可讀存儲介質,其上存儲有計算機程序,所述計算機程序被處理器執行時實現上述一種負載均衡的方法中的各個步驟。
為了解決上述技術問題,本發明采用的另一種技術方案為:
一種電子設備,包括存儲器、處理器及存儲在存儲器上并可在處理器上運行的計算機程序,所述處理器執行所述計算機程序時實現上述一種負載均衡的方法中的各個步驟。
本發明的有益效果在于:獲取主機的當前可用塊條帶數量,根據當前可用塊條帶數量與預設最低寫帶寬確定當前限流寫帶寬,再基于當前限流寫帶寬周期發送令牌給主機,并根據令牌執行數據寫入操作,不再像現有技術中,只保證了空間第一時間釋放,而是通過當前可用塊條帶數量與預設最低寫帶寬確定當前限流寫帶寬,當前限流寫帶寬會隨著當前可用塊條帶數量的變化而變化,基于當前限流寫帶寬使用周期令牌機制對主機的寫入速率進行實時控制,均衡主機的寫入速率和空間釋放速率,同時,通過周期發送令牌至主機,能夠最大程度地縮小最大寫時延,減少超時請求的產生,有利于穩定主機性能。
附圖說明
圖1為本發明實施例的一種負載均衡的方法的步驟流程圖;
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于成都佰維存儲科技有限公司,未經成都佰維存儲科技有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202110733246.X/2.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:一種太陽能儲能發電裝置
- 下一篇:一種全自動抓棉機





