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

最新文章

  1. NSwagStudio for Swagger Api
  2. 负载均衡的场景下ASP.NET Core如何获取客户端IP地址
  3. 推荐一篇 OAuth 2.0 必读文章
  4. poj 3254 状压dp入门题
  5. nginx 常用配置说明
  6. ffmpeg之yuv2rgb_c_24_rgb
  7. WITH AS 优化逻辑读
  8. DB2 递归
  9. [LeetCode] 128. Longest Consecutive Sequence 解题思路
  10. 解决Android Activity切换时出现白屏问题
  11. 《JavaScript高级程序设计》读书笔记 ---操作符一
  12. Symbol
  13. Javaweb学习笔记——(十三)——————JSTL、JSTL核心标签库、自定义标签、有标签体的标签、带有属性的标签、MVC、Javaweb三层框架
  14. C# Json序列化去掉k__BackingField问题的解决方案
  15. python 全栈开发,Day9(函数的初始,返回值,传参,三元运算)
  16. 第三次随笔--安装虚拟机及学习linux系统初体验
  17. MyEclipse持续性开发教程:用JPA和Spring管理数据(二)
  18. CUDA C Programming Guide 在线教程学习笔记 Part 5
  19. Linux 操作日志
  20. webbrowser控件使用时的注意事项

热门文章

  1. android应用一(调用WebServices)
  2. HDU-4593(水题)
  3. android - DefaultHttpClient设置超时.
  4. Ubuntu Server下建立VPN服务器 pptp 模式的方法
  5. (七)Struts2 验证框架
  6. Linq XML
  7. HTML网页图片滚动代码
  8. C# 获取路径中文件名、目录、扩展名等
  9. ThinkPHP URL模式和URL重写
  10. 【Python开发实战】Windows7+VirtualBox+Ubuntu环境配置