Memcached的优点
核心知识点
memcached总的特点:简单、稳定、专注
1.简单的通信协议
a.通信协议:TCP
b.序列化协议:文本的自定义协议
2.丰富的客户端程序:几乎支持所有的网络编程语言
3.高性能的网络通信:Libevent(事件出发的通信协议库)
4.高效的内存管理:固定内存分配(slab_class——》slab——》chunk)
5.互不通信的集群架构
Memcached曾一度是网站分布式缓存的代名词,被大量网站使用。
其简单的设计、优异的性能、互不通信的服务器集群、海量数据可伸缩的架构令网站架构师们趋之若鹜。

Memcached的优异性主要表现在以下几个方面:
(1)简单的通信协议
远程通行设计需要考虑两方面的要素,一是通信协议,选择TCP协议还是UDP协议,抑或是HTTP协议;
一是通信序列化协议,数据传输的两端,必须使用彼此可识别的数据的数据序列化方式才能使通信得以完成,
如XML、JSON等文本序列化协议,抑或是Google Protobuffer等二进制序列化协议。
Memcached使用TCP协议(UDP也支持)通信,其序列化协议则是一套基于文本的自定义协议,
非常简单,以一个命令关键字开头,后面是一组命令操作数。
例如读取一个数据的命令协议是get <key>。Memcached以后,许多NoSQL产品都借鉴了或直接会支持这套协议。
(2)丰富的客户端程序
Memcached通信协议非常简单,只要支持该协议的客户端都可以和Memcached服务器通信,
因此Memcached发展出非常丰富的客户端程序,几乎支持所有的主流的网络编程语言,
例如,Java、C/C++/C#、Perl、Python、PHP、Ruby等,因此在混合使用多种编程的网站,Memcached更是如鱼得水。
(3)高性能的网络通信
Memcached服务端通信模块基于Libevent,一个支持事件出发的网络通信程序库,
Libevent的设计和实现有许多值得改善的地方,但它在稳定的长连接方面的表现却正是Memcached需要的。
(4)高效的内存管理
内存管理中一个令人头疼的问题就是内存碎片管理。操作系统、虚拟机垃圾回收在这方面想了许多方法:压缩、复制等。
Memcached使用了一个非常简单的方法——固定空间分配。
Memcached将内存空间分为一组slab,每个slab里又包含一组chunk,同一个slab里的每个chunk的大小是固定的,
拥有相同大小chunk的slab被组织在一起,叫作slab_class。
存储数据时根据数据的Size大小,寻找一个大于Size的最小chunk将数据写入。
这种内存管理方式避免了内存碎片管理的问题,内存的分配和释放都是以chunk为单位的。
和其它缓存一样,Memcached采用LRU算法释放最近最久未被访问的数据占用的空间,
释放的chunk被标记为未用,等待下一个合适大小的数据写入。

当然这种方式也会带来内存浪费的问题。数据只能存入一个比它大的chunk里,而一个chunk只能存入一个数据,其他内存空间被浪费了。
如果启动参数配置不合理,浪费会更加惊人,发现没有缓存多少数据,内存空间就用尽了。
(5)互不通信的服务器集群架构
如上所说,正是这个特性使得Memcached从JBoss Cache、OSCache等众多分布式缓存产品中脱颖而出,满足网站对海量缓存数据的请求。
而其客户端路由算法一致性hash更成为数据存储伸缩性架构设计的经典范式。
事实上,正是集群内服务器互不通信使得集群可以做到几乎无限制的线性伸缩,这也是目前流行的许多大数据技术的基本架构特点。
虽然近些年许多NoSQL产品层出不穷,在数据持久化、支持复杂数据结构、甚至性能方面有许多产品优于Memcached,
但Memcached由于其简单、稳定、专注的特点,仍然在分布式缓存领域占据着重要的地位。
Memcached的优点的更多相关文章
- 畅谈Redis和Memcached的区别
		
简述 memcached 和 redis 都很类似:都是内存型数据库,数据保存在内存中,通过tcp直接存取,优势是速度快,并发高,缺点是数据类型有限,查询功能不强,一般用作缓存. 那么题主说 memc ...
 - memcached的缺点
		
上篇博客说了为什么引入memcached,主要讲述了memcached的优点,接下来就是我们在使用中必须要注意的内容,memcached的缺点,只有正确认识它,才能运用自如,接下来先看一下memcac ...
 - 为什么引入Memcached?
		
刚memcached了解学习,一直是处于一个懵懂的状态,先是对memcached进行了一个了解,但我们为什么要在ITOO中引入memcached呢?当问我的时候当时自己脑子中打了一个大大的 这就必须去 ...
 - redis,memcached,mongodb之间的区别
		
Redis Redis的优点: 支持多种数据结构,如 string(字符串). list(双向链表).dict(hash表).set(集合).zset(排序set).hyperloglog(基数估算) ...
 - Redis、Memcache和MongoDB的区别
		
>>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境 ...
 - redis、memcache、mongoDB有哪些区别(转载)
		
转载: http://leandre.cn/database/64.html Memcached Memcached的优点: Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS ...
 - linux下实现redis共享session的tomcat集群
		
为了实现主域名与子域名的下不同的产品间一次登录,到处访问的效果,因此采用rediss实现tomcat的集群效果.基于redis能够异步讲缓存内容固化到磁盘上,从而当服务器意外重启后,仍然能够让sess ...
 - Redis、Memcache与MongoDB的区别
		
>>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境 ...
 - 第一章· Redis入门部署及持久化介绍
		
Redis简介 Redis安装部署 Redis持久化 Redis简介 软件说明: Redis是一款开源的,ANSI C语言编写的,高级键值(key-value)缓存和支持永久存储NoSQL数据库产品. ...
 
随机推荐
- hdu 1541Stars
			
题意:定义在某颗星星左下方的星星的个数表示该星星的水平,求出水平分别为为0...n-1的星星个数. 首先题目是按照y坐标升序输入的,设第第1,2...n个星星的横坐标依次为x1,x2,...xn.显然 ...
 - LCD设备驱动程序
			
LCD是Liquid Crystal Display的简称,也就是经常所说的液晶显示器 LCD能够支持彩色图像的显示和视频的播放,是一种非常重要的输出设备 Framebuffer 是Linux系统 ...
 - python核心编程学习(第三版)之网络编程
			
套接字 套接字是计算机网络数据结构.在任何类型的通信开始之前,网络应用程序必须创建套接字. 有两种类型的套接字,基于文件和面向网络的. unix套接字是第一个家族,AF_UNIX代表地址家族,缩写AF ...
 - 19. Spring Boot 添加JSP支持【从零开始学Spring Boot】
			
转:http://blog.csdn.net/linxingliang/article/details/52017140 这个部分比较复杂,所以单独创建一个工程来进行讲解: 大体步骤: (1) ...
 - mongodb分片片键的选择(持续更新中)
			
首先要了解项目的情况,检查使用情况 对集合进行分片时,要选择一个或者两个字段拆分数据,这个键叫做片键 一旦拥有对个分片,在修改片键几乎是不肯能的事情,因此选择合适的片键是非常重要的. 对集合分片之前要 ...
 - 安装nagios
			
第二部分.apache的安装 615 tar zxvf httpd-2.2.9.tar.gz 616 cd httpd-2.2.9 617 ./configure --prefix=/u ...
 - libGDX 模块概览
			
本文章翻译自libGDX官方wiki,.转载请注明出处:http://blog.csdn.net/kent_todo/article/details/37940595 libGDX官方网址:http: ...
 - 【Python数据分析】IPython快捷键
			
命令 说明 CTRL+P(或向上箭头) 后向搜索命令历史中以当前输入的文本开头的命令 CTRL+N(或向下箭头) ...
 - 设计模式之Visitor模式(笔记)
			
訪问者模式:表示一个作用于某个对象结构中的各元素操作.它使你能够不改变各元素的类的前提下定义作用于这些元素的新操作. 首先定义一个visitor抽象类,为每一个详细类声明一个visit操作 publi ...
 - Qt4.8.5配置相关问题
			
空余时间想看看Qt,在安装和编译过程中遇到了一些值得记录的东西,总结一下. (一)安装 1.先安装编译环境qt-creator-win-opensource-3.0.0.exe.使用默认路径C:\Qt ...