温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

openstack-Swift中ring的通俗理解

发布时间:2020-06-30 21:25:57 来源:网络 阅读:1118 作者:lduan 栏目:移动开发

先看拓扑图:

openstack-Swift中ring的通俗理解 

每个文件和虚拟节点之间是一对一的关系,每上传一个文件就会分配一个虚拟节点,虚拟节点数一般是2的n次幂。

每个虚拟节点和zone是一对多的关系,假设每个文件有两个副本的话,那么每个虚拟节点对应到两个zone,这里只讨论文件只有一个副本,所以一个虚拟节点只对应到一个zone。

而一个zone可以对应到多个虚拟节点,比如上图有6个虚拟节点3个zone,那么每个zone对应两个虚拟节点。如果2^n个虚拟节点怎么分配给zone,就要看每个zone的权重(weight)了。

如上图,file1对应的1号虚拟节点,1号虚拟节点对应的是zone1,所以file1是存储在zone1里的,file2对应的4号虚拟节点,4号虚拟节点对应的是z1,那么file2也是存储在zone1里的(这里假设file4对应的是4号虚拟节点)。

现在准备在环境里添加一个新的zone,如下图:

openstack-Swift中ring的通俗理解 

增加一个新的zone之后,那么虚拟节点和zone之间的对应关系就要重新分配(rebalance),如上图。

此时4号虚拟节点对应的是zone4,按照现在的分配,file2应该是存储在zone4里,但是根据前面的分析,file2已经存储在zone1里了,那么就要开始把file2从zone1复制到zone4里去。

下面开始测试:

当前swift就使用一个zone,所以这三个对象都是放在同一个zone里的:

openstack-Swift中ring的通俗理解 

现在添加一个新的zone:

openstack-Swift中ring的通俗理解 

现在把新的分区添加到build文件里:

openstack-Swift中ring的通俗理解 

 

openstack-Swift中ring的通俗理解 

此时原来分布在swiftloopbak里的数据会搬到新的zone里:

openstack-Swift中ring的通俗理解 上传一些新的文件测试:

openstack-Swift中ring的通俗理解


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI