SwiftStack中Swift容量管理之如何實現(xiàn)平滑添加/刪除存儲

小編給大家分享一下SwiftStack中Swift容量管理之如何實現(xiàn)平滑添加/刪除存儲,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

10年積累的成都做網(wǎng)站、成都網(wǎng)站設(shè)計、成都外貿(mào)網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有江海免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

SwiftStack中Swift Capacity Management  即Swift的容量管理,當在Swift服務(wù)器集群中

刪除或者添加存儲的時候,應(yīng)該怎么做使得系統(tǒng)可以平滑過渡,而不會使得在執(zhí)行刪除或添加存儲操作后服務(wù)

器的出現(xiàn)占用大量的I/O以及帶寬,CPU資源的問題。

添加存儲

一次性添加存儲--傻瓜做法:

如果在運行Swift的時候添加3TB的硬盤存儲,名稱為d16,節(jié)點為192.168.12.104

那么需要在ring中添加存儲

$ swift-ring-builder account.builder add z1-192.168.12.104:6002/d16 3000

$ swift-ring-builder container.builder add z1-192.168.12.104:6001/d16 3000

$ swift-ring-builder object.builder add z1-192.168.12.104:6000/d16 3000

3000為該存儲在ring中的權(quán)重(weight),用存儲的容量(GB作為單位)作為權(quán)重是比較方便的做法。

Rebalance ring,并且把所有新的ring.gz重新傳送到其他的存儲服務(wù)器上

$ swift-ring-builder account.builder rebalance

$ swift-ring-builder container.builder rebalance

$ swift-ring-builder object.builder rebalance

Swift執(zhí)行了ring的修改,但是真的可以皆大歡喜了?

錯!這樣做集群的性能將會急劇下降。即時添加3TB的存儲,將會造成大量的數(shù)據(jù)在集群中傳輸。

Rebalance ring意味著每個存儲設(shè)備有相等的負載(根據(jù)權(quán)重)。如果集群中有1.5T的數(shù)據(jù)將會傳送到新的設(shè)備中,

那么將導(dǎo)致10GB的以太網(wǎng)卡在接下的20分鐘內(nèi)達到100%使用率。整個系統(tǒng)的性能在數(shù)個小時內(nèi)將慘不忍睹。

平滑添加存儲--聰明的做法:

添加存儲的時候把權(quán)重從小開始:3000-》25

$ swift-ring-builder account.builder add z1-192.168.12.104:6002/d16 25

$ swift-ring-builder container.builder add z1-192.168.12.104:6001/d16 25

$ swift-ring-builder object.builder add z1-192.168.12.104:6000/d16 25

$ scp account.ring.gz swift-node-1:/etc/swift/account.ring.gz

$ scp container.ring.gz swift-node-1:/etc/swift/container.ring.gz

$ scp account.ring.gz swift-node-1:/etc/swift/account.ring.gz

$ scp account.ring.gz swift-node-2:/etc/swift/account.ring.gz

$ scp container.ring.gz swift-node-2:/etc/swift/container.ring.gz

$ scp account.ring.gz swift-node-2:/etc/swift/account.ring.gz ...

Rebalance ring,并傳送ring.gz文件到集群中的所有存儲服務(wù)器

$ swift-ring-builder account.builder rebalance

$ swift-ring-builder container.builder rebalance

$ swift-ring-builder object.builder rebalance

$ scp account.ring.gz swift-node-1:/etc/swift/account.ring.gz

$ scp container.ring.gz swift-node-1:/etc/swift/container.ring.gz

$ scp account.ring.gz swift-node-1:/etc/swift/account.ring.gz

$ scp account.ring.gz swift-node-2:/etc/swift/account.ring.gz

$ scp container.ring.gz swift-node-2:/etc/swift/container.ring.gz

$ scp account.ring.gz swift-node-2:/etc/swift/account.ring.gz ...

等待一段時間后(比如說一個小時)重新設(shè)置該存儲的權(quán)重(25->50),再reblance ring,再傳送ring.gz到集群中的所有存儲服務(wù)器

$ swift-ring-builder account.builder set_weight z1-192.168.12.104:6002/d16 50

$ swift-ring-builder container.builder set_weight z1-192.168.12.104:6001/d16 50

$ swift-ring-builder object.builder set_weight z1-192.168.12.104:6000/d16 50

$ swift-ring-builder account.builder rebalance

$ swift-ring-builder container.builder rebalance

$ swift-ring-builder object.builder rebalance

$ scp account.ring.gz ...

不斷重復(fù),直到120個小時之后,權(quán)重變?yōu)?000了,設(shè)備添加就算是成功了。

當然,可以寫通過腳本的方式省略大量的重復(fù)步驟!

刪除存儲

      方式和添加存儲是一樣的,把存儲的權(quán)重逐步減少,每個小時或者固定的時間內(nèi)重復(fù)步驟,直到權(quán)重變?yōu)?。

這個時候要刪除的存儲就可以從服務(wù)器下架了。

看完了這篇文章,相信你對“SwiftStack中Swift容量管理之如何實現(xiàn)平滑添加/刪除存儲”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

文章標題:SwiftStack中Swift容量管理之如何實現(xiàn)平滑添加/刪除存儲
標題鏈接:http://bm7419.com/article34/gijhse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄手機網(wǎng)站建設(shè)、App開發(fā)、微信公眾號、網(wǎng)站設(shè)計公司網(wǎng)頁設(shè)計公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)