2015第43周三memcached
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信。
memcached缺乏认证以及安全管制,这代表应该将memcached服务器放置在防火墙后。
memcached作为高速运行的分布式缓存服务器,具有以下的特点。
· 协议简单
· 基于libevent的事件处理
· 内置内存存储方式
· memcached不互相通信的分布式
https://github.com/memcached/memcached
这两年 Redis火得可以,Redis也常常被当作 Memcached的挑战者被提到桌面上来。关于Redis与Memcached的比较更是比比皆是。然而,Redis真的在功能、性能以及内存使用效率上都超越了Memcached吗?
没有必要过于关注性能,因为二者的性能都已经足够高了。由于Redis只使用单核,而Memcached可以使用多核,所以二者比较起来,平均每一个核上,Redis在存储小数据时比Memcached性能更高。而在100k以上的数据中,Memcached性能要高于Redis。虽然Redis最近也在存储大数据的性能上进行优化,但是比起Memcached,还是稍有逊色。说了这么多,结论是,无论你使用哪一个,每秒处理请求的次数都不会成为瓶颈。
在内存使用效率上,如果使用简单的key-value存储,Memcached的内存利用率更高。而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。当然,这和你的应用场景和数据特性有关。
如果你对数据持久化和数据同步有所要求,那么推荐你选择Redis。因为这两个特性Memcached都不具备。即使你只是希望在升级或者重启系统后缓存数据不会丢失,选择Redis也是明智的。
当然,最后还得说到你的具体应用需求。Redis相比Memcached来说,拥有更多的数据结构,并支持更丰富的数据操作。通常在Memcached里,你需要将数据拿到客户端来进行类似的修改再set回去。这大大增加了网络IO的次数和数据体积。在Redis中,这些复杂的操作通常和一般的GET/SET一样高效。所以,如果你需要缓存能够支持更复杂的结构和操作,那么Redis会是不错的选择。
http://www.cnblogs.com/ceecy/p/3279407.html
最新文章
- NSwagStudio for Swagger Api
- 负载均衡的场景下ASP.NET Core如何获取客户端IP地址
- 推荐一篇 OAuth 2.0 必读文章
- poj 3254 状压dp入门题
- nginx 常用配置说明
- ffmpeg之yuv2rgb_c_24_rgb
- WITH AS 优化逻辑读
- DB2 递归
- [LeetCode] 128. Longest Consecutive Sequence 解题思路
- 解决Android Activity切换时出现白屏问题
- 《JavaScript高级程序设计》读书笔记 ---操作符一
- Symbol
- Javaweb学习笔记——(十三)——————JSTL、JSTL核心标签库、自定义标签、有标签体的标签、带有属性的标签、MVC、Javaweb三层框架
- C# Json序列化去掉k__BackingField问题的解决方案
- python 全栈开发,Day9(函数的初始,返回值,传参,三元运算)
- 第三次随笔--安装虚拟机及学习linux系统初体验
- MyEclipse持续性开发教程:用JPA和Spring管理数据(二)
- CUDA C Programming Guide 在线教程学习笔记 Part 5
- Linux 操作日志
- webbrowser控件使用时的注意事项