GitHub版本号地址: https://github.com/cncounter/translation/blob/master/tiemao_2014/Redis_beats_Memcached/Redis_beats_Memcached.md

副标题: Redis是新兴的通用存储系统,而Memcached仍有其适用领域

Memcached还是Redis? 在现代高性能Web应用中这一直是个争论不休的话题。 在基于关系型数据库的Web应用须要提高性能时,使用缓存是绝大多数架构师的第一选择,自然,Memcached和Redis一般是优先选择。

共同特征

  • 都是 key-value 形式的内存数据库
  • 都是NoSQL家族的数据管理解决方式
  • 都基于相同的key-value 数据模型
  • 所有数据所有放在内存中(这也是适用于缓存的原因)
  • 性能得分不分伯仲,包含数据吞吐量和延迟等指标
  • 都是成熟的、广受开源项目欢迎的 key-value存储系统

Memcached最初在2003年由 Brad Fitzpatrick 为 LiveJournal站点开发。然后又用C语言重写了一遍(初版为Perl实现),并开放给公众使用,从此成为现代Web系统开发的基石。

当前Memcached的发展方向是改进稳定性和性能优化,而不是加入新功能特性。

Redis于2009年由 Salvatore Sanfilippo 创建, 直到今天 Sanfilippo 依旧是Redis的唯一开发人员和代码维护者。 Redis也被称为 "Memcached增强版(Memcached on steroids)", 这一点也不令人吃惊, 由于 Redis 有一部分就是在 Memcached 的经验总结之上构建的的。 Redis比Memcached具有很多其它的功能特性,这使得它更灵活,更强大也更复杂。

Memcached和Redis被众多企业以及大量生产系统所採用, 支持各种语言开发的client,有丰富的SDK。 其实, 在上点规模的互联网Web开发语言中,基本上没有不支持Memcached或Redis的。

为什么Memcached和Redis如此流行? 不仅是其具有超高的性能,还由于相对来说他们都非常easy。 对程序猿来说上手使用Memcached或Redis相当easy。 安装和设置并集成到系统中可能仅仅须要几分钟时间。 因此花费一点点时间和精力就能立马大幅提升系统性能 —— 一般是提升一个数量级。

一个简洁的解决方式却能获得巨大的性能收益: 这酸爽简直超乎你的想象。

Memcached 适用场景

由于Redis是新兴解决方式,提供了很多其它的功能特性,比起Memcached来说, Redis一般都是更好的选择。 在两个特定场景下Memcached可能是更好的选择。

第一种是非常细碎的静态数据,如HTML代码片段。 Memcached的内存管理不像Redis那么复杂,所以性能更高一些,原因是Memcached 的元数据metadata更小,相对来说额外开销就非常少。 Memcached唯一支持的数据类型是字符串 String,非常适合缓存仅仅读数据,由于字符串不须要额外的处理。

第二个场景,是Memcached比Redis更easy水平扩展。 原因在于它的设计和和功能非常easy,Memcached更easy扩展。 消息显示, Redis在即将到来的3.0版(阅读CA版本号公布笔记)将内置可靠的集群支持[但一直在跳票]。

Redis 用武之地

除非受环境制约(如遗留系统),或者业务符合上面的2种情况,否则你应该优先选择Redis。 使用Redis作为缓存,通过调优缓存内容,系统效率能获得极其提升。

非常明显Redis的优势在于缓存管理。

缓存通过某种数据回收机制(data eviction mechanism)在必要时将旧数据从内存中删除,为新数据腾出空间。 Memcached的数据回收机制使用LRU(Least Recently Used,近期最少使用)算法,同一时候优先清除与新数据大小差点儿相同的旧数据块。 相比之下,Redis同意细粒度控制过期缓存,有6种不同的策略可供选择。 Redis还採用了一些更复杂的内存管理方法和回收策略。

Redis对缓存的对象提供更大的灵活性。 而Memcached限制 key 为250字节,限制 value 为1 MB,且仅仅能通过纯文本String通信. Redis的 key 和 value 限制大小都是512 MB,是二进制安全的【即不丢数据,与编码无关】。

Redis提供6种数据类型,使缓存以及管理缓存变得更加智能和方便,为应用程序开发人员打开了一个无限可能的世界。

相比将对象序列化后通过字符串存储, Redis 通过 Hash来存储一个对象的字段和值,并能够通过单个key来管理它们。

看看用Memcached更新一个对象须要干什么:

  1. 获取整个字符串
  2. 反序列化为对象
  3. 改动当中的值
  4. 再次序列化该对象
  5. 在缓存中将整个字符串替换为新字符串

并且每次更新都要干这些破事。

而使用Redis Hash的方式, 能够大幅度减少资源消耗并提高性能。

Redis的其它数据类型,如List 或者 Set,可用来实现更复杂的缓存管理模式。

Redis的还有一个重大长处是其存储的数据是不透明的,这意味着在server端能够直接操纵这些数据。

160多个命令中的大部分都能够用来进行数据操作, 所以通过服务端脚本调用进行数据处理成为现实。

这些内置命令和用户脚本能够让你直接灵活地处理数据任务,而无需通过网络将传输数据给还有一个系统进行处理。

Redis提供了可选/可调整的数据持久化, 目的是为了在 崩溃/重新启动后能够高速载入缓存。

尽管我们一般觉得缓存中的数据是不稳定,瞬时的, 但在缓存系统中将数据持久化到磁盘还是非常有价值的。

在重新启动后马上载入预热的方式耗时非常短, 并且减轻了主数据库系统的开销。

最后, Redis提供主从复制(replication)。 Replication 可用于实现高可用的cache系统,同意某些server宕机的情况下也能提供不间断的服务。 如果要求在某台缓存server崩溃时, 仅仅有少部分用户和程序在短时间内受影响, 大多数情况下就须要有一个行之有效的解决方式,来保证缓存内容和服务的可用性。

当今开源软件一直在提供最佳的有用技术方案。 须要使用缓存来提高应用系统性能时,Redis和Memcached是最佳的产品级解决方式。 但考虑到其丰富的功能和先进的设计,绝大多数时候Redis都应该是你的第一选择。

作者简单介绍: Itamar Haber (@itamarhaber) 是 Redis Labs的首席开发人员, 该企业为开发人员提供全然托管的Memcached和Redis云服务。

具有多年软件产品研发经验,曾在 Xeround, Etagon, Amicada, and M.N.S Ltd.担任管理和领导职位. Itamar 获得 Northwestern and Tel-Aviv Universitiesd 的Kellogg-Recanati工商管理硕士, 以及 Science in Computer Science 学士。

相关阅读:

原文链接: Why Redis beats Memcached for caching

原文日期: 2014-10-15

翻译日期: 2014-10-23

翻译人员: 锚的

为什么Redis比Memcached易的更多相关文章

  1. Redis,MemCached,MongoDB 概述

    调研项目主要有Redis. MemCached. MongoDB,以及Amazon的DynamoDB Redis 是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key- ...

  2. 数据库应用(Mysql、Mongodb、Redis、Memcached、CouchDB、Cassandra)

    目前,主流数据库包括关系型(SQL)和非关系型(NoSQL)两种. 关系数据库是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据,支持复杂的事物处理和结构化查询.代表实 ...

  3. 该用哪个:Redis与Memcached之间如何选择呢?

    华为云分布式缓存Redis5.0和Memcached都是华为云DCS的核心产品. 那么在不同的使用场景之下,如何选择Redis5.0和Memcached呢? 就由小编为大家进行详细的数据对比分析吧 R ...

  4. mongodb,redis,memcached,mysql对比

    1.性能都比较高,性能对我们来说应该都不是瓶颈总体来讲,TPS方面redis和memcache差不多,要大于mongodb 2.操作的便利性memcache数据结构单一redis丰富一些,数据操作方面 ...

  5. 浅谈redis和memcached的区别

    缓存技术方面说到redis大家必然会联想到memcached,了解它们的人应该都知道以下几点吧 redis与 memcached相比,redis支持key-value数据类型,同事支持list.set ...

  6. Redis 对比 Memcached 并在 CentOS 下进行安装配置

    了解一下 Redis Redis 是一个开源.支持网络.基于内存.键值对的 Key-Value 数据库,使用 ANSI C 编写,并提供多种语言的 API ,它几乎没有上手难度,只需要几分钟我们就能完 ...

  7. Redis和Memcached整体

    Redis和Memcached整体对比 Redis的作者Salvatore Sanfilippo曾经对这两种基于内存的数据存储系统进行过比较,总体来看还是比较客观的,现总结如下: 1)性能对比:由于R ...

  8. redis、memcached、mongoDB 对比与安装

    一.redis.memcached.mongoDB 对比 Memcached 和 Redis都是内存型数据库,数据保存在内存中,通过tcp直接存取,速度快,并发高.Mongodb是文档型的非关系型数据 ...

  9. redis和memcached缓存

    memcached memcache开源的,高性能,高并发分布式内存缓存系统,天生支持集群 memcached下载地址: http://memcached.org/downloads python实现 ...

随机推荐

  1. Virtualbox mouse move in and out and file share with windows

    How to use Virstalbox to share files with Linux and Windows, and to move the mouse in and out Virtua ...

  2. RANSAC - 随机采样一致性算法

    RANSAC范例的正式描述如下: 首先,要给定: 1一个模型,该模型需要最少n个数据点去实例化它的自由参数: 2一组数据点P,P中包含数据点的数量#(P)大于n. 然后, 从P中随机地选择n个点(组成 ...

  3. linux使用进阶(一)

    本文依据<应该知道的Linux技巧>coolshell上的一篇文章提到的Linux技巧,结合自己掌握的情况进行扩展和总结得来.主要包含下面内容:     一.日常操作     二.数据处理 ...

  4. C编译: makefile基础

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在编译一个大型项目的时候,往往有很多目标文件.库文件.头文件以及最终的可执行文件. ...

  5. Devstack: A copy of worked local.conf I&#39;m sharing with you.

    service_plugins = neutron.services.firewall.fwaas_plugin.FirewallPlugin [service_providers] service_ ...

  6. SQL语句查询数据库的触发器、存储过程、视图以及表的SQL语句

    Sql Server数据库用SQL语句查询方法如下: select name from sysobjects where xtype='TR' --所有触发器 select name from sys ...

  7. Linux SSH端口转发

    SSH端口转发分为两种,一种是本地端口转发,又称为本地SSH隧道.一直是远程端口转发.SSH端口转发,还必须指定数据传送的目标主机,从而形成点对点的端口转发. 本地端口转发     假定有三台主机A. ...

  8. SE 2014年4月14日

    一. 概述BGP的特点 BGP协议是一种距离矢量协议,基于TCP的179端口,BGP协议不会动态的学习路由,只能将IGP协议学习到的或者静态路由注入到BGP中,成为BGP路由,BGP路由携带有丰富的路 ...

  9. [Leetcode]-ReverseLinkedList

    题目:单链表取反 #include <stdlib.h> #include <stdio.h> typedef struct node *list; typedef struc ...

  10. 《Cocos2d-x实战(卷Ⅰ):C++开发》

    <Cocos2d-x实战(卷Ⅰ):C++开发>   基础篇 第1章    准备开始 1.1   本书学习路线图 1.2   使用实例代码   第2章    Cocos2d-x介绍与环境搭建 ...