久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

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

147次閱讀
沒有評論

共計(jì) 2690 個字符,預(yù)計(jì)需要花費(fèi) 7 分鐘才能閱讀完成。

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

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

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

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

添加存儲:

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

如果在運(yùn)行 Swift 的時候添加 3TB 的硬盤存儲,名稱為 d16, 節(jié)點(diǎn)為 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è)備有相等的負(fù)載(根據(jù)權(quán)重)。如果集群中有 1.5T 的數(shù)據(jù)將會傳送到新的設(shè)備中,

那么將導(dǎo)致 10GB 的以太網(wǎng)卡在接下的 20 分鐘內(nèi)達(dá)到 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)?3000 了,設(shè)備添加就算是成功了。

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

刪除存儲

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

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

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

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-08-16發(fā)表,共計(jì)2690字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 新源县| 西城区| 栾城县| 宁武县| 孝义市| 开阳县| 沙湾县| 蓝山县| 六盘水市| 刚察县| 罗定市| 安乡县| 绥中县| 灵丘县| 酒泉市| 大足县| 巴林右旗| 榆中县| 钟山县| 方山县| 潍坊市| 青龙| 始兴县| 岢岚县| 钦州市| 南投县| 宁国市| 水城县| 马公市| 淄博市| 贵州省| 宣威市| 绥江县| 三门峡市| 三穗县| 什邡市| 阜宁县| 南投县| 天全县| 宿迁市| 手游|