memcached虽然称为“分布式”缓存服务器,但服务器端并没有“分布式”功能。服务器端仅包括 内存存储功能,其实现非常简单。至于memcached的分布式,则是完全由客户端程序库实现的。这种分布式是memcached的最大特点。
memcached的分布式是什么意思?
这里多次使用了“分布式”这个词,但并未做详细解释。现在开始简单地介绍一下其原理,各个客户端的实现基本相同。
下面假设memcached服务器有node1~node3三台,应用程序要保存键名为“tokyo”“kanagawa”“chiba”“saitama”“gunma” 的数据。
图1 分布式简介:准备
首先向memcached中添加“tokyo”。将“tokyo”传给客户端程序库后,客户端实现的算法就会根据“键”来决定保存数据的memcached服务器。服务器选定后,即命令它保存“tokyo”及其值。
图2 分布式简介:添加时
同样,“kanagawa”“chiba”“saitama”“gunma”都是先选择服务器再保存。
接下来获取保存的数据。获取时也要将要获取的键“tokyo”传递给函数库。函数库通过与数据保存时相同的算法,根据“键”选择服务器。使用的算法相同,就能选中与保存时相同的服务器,然后发送get命令。只要数据没有因为某些原因被删除,就能获得保存的值。
图3 分布式简介:获取时
这样,将不同的键保存到不同的服务器上,就实现了memcached的分布式。 memcached服务器增多后,键就会分散,即使一台memcached服务器发生故障无法连接,也不会影响其他的缓存,系统依然能继续运行。
根据余数计算分散
就是“根据服务器台数的余数进行分散”。求得键的整数哈希值,再除以服务器台数,根据其余数来选择服务器。首先求得字符串的CRC值,根据该值除以服务器节点数目得到的余数决定服务器。
根据余数计算分散的缺点
余数计算的方法简单,数据的分散性也相当优秀,但也有其缺点。那就是当添加或移除服务器时,缓存重组的代价相当巨大。添加服务器后,余数就会产生巨变,这样就无法获取与保存时相同的服务器,从而影响缓存的命中率。实验中,由于采用普通取余算法,由三个节点变成四个节点后,26个键中只有六个在访问原来的 服务器,其他的全都移到了其他服务器。命中率降低到23%。这种情况下,在添加服务器的瞬间缓存效率 会大幅度下降,负载会集中到数据库服务器上,有可能会发生无法提供正常服务的情况。
Consistent Hashing的简单说明
Consistent Hashing如下所示:首先求出memcached服务器(节点)的哈希值,并将其配置到0~232
的圆(continuum)上。然后用同样的方法求出存储数据的键的哈希值,并映射到圆上。然后从数据映射到的位置开始顺时针查找,将数据保存到找到的第一个服务器上。如果超过232
仍然找不到服务器,就会保存到第一台memcached服务器上。
图4 Consistent Hashing:基本原理
从上图的状态中添加一台memcached服务器。余数分布式算法由于保存键的服务器会发生巨大变化而影响缓存的命中率,但Consistent Hashing中,只有在continuum上增加服务器的地点逆时针方向的第一台服务器上的键会受到影响。
图5 Consistent Hashing:添加服务器
因此,Consistent Hashing最大限度地抑制了键的重新分布。而且,有的Consistent
Hashing的实现方法还采用了虚拟节点的思想。使用一般的hash函数的话,服务器的映射地点的分布非常不均匀。因此,使用虚拟节点的思想,为每个物
理节点(服务器)在continuum上分配100~200个点。这样就能抑制分布不均匀,最大限度地减小服务器增减时的缓存重新分布。
由服务器台数(n)和增加的服务器台数(m)计算增加服务器后的命中率计算公式如下:
(1 - n/(n+m)) * 100
总结
本次介绍了memcached的分布式算法,主要有memcached的分布式是由客户端函数库实现,以及高效率地分散数据的Consistent Hashing算法。下次将介绍mixi在memcached应用方面的一些经验,和相关的兼容应用程序。
======关于memcached的几篇好文章=======================================
集群架构问题归纳,了解一些基本存储问题:
http://page.renren.com/600009052/note/475136305
常用的一些命令:
http://blog.chinaunix.net/u1/45336/showart_2227790.html
数据存储大小计算方法(v1.4.1)
http://blog.sina.com.cn/s/blog_45a34fc20100eohq.html
- 大小: 19.6 KB
- 大小: 27.4 KB
- 大小: 24.1 KB
- 大小: 46.1 KB
- 大小: 40.2 KB
分享到:
相关推荐
7. **故障转移与分布式一致性**:如何处理节点故障,以及Memcached的分布式一致性哈希算法。 8. **性能优化**:缓存命中率提升技巧,避免缓存击穿、雪崩等问题的方法。 9. **源码分析**:如果包含源码,可能涉及具体...
memcached是一个高性能、分布式的内存对象缓存系统,常用于减轻数据库负载,提高Web应用性能。 **描述解读:** 1. 提到"memcache windows x64,x86",这意味着这个压缩包包含了适用于两种不同处理器架构的版本,分别...
Memcached是一款高性能、分布式内存对象缓存系统,常用于减轻数据库负载,提高Web应用性能。 **描述解读:** 描述提到“这个是memcached windows上服务”,意味着这是在Windows操作系统环境下运行的Memcached服务...
Memcached是一款高性能、分布式的内存对象缓存系统,常用于加速动态Web应用,通过将数据存储在内存中来减少数据库的负载。 **描述解读:** 描述中提到,这个编译版本是出于公司需求而自行研究完成的,意味着这可能...
本书详细介绍了如何利用Memcached这一高性能、分布式内存对象缓存系统来优化网站性能,解决大规模网络应用中的数据存储与访问瓶颈问题。以下是对该书部分关键知识点的深入解读。 ### 一、Memcached概述 #### 1.1 ...
Memcached是一种广泛使用的开源高性能分布式内存对象缓存系统,它能够减轻数据库的负担,提高Web应用的响应速度。监视工具通常提供实时数据显示,帮助管理员了解系统的运行状态、性能指标以及可能的问题。 **描述...
Memcached是一种高性能、分布式内存对象缓存系统,常用于减轻数据库负载,提升Web应用的响应速度。 **描述解读:** 描述中提到"关于memcache 使用的 客户端是memcached client for java 的 JAVA工程",这意味着这...
**标签解读:**"memcached" 和 "NET 3.5" 作为标签,明确了讨论的主题和适用的技术栈。memcached 提供了跨语言的兼容性,而“NET 3.5”表明我们关注的是.NET Framework的第三个主要版本,发布于2007年,包含了许多新...
5. **分布式缓存**:Memcached作为分布式缓存系统,可以在多台服务器之间共享数据,通过负载均衡减少单台服务器的压力,提升整体系统的可扩展性和性能。 6. **键值存储**:Memcached基于键值对的数据结构,用户通过...
**标题解析:** "memcached套装" 这个标题表明我们关注的是一个包含与memcached相关的组件或工具的...以上是对"memcached套装"的详细解读,涵盖了从安装、配置到使用的全套流程,以及与Hibernate4集成的关键知识点。
"memcached-client" 指的是Memcached的客户端,是一个轻量级的分布式内存对象缓存系统,广泛用于Web应用以减轻数据库负载。"php" 表明这个客户端是为PHP编程语言设计的。"six4fu" 如前文所述,可能是开发者的标识。 ...
2. **分布式内存对象缓存**: 分布式意味着多个服务器可以共享数据,Memcached可以在多台服务器上部署,形成集群,提高服务的可用性和处理能力。 3. **键值对存储**: Memcached基于键值对(key-value)存储,用户...
标题中的“memcached分析文档”指的是对开源内存...这份“memcached.pdf”文档将是对以上知识点的详细解读,帮助读者全面理解并有效使用Memcached。对于希望提升Web应用性能的开发者来说,这是一份非常有价值的资源。
2. **基于缓存(如Redis、Memcached、Tair)实现分布式锁**: 缓存系统通常具有高性能和高可用性,适合实现分布式锁。例如,Redis提供了`SETNX`命令,可以原子性地设置一个键值,如果键不存在则设置成功,从而实现...
这包括了对CAP理论、BASE理论的深入解读,这些理论对于理解在分布式系统中如何权衡一致性、可用性和分区容错性至关重要。CAP理论阐述了在分布式系统中,一致性和可用性无法同时完全满足,而必须有所取舍。而BASE理论...