文档章节

Memcached-分布式内存缓存服务器

ymzyf2007
 ymzyf2007
发布于 2014/11/14 17:38
字数 1178
阅读 27
收藏 0

      许多Web 应用程序都将数据保存到关系型数据库中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大,访问的集中,就会出现数据库的负担加重,数据库响应恶化,网站延迟等重大影响。Memcached是高性能的分布式内存缓存服务器。一般的使用目的是通过缓存数据库查询结果,减少对数据库的访问次数,以提高动态Web应用的响应速度、提高扩展性。如图:
分布式缓存-Memcached

Memcached作为高速运行的分布式内存缓存服务器具有以下特点:

       协议简单:memcached的服务器客户端通信并不使用复杂的MXL等格式,而是使用简单的基于文本的协议。

       基于libevent的事件处理:libevent是个程序库,他将Linux 的epoll、BSD类操作系统的kqueue等时间处理功能封装成统一的接口。memcached使用这个libevent库,因此能在Linux、BSD、Solaris等操作系统上发挥其高性能。

       内置内存存储方式:为了提高性能,memcached中保存的数据都存储在memcached内置的内存存储空间中。由于数据仅存在于内存中,因此重启memcached,重启操作系统会导致全部数据消失。另外,内容容量达到指定的值之后memcached回自动删除不适用的缓存。

       Memcached不互通信的分布式:memcached尽管是“分布式”缓存服务器,但服务器端并没有分布式功能。各个memcached不会互相通信以共享信息。他的分布式主要是通过客户端实现的。


Memcached的内存管理

        Memcached默认情况下采用了名为Slab Allocatoion的机制分配,管理内存。

        Slab Allocator的基本原理是按照预定规定的大小,将分配的内存分割成特定长度的块,已完全解决内存碎片问题。Slab Allocator的原理相当简单:将分配的内存分割成各种尺寸的块,并把尺寸相同的块分成组

如图:

分布式缓存-Memcached

Memcached在数据删除方面有效利用资源
       Memcached删除数据时数据不会真正从Memcached中消失。Memcached不会释放已分配的内存。记录超时后,客户端就无法再看见该记录,其存储空间即可重复使用。

       Lazy Expriationmemcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否过期。这种技术称为lazy expiration.因此memcached不会再过期监视上耗费CPU资源。


对于缓存存储容量满的情况下的删除需要考虑多种机制,一方面是按队列机制,一方面应该对应缓存对象本身的优先级,根据缓存对象的优先级进行对象的删除。

LRU:从缓存中有效删除数据的原理
       Memcached会优先使用已超时的记录空间,但即使如此,也会发生追加新纪录时空间不足的情况。此时就要使用名为Last Recently Used(LRU)机制来分配空间。这就是删除最少使用的记录的机制。因此当memcached的内存空间不足时,就从最近未使用的记录中搜索,并将空间分配给新的记录。

Memcached分布式
       Memcached虽然称为分布式缓存服务器,但服务器端并没有“分布式”的功能。Memcached的分布式完全是由客户端实现的。现在我们就看一下memcached是怎么实现分布式缓存的。

        假如下面有memcached服务器node1~node3三台,应用程序要保存键名为“bizDataKey”“pageDataKey”的数据。

        首先向memcached中添加“bizDataKey”。将“bizDataKey”传给客户端程序库后,客户端实现的算法就会根据“键”来决定保存数据的memcached服务器。服务器选定后,即命令它保存“bizDataKey”及其值。
        同样“pageDataKey”都是先选择memcached服务器再保存。

        接下来获取保存的数据。获取时也要将获取的键“pageDataKey”传递给客户端程序库。程序库通过与数据保存时相同的算法,根据”键“选择服务器。
分布式缓存-Memcached

        这样,将不同的键保存到不同的memcached服务器上,就实现了memcached的分布式。memcached服务器增多后,键就会分散,即使一台memcached服务器发生故障无法连接,也不会影响其他的缓存,系统依然能继续运行。


© 著作权归作者所有

共有 人打赏支持
ymzyf2007
粉丝 0
博文 1
码字总数 1178
作品 0
广州
分布式缓存-Memcached

什么是Memcached 许多Web 应用程序都将数据保存到RDBMS中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大,访问的集中,就会出现REBMS的负担加重,数据库响应恶化,网站显示延...

风子
2013/03/20
0
0
memcached分布式内存缓存服务器

memcached是什么? memcached 是以LiveJournal 旗下Danga Interactive 公司的Brad Fitzpatric 为首开发的一款软件。现在已成为 mixi、 hatena、 Facebook、 Vox、LiveJournal等众多服务中 提...

凡尘里的一根葱
2015/10/23
178
0
memcached总结

分布式缓存出于如下考虑,首先是缓存本身的水平线性扩展问题,其次是缓存大并发下的本身的性能问题,再次避免缓存的单点故障问题(多副本和副本一致性)。分布式缓存的核心技术包括首先是内存本...

天下杰论
2014/08/07
59
0
Memcached全面剖析

整个网站应用中,缓存几乎无处不在,既存在于浏览器、也存在于应用服务器和数据库服务器;既可以对数据缓存(分布式缓存),也可以对文件缓存(分布式存储系统),还可以对页面片段缓存(ESI...

亚特兰缇斯
2016/04/03
42
0
memcached简介与安装【网络摘抄】

memcached是什么? memcached是以LiveJournal 旗下Danga Interactive公司的Brad Fitzpatric 为首开发的一款软件。现在已成为mixi 、 hatena、 Facebook 、 Vox 、LiveJournal等众多服务中提高...

yuanzhitang
2016/09/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

这些Spring中的设计模式,你都知道吗?

设计模式作为工作学习中的枕边书,却时常处于勤说不用的尴尬境地,也不是我们时常忘记,只是一直没有记忆。 Spring作为业界的经典框架,无论是在架构设计方面,还是在代码编写方面,都堪称行...

Java填坑之路
24分钟前
1
0
Spring Aop原理之Advisor过滤

在上文(Spring Aop之Advisor解析)中我们讲到,Spring Aop对目标bean的代理主要分为三个步骤:获取所有的Advisor,过滤当前bean可应用的Advisor和使用Advisor为当前bean生成代理对象,并且上文...

爱宝贝丶
35分钟前
0
0
JMockit学习教程

1 JMockit中文网 我觉得如果仅仅是开发自测的话,把JMockit中文网认真看一遍,就可以在项目中使用JMockit了。 http://jmockit.cn/index.htm 2 JMockit中文教程 官方文档中文版。对于不喜欢看...

SuperHeroes
47分钟前
0
0
Linux服务器几乎从不采用Arch Linux?

我们见得多的Linux服务器系统一般都是什么Ubuntu Server啊,什么Cent OS啊,什么Fedora啊,或者企业采用的Red Hat啊,为什么几乎没有Arch Linux呢?下面我将从若干个方面指出Arch Linux在服务...

linux-tao
58分钟前
0
0
js 函数柯里化 闭包

参考 https://mp.weixin.qq.com/s/GEHL3jarDdAAcr5tQGjmDg 一个统计求和的函数 需要知道整个数组的信息,然后遍历求值 function countMoney() { let money = 0 // 温馨提示:arguments...

阿豪boy
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部