转载:http://blog.csdn.net/cywosp/article/details/23970017
在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memcached、Redis、淘宝的Tair等,二、本地缓存,例如:Facebook的flushcache等,其中本地缓存又可以分为两种:本地磁盘缓存(现在一般都采用读写性能比较优异的SSD来做存储)和本地内存缓存。在系统中,为了提高缓存存储系统的性能以及热点数据的命中率,一般在本地磁盘缓存中也会引入内存缓存用于存储经常访问的数据。有时为了减少客户端对服务器的请求,也会在客户端上使用缓存,当然这是要考虑安全问题的。在这里,本文主要讨论分布式文件系统下的本地磁盘缓存。
1. 本地磁盘缓存与操作系统的关系
- 一、处于Storage Controller层,OS与应用相互独立,与硬件相关联,由硬件来做读写保护
- 二、处于Device Driver层,与应用独立,与硬件独立,需要第三方来完成读写保护,处于这一层的本地缓存系统有Facebook的flushcache
- 三、处于File System层,OS与应用相关联,与硬件独立,需要第三方来完成读写保护,这一层的本地缓存是在应用中使用最为广泛的,本文所讨论的本地缓存也是基于此层
2. 存储设备以及空间
根据现有的硬件存储技术,SSD的随机读写性能以非常优异,并且其使用寿命也得到了很好的保证,因此被广泛的应用于数据需要持久化存储和高速读写的服务器中。根据性价比来考虑,一般的分布式文件系统的服务器机器中不会放置太大的SSD来做缓存存储设备。——64GB至128GB的SSD是主流。
3. 磁盘缓存系统在分布式文件系统中的地位
缓存系统在整个分布式中以多种形态存在,常见的有以单独一个进程运行的方式存在,这种方式类似于C/S模式,需要进程间的通信;另外就是直接寄宿于分布式文件系统的进程中,由分布式文件系统的进程直接调用缓存的接口来进行数据读写操作,本文主要讨论后一种。
4. 分布式文件系统中,本地磁盘缓存的存储策略大概有一下所示的三种:
- 一、Write Around策略,该策略主要是读缓存,不直接写本地磁盘缓存,而是直接将数据写入分布式持久化存储当中,在读取数据时,如果发现缓存中没有对应的数据则向分布式持久化存储请求,然后再将请求后的数据写入缓存中。优点在于没有一致性问题,数据不会丢失,利于数据集中读取。缺点在于,分布式文件系统中直接将数据写入持久化存储速度会比较慢,对于用户体验会有很大的影响。
- 二、Write Through策略,该策略在读取数据方面与Write Around差不多,但是在数据写入方面有很大的区别,数据在写入的过程中,写入本地缓存的同时也将数据写入分布式持久化存储中。优点在于没有一致性问题,数据不会丢失,利于数据集中读取。缺点在于写入速度将会比较慢,不过这取决于分布式持久化存储的写入性能。
- 三、Write Back策略,该策略主要是读写缓存共用,将数据先写到本地缓存中,然后再通过异步的方式将脏数据同步到分布式持久化存储中,在本地读取数据Miss后才向分布式持久化存储请求,并回写到本地缓存中。优点在于写入速度快,利于数据集中读取,缺点在于会产生一致性问题以及数据可能会丢失。虽然这种策略容会导致数据的丢失,但是在不同层次的存储方案中其是常常被采用个的一种。
5. 存储数据类型
在分布式文件系统中,本地缓存效率极高,数据直接存储于服务器本地,对数据的操作就是对本地文件的操作,但是由于分布式的特征,本地缓存中的数据其它节点无法访问,那么如果相同的一份数据被多台机器缓存于本地,一旦该数据在其中一台机器中被修改,这就会导致一定数据的不一致,因此本地缓存最好只用于存储静态数据——一旦写入就再也不会修改的数据,例如文件的数据块内容、图片等等。
6. 索引
根据项目实践,在分布式文件系统中数据块的网络传输占用了绝大多数的时间,根据对数据随机访问概率的统计数据来分析,当一个文件被连续多次访问之后,其在最近一段时间内被访问到的概率非常之高,因此,为了减少对同一文件的网络IO,设计一个高效且符合实际的场景的本地磁盘缓存非常有必要。高效的缓存系统,必然少不了索引,利用索引快速定位对应数据的文件路径,然后尽可能的挖掘磁盘的读写潜力,让系统瓶颈落在对磁盘的读写上。同时,索引还可以很好的用于控制磁盘当前的使用空间;如果采用Write Back策略,还可以高效计算还未被同步到分布式持久化存储的存储大小;对索引的管理还可以提高缓存的命中率,什么样的数据可以被删除,什么时候删除等等。
缓存中一般都采用Key-Value的键值对形式将数据存储,Key由应用传入为了区分Value唯一的标志,为了能加速查找和减少索引的内存占用空间,缓存内部会将Key的内容进行MD5计算,然后存储在索引的数据结构中;Value的内容则以一个文件,或者多个Value存入一个文件中。由于使用SSD作为最后的Value存储,这里我们就简单的将每一个Key作为一个文件存储。另外,为了处理大量的小文件导致文件系统的inode耗尽的问题,可以将小于8KB的数据用leveldb来存储(leveldb对小数据的存储性能非常高)。
索引的组织方式有很多种,常用的有标准库的map,list,其它效率更高的有红黑树、B+树等等,这些也都是一种索引在内存中的存储和组织方式,其核心还是离不开对Key值的查找比较。在操作系统中,字符串的比较效率往往要低于系统整数类型,比如对两个32位MD5字符串的比较需要系统进行32次的比较,如果我们将MD5的值用4个unsigned int或者2个unsigned long long来存储的话(这里是在64位操作系统上的),那么直接利用CPU能对整型数进行计算的特性只需要比较4次或者2次即可,这样既可以节省16个字节的内存空间,同时还能加速比较,快速定位。
在索引的内存占用方面我们不必太过于担心,现在的服务中一般的内存配置都是十几GB,用1GB的内存来存储索引也不算太坑老板。假如每个索引所占字节数为32,那么1024 * 1024 * 1024 / 32 = 33554432个索引,如果每个索引所对应内容的平均大小为4KB,那么需要的磁盘空间为33554432 * 4KB = 134217728KB ≈ 128GB,128GB的容量正好与第2点中所说的存储相符。当然如果你开发的分布式文件系统就是用于存储小文件的,那么这些算法就需要额外考虑了。
7. 缓存的更新
在缓存系统中,由于容量有限,因此,在还有数据继续写入的情况下必须删除一些已存在缓存,腾出空间。在我们已知的常用缓存老化方法中大概有如下几种:
先进先出(FIFO: First In, First Out)
最近最少使用(LRU: Least Recently Used)
最少使用频率(LFU: Least Frequently Used)
随机删除(Random)
在实际开发过程中,有时还会采用一些其它的方式,比如,在每个数据中加入生命周期的管理——设置该数据在一定时间内自动失效并将其删除,这种方式需要对系统的时间有很精确的要求,系统时间不能随便被更改。
在分布式系统中,由于缓存会被老化或者删除,那么就会产生当缓存被老化后,某一时刻有同一数据被多人从同一台服务器中访问,所有的访问都会到缓存系统中查找,此时,发现缓存中数据不存在,那么都到分布式持久化存储中读取,返回之后,所有请求的操作会将同一份数据再回写到缓存系统中的问题。对于这个问题我暂时还没有找到什么比较好的处理方法,只能从缓存存储的数据以及业务逻辑上处理。像第5点所说的,缓存只用于存储静态数据,那样数据就可以覆盖,而不会产生一致性的问题。
如果在缓存策略中采用了Write Back策略,那么就需要做,在缓存中还未被持久化到分布式持久化存储的数据的特殊处理,这一类数据在备份持久化之前不能被内部的主动老化策略所删除。
8. 性能和命中率
在支持多线访问的缓存系统中,为提高索引的查找性能,避免锁的高频率碰撞,一般在设计索引的组织方式时会采用hash table的方法,使用多个hash桶,根据对应的hash算法来分散索引的存储,这种方法简单,易于实现,但其也存在无法动态添加hash桶的缺点。每个hash桶中放置的是一个LRU链表,LRU是缓存系统中最常见的数据替换算法,每次淘汰最久没有被访问的数据。每一个hash桶中只对LRU进行上锁,这样就能减少一部分的锁碰撞。memcached中也才用了hash table加LRU链表来管理内存的方法,其高效的管理,使得memcached被广泛用于网站的缓存中,其内存管理示意图如下:
memcache以slab方式管理内存块,从系统申请1MB大小的大块内存并划分为不同大小的chunk,不同slab的chunk大小依次为80字节,80 * 1.25,80 * 1.25^2, …。向memcache中添加item时,memcache会根据item的大小选择合适的chunk。
在项目中,为了权衡性能和命中率之间的关系,有时候常常会降低命中率来换取性能。在数据老化时可以将LRU的最少使用的前几个一起老化,减少每次只老化一个就得锁住当前的LRU链表的频率,从而加速索引的查找和写入,其次是增加hash桶个数,减少hash冲突,同时也减少了对同一LRU链表的操作。
9. 索引的持久化
在Google的好文《Introduction to Distributed System Design》中有阐明关于分布式的设计:design for failure。因此,在分布式文件系统中做好故障处理是及其重要有极其困难的,但是做好进程内的状态保存,当程序重启后能及时恢复到崩溃前的状态还是能够容易实现的。在缓存系统中,数据的索引尤为重要,因此可将其持久化,待程序重新启动后就可以重建索引。这里建议可以使用google的leveldb来做索引的持久化,其高效的读写性能,并不会对系统的性能太大的影响。——这里不考虑机器突然断电的情况。
总结
在现在的系统中,缓存无处不在,如果能合理的利用缓存,那么整个系统的性能将会得到大大个提高。那么如何判定一个缓存系统是高效的呢?在实际开发过程中,我们总结出:现在开源的缓存项目很多,但是符合自身项目需求的却寥寥无几,因此,设计一个满足自身业务需求的缓存系统时,切记不要过度设计,简单且满足需求,够用就行。
相关推荐
基于Rust的分布式文件系统项目介绍 随着大数据和云计算技术的快速发展,分布式文件系统作为存储和管理海量数据的关键技术之一,受到了越来越多的关注。Rust作为一种安全、高效且并发性能出色的编程语言,为构建高...
在当今信息技术高速发展的背景下,分布式文件系统作为处理大规模数据存储和检索的重要技术,已经成为存储领域的核心技术之一。分布式文件系统允许多个客户端并发访问存储在同一物理或虚拟存储资源中的数据,它能够在...
分布式文件系统是指文件系统管理的物理存储资源不一定直接连接在本地节点上,而是通过计算机网络与节点相连。分布式文件系统的设计是基于客户机 / 服务器模式。 分布式文件系统的特性: 1. 容易访问文件 2. 可用性...
在分布式文件系统出现之前,本地文件系统是数据存储的主要形式。典型的本地文件系统包括: - **FFS**(Fast File System):由Bill Joy为SunOS设计,旨在提供比当时其他文件系统更快的速度。 - **LFS**(Log-...
在单应用不需要集群支持或者集群情况下各节点无需互相通知的场景下使用本地缓存较合适。 本地缓存优点 1. 读取速度快:本地缓存不需要远程网络请求去操作内存空间,没有额外的性能消耗,所以读取速度快。 2. 适合...
### 分布式文件系统的历史与现状 #### 一、引言 随着信息技术的快速发展,分布式文件系统作为一种重要的数据存储和管理技术,在过去的几十年里取得了显著的进步。本文将深入探讨分布式文件系统的起源、发展历程以及...
总的来说,分布式文件系统是现代计算环境中不可或缺的一部分,它通过创新的体系结构和关键技术,解决了传统本地文件系统在大规模分布式环境下的局限性,为用户提供了一个无缝、高效的文件访问平台。对分布式文件系统...
在这个场景下,"分布式文件系统 c++编写" 指的是一个用C++实现的分布式文件系统项目,可能是模仿或受到了Google的分布式文件系统GFS(Google File System)的启发。 GFS是Google为了处理大规模数据存储和处理而设计...
与传统的本地文件系统不同,分布式文件系统中的文件不一定直接与主机通过I/O总线相连,而是通过网络互连的多个主机共同处理。这种系统的出现,主要是为了应对局域网环境下,每台主机都保存一份共享文件带来的存储...
6. **命名空间**:分布式文件系统提供统一的命名空间,使得用户可以像操作本地文件系统一样操作远程文件。 7. **安全性**:支持权限管理和访问控制,保护数据安全,防止未经授权的访问。 **源码与工具**: 在学习...
相比之下,分布式文件系统如HDFS,其核心构架设计用于处理大规模数据集,数据被分布存储在多个服务器上,通过网络相互连接。HDFS具有高容错性的特点,它默认数据在不同的物理存储设备上保存多个副本。这样即使部分...
本文将对比五种典型的分布式文件系统,包括HDFS、Ceph、MooseFS、GlusterFS和LustreFS,介绍其基本架构、数据分布和查询处理流程,然后对这些系统的优缺点进行分析,最后给出了在不同场景下如何对分布式文件系统进行...
分布式文件系统是一种在多台计算机之间共享和管理数据的系统,它允许多个节点同时访问和操作同一份文件,以提高数据的可访问性和处理效率。Chubby是一种由Google开发的分布式文件系统,特别设计用于提供粗粒度的锁...
为了优化性能,系统可能采用缓存策略,将常用或最近访问的文件部分存储在本地,减少网络延迟。 负载均衡是ctjdfs解决大容量存储问题的关键。通过智能调度策略,系统可以根据服务器的负载情况动态分配新文件的存储...
- 出现了一些新的分布式文件系统,例如GPFS(Global Parallel File System)和Lustre等,它们能够在更大的规模下提供更高的性能。 - **第三代分布式文件系统**: - 随着大数据时代的到来,出现了像Google File ...
分布式文件系统是现代大数据处理和云计算环境中不可或缺的基础架构。它允许多台计算机通过网络共享存储资源,提高了数据的可访问性和处理效率。本篇论文集主要探讨了分布式文件系统中的恢复机制以及一种新的并行调度...