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,如下图:

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

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

下面开始测试:

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

现在添加一个新的zone:

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

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

 上传一些新的文件测试:

时间: 2024-12-23 05:23:35

openstack-Swift中ring的通俗理解的相关文章

swift中第三方网络请求库Alamofire的安装与使用

swift中第三方网络请求库Alamofire的安装与使用 Alamofire是swift中一个比较流行的网络请求库:https://github.com/Alamofire/Alamofire.下面我们就介绍一个这个库的安装与使用. 一.安装包管理工具CocoaPods 由于国内容易被墙,速度也非常的慢,这里我们使用提供的源 http://ruby.taobao.org/ gem sources --remove https://rubygems.org/ gem sources –a htt

理解 OpenStack Swift (2):架构、原理及功能 [Architecture, Implementation and Features]

本系列文章着重学习和研究OpenStack Swift,包括环境搭建.原理.架构.监控和性能等. (1)OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置 (2)原理.架构和性能 (3)监控 1. 架构 1.1 总体架构 Swift 的总体架构非常的清晰和独立: # 分层(Tier) 组件(Service) 功能(Function) 特性 部署考量 1 访问层(Access Tier) Load Balancer 硬件(比如F5)或者软件(比如HAPro

理解 OpenStack Swift (3):监控和一些影响性能的因素 [Monitoring and Performance]

本系列文章着重学习和研究OpenStack Swift,包括环境搭建.原理.架构.监控和性能等. (1)OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置 (2)原理.架构和性能 (3)监控 对 Swift 集群的监控是必要的,特别是集群规模很大的时候. 1. 监控目标 主要的监控目标包括: 硬件故障 操作系统故障 Swift 集群健康状态 Swift 集群状态 2. Swift 提供的工具 2.1 Swift 自带的各种 Audit 工具 2.1.1

如何理解Swift中Optional的 ! 和 ?

很多人在刚上手swift时对于Optional中 '!' 和 '?' 的使用十分不理解,接下来我会谈一谈自己对于这两个符号的使用方式的理解. 先来说说Optional的概念,以方便之后的理解.来看一下下面的代码: var a : String = nil // 编译错误,String类型不能为nilvar b : String = "Hello!"12Swift 中的普通类型不再能设为nil.那如何表示这个值不存在呢?所以引进了Optional的概念:代表 nil 或某个具体的值.例如

理解Swift中map 和 flatMap对集合的作用

map和flatMap是函数式编程中常见的概念,python等语言中都有.借助于 map和flapMap 函数可以非常轻易地将数组转换成另外一个新数组. map函数可以被数组调用,它接受一个闭包作为參数,作用于数组中的每一个元素.闭包返回一个变换后的元素.接着将全部这些变换后的元素组成一个新的数组. 简单的说. map就是映射函数,把一个集合映射成还有一个集合. Swift的flatMap不easy理解,flatMap非常像map函数,可是它摒弃了那些值为nil的元素. flatMap是在处理一

[翻译]理解Swift中的Optional

原文出处:Understanding Optionals in Swift 苹果新的Swift编程语言带来了一些新的技巧,能使软件开发比以往更方便.更安全.然而,一个很有力的特性Optional,在你第一次使用时可能会感到困惑.Optionals将会在编译阶段检查哪些值为nil.通过这种方式,你可以更好的保证应用程序交付在用户手里是可运行的.在Swift中,Optionals也提供了一些接口用来和遗留的Objective-C代码之间交互. 初试Optional 让我们在XCode中新建一个叫做s

理解 OpenStack Swift (1):OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置

本系列文章着重学习和研究OpenStack Swift,包括环境搭建.原理.架构.监控和性能等. (1)OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置 (2)Swift 原理和架构 (3)Swift 监控 (4)Swift 性能 要实现的系统的效果图: 特点: 使用三个对等物理节点,每个节点上部署所有Swift 服务 使用开源的 UCARP 控制一个 VIP,它会被绑定到三个物理网卡中的一个. 使用开源的 HAProxy 做负载均衡 开启 Swift

[转载] 对象存储(2):OpenStack Swift——概念、架构与规模部署

原文: http://www.testlab.com.cn/Index/article/id/1085.html#rd?sukey=fc78a68049a14bb228cb2742bdec2b9498806815fcb59399eee501874bb9e9086bce3050baf1438179330d72d2508871 摘要:开源的最大魅力,是能够满足人们的探索欲和求知欲,让我们可以很深入地了解一个系统,如果我们发现它的设计或者实现中有任何不合理的或者错误的地方,我们可以提出自己的想法并且实

【转载】OpenStack Swift学习笔记

免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:崔炳华      原文地址:http://blog.csdn.net/i_chips/article/details/17787017 1       概述 OpenStack Object Storage(Swift)是OpenStack开源云计算项目的子项目之一.Swift的目的是使用普通硬件来构建冗余的.可扩展的分布式对象存储集群,存储容量可达PB级. Swift并不是