`

Memcached处理

 
阅读更多

 

Memcached有两个核心组件组成服务端(ms)和客户端(mc),在一个memcached的查询中,mc先通过计算key的hash值来 确定kv对所处在的ms位置。当ms确定后,客户端就会发送一个查询请求给对应的ms,让它来查找确切的数据。因为这之间没有交互以及多播协议,所以 memcached交互带给网络的影响是最小化的

举例说明:考虑以下这个场景,有三个mc分别是X,Y,Z,还有三个ms分别是A,B,C:

设置kv对
X想设置key=”foo”,value=”seattle”
X拿到ms列表,并对key做hash转化,根据hash值确定kv对所存的ms位置
B被选中了
X连接上B,B收到请求,把(key=”foo”,value=”seattle”)存了起来

获取kv对
Z想得到key=”foo”的value
Z用相同的hash算法算出hash值,并确定key=”foo”的值存在B上
Z连接上B,并从B那边得到value=”seattle”
其他任何从X,Y,Z的想得到key=”foo”的值的请求都会发向B

Memcached服务器(ms)

内存分配

默认情况下,ms是用一个内置的叫“块分配器”的组件来分配内存的。舍弃c++标准的malloc/free的内存分配,而采用块分配器的主要目的 是为了避免内存碎片,否则操作系统要花费更多时间来查找这些逻辑上连续的内存块(实际上是断开的)。用了块分配器,ms会轮流的对内存进行大块的分配,并 不断重用。当然由于块的大小各不相同,当数据大小和块大小不太相符的情况下,还是有可能导致内存的浪费。

同时,ms对key和data都有相应的限制,key的长度不能超过250字节,data也不能超过块大小的限制 --- 1MB。
因为 mc所使用的hash算法,并不会考虑到每个ms的内存大小。理论上mc会分配概率上等量的kv对给每个ms,这样如果每个ms的内存都不太一样,那可能 会导致内存使用率的降低。所以一种替代的解决方案是,根据每个ms的内存大小,找出他们的最大公约数,然后在每个ms上开n个容量=最大公约数的 instance,这样就等于拥有了多个容量大小一样的子ms,从而提供整体的内存使用率。

缓存策略

当ms的hash表满了之后,新的插入数据会替代老的数据,更新的策略是LRU(最近最少使用),以及每个kv对的有效时限。Kv对存储有效时限是在mc端由app设置并作为参数传给ms的。

同时ms采用是偷懒替代法,ms不会开额外的进程来实时监测过时的kv对并删除,而是当且仅当,新来一个插入的数据,而此时又没有多余的空间放了,才会进行清除动作。

 

Memcached客户端(mc)

Memcached客户端有各种语言的版本供大家使用,包括java,c,php,.net等等。
大家可以根据自己项目的需要,选择合适的客户端来集成。

 

缓存式的Web应用程序架构
有了缓存的支持,我们可以在传统的app层和db层之间加入cache层, 每个app服务器都可以绑定一个mc,每次数据的读取都可以从ms中取得,如果没有,再从db层读取。而当数据要进行更新时,除了要发送update的 sql给db层,同时也要将更新的数据发给mc,让mc去更新ms中的数据。

分享到:
评论

相关推荐

    Tomcat通过Memcached实现session共享的完整部署记录

    本文记录了我在生产环境下使用memcached实现tomcat session会话共享解决方案的实施完整过程,验证可用!有需要的请拿走.

    linux安装memcached问题处理,可能有些乱,但是能看懂

    linux安装memcached问题处理,可能有些乱,但是能看懂

    memcached缓存处理

    memcached-1.2.6-win32-bin

    memcached分析-main

    memcached的线程模型分析,memcached网络事件处理的最核心部分分析

    memcached1

    // 设置初始连接数、最小和最大连接数以及最大处理时间 pool.setInitConn( 5 ); pool.setMinConn( 5 ); pool.setMaxConn( 250 ); pool.setMaxIdle( 1000 * 60 * 60 * 6 ); // 设置主线程的睡眠时间 pool....

    Laravel开发-multi-memcached

    Laravel开发-multi-memcached 支持laravel和elasticache的多个memcached连接处理程序

    Memcached的原理及应用

    Memcached的原理及应用,优秀的缓存处理技术

    memcached实现集群的session共享问题

    memcached实现集群的session共享问题,处理集群服务器情况下,memcached的session共享解决方案

    memcached C++客户端的最简单实现

    这里面对socket各种不正常状态基本没有做处理,不适合直接使用。但是它绝对足够简单方便,很适合打算用memcached但又不喜欢用那些庞大复杂的开源库的同学。 用vc2010做的,其它版本可以不用我的vsproj,直接用里面...

    memCached 学习

    基于libevent的事件处理 内置内存存储方式 memcached不互相通信的分布式 安装memcached memcached的安装 memcached的启动 用客户端连接 使用Cache::Memcached 使用Cache::Memcached连接memcached 保存数据 获取数据 ...

    缓存服务器memcached下载

    memcache 用于缓存服务器,大大的提高了页面的加载速度,提高了网站的性能

    29道memcached面试题含答案(很全)

    它使用一个名为transport-memcached的插件提供Memcached命令映射到REST接口的功能,使得Memcached命令可以被同样的REST层处理。 Memcached支持的命令包括get、set、delete和quit等。其中,get命令用于获取存储在...

    最基本的缓存工具memcached

    JavaCV 是一款开源的视觉处理库,基于GPLv2协议,对各种常用计算机视觉库封装后的一组jar包(部署和本地都需要用到的缓存)

    memcached完全剖析

    基于libevent的事件处理 内置内存存储方式 memcached不互相通信的分布式 安装memcached memcached的安装 memcached的启动 用客户端连接 使用Cache::Memcached 使用Cache::Memcached连接memcached 保存数据 获取数据 ...

    memcached:在Node.js之上构建的功能齐全的Memcached客户端。 考虑到扩展性,因此它将支持Memcached集群和一致的哈希

    例如,有多种处理错误的方法,例如,当服务器不可用时,您可以配置客户端,使其在高速缓存未命中时看到对该服务器的所有请求,直到它再次上升为止。 还可以从一致的哈希算法中自动删除受影响的服务器,或者为故障...

    应用memcached提升站点性能

    开源memcached工具是一个用来存储常用信息的缓存,有了它,您便无需从缓慢的资源,比如磁盘或数据库,加载(并处理)信息了。该工具可部署在专用的情况下,也可作为用完现有环境内的多余内存的一种方法。尽管...

    PHP分布式缓存memcached开发包

    作为PHP开发人员,我们一般能想到的方法有页面静态化处理、防盗链、CDN内容分发加速访问、mysql数据库优化建立索引、架设apache服务器集群()、还有就是现在流行的各种分布式缓存技术:如memcached/redis;...

    memcached协议路由器Mcrouter.zip

    Mcrouter 是一个 memcached 协议路由器,用于对 memcached 的部署进行扩展。这是 Facebook 缓存架构的核心组件,峰值的时候每秒可处理 50 亿请求。详细介绍请看这里。 标签:Mcrouter

    crails:Web应用程序的C ++ MVC开发的Crails框架

    使用crails-cache,您将获得一个简单的API,以使用memcached处理缓存 使用crails-mail,您可以轻松呈现和发送邮件 使用crails-image,您可以将图像存储在模型中,并使用Magick ++生成缩略图 使用crails-sent

    memcached全面剖析

    基于libevent的事件处理..........................................................................................................6 内置内存存储方式.........................................................

Global site tag (gtag.js) - Google Analytics