Memcache介绍

概念:Memcache是一个高性能,分布式内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

Memcache特性:

1)使用物理内存作为缓存区,可独立运行在服务器上。每个进程最大2G,如果想缓存更多的数据,可以开辟更多的memcache进程(不同端口)或者使用分布式memcache进行缓存,将数据缓存到不同的物理机或者虚拟机上。

2)使用key-value的方式来存储数据,这是一种单索引的结构化数据组织形式,可使数据项查询时间复杂度为O(1)。

3)协议简单:基于文本行的协议,直接通过telnet在memcached服务器上可进行存取数据操作,简单,方便多种缓存参考此协议;

4)基于libevent高性能通信:Libevent是一套利用C开发的程序库,它将BSD系统的kqueue,Linux系统的epoll(Linux2.6内核)等事件处理功能封装成一个接口,与传统的select相比,提高了性能。

5)内置的内存管理方式:所有数据都保存在内存中,存取数据比硬盘快,当内存满后,通过LRU算法自动删除不使用的缓存,但没有考虑数据的容灾问题,重启服务,所有数据会丢失。

6)分布式:各个memcached服务器之间互不通信,各自独立存取数据,不共享任何信息。服务器并不具有分布式功能,分布式部署取决于memcache客户端、

7)缓存策略:Memcached的缓存策略是LRU(最近最少使用)到期失效策略。在memcached内存储数据项时,可以指定它在缓存的失效时间,默认为永久。当memcached服务器用完分配的内时,失效的数据被首先替换,然后也是最近未使用的数据。在LRU中,memcached使用的是一种Lazy Expiration策略,自己不会监控存入的key/vlue对是否过期,而是在获取key值时查看记录的时间戳,检查key/value对空间是否过期,这样可减轻服务器的负载。

Redis

Redis 介绍

Redis是一个开源(BSD许可)的,基于内存的,多数据结构存储系统。可以用作数据库、缓存和消息中间件。 支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists),集合(sets), 有序集合(sorted sets) 与范围查询,bitmaps,hyperloglogs和 地理空间(geospatial) 索引半径查询,内置了 复制(replication),LUA脚本(Lua scripting),LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(high availability)。

区别

简单地比较Redis与Memcached的区别

  1. Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。
  2. Redis支持数据的备份,即master-slave模式的数据备份。
  3. Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。

在Redis中,并不是所有的数据都一直存储在内存中的。这是和Memcached相比一个最大的区别。Redis只会缓存所有的key的信息,如果Redis发现内存的使用量超过了某一个阀值,将触发swap的操作,Redis根据“swappability = age*log(size_in_memory)”计算出哪些key对应的value需要swap到磁盘。然后再将这些key对应的value持久化到磁盘中,同时在内存中清除。这种特性使得Redis可以保持超过其机器本身内存大小的数据。当然,机器本身的内存必须要能够保持所有的key,毕竟这些数据是不会进行swap操作的。同时由于Redis将内存中的数据swap到磁盘中的时候,提供服务的主线程和进行swap操作的子线程会共享这部分内存,所以如果更新需要swap的数据,Redis将阻塞这个操作,直到子线程完成swap操作后才可以进行修改。

当从Redis中读取数据的时候,如果读取的key对应的value不在内存中,那么Redis就需要从swap文件中加载相应数据,然后再返回给请求方。这里就存在一个I/O线程池的问题。在默认的情况下,Redis会出现阻塞,即完成所有的swap文件加载后才会相应。这种策略在客户端的数量较小,进行批量操作的时候比较合适。但是如果将Redis应用在一个大型的网站应用程序中,这显然是无法满足大并发的情况的。所以Redis运行我们设置I/O线程池的大小,对需要从swap文件中加载相应数据的读取请求进行并发操作,减少阻塞的时间。

Redis 和Memcache各方面介绍区别

  1. 性能:TPS方面redis和memcache差不多,redis:单核,因此在大数据量的情况下,略逊色于Memcache, Memcache:多核,多线程,性能强劲,但是在数据量不大时,优势不明显
  2. 操作的便利性:memcache数据结构单一,redis丰富一些,数据操作方面,redis更好一些,较少的网络IO次数
  3. 内存空间的大小和数据量的大小:redis在2.0版本后增加了自己的VM特性,突破物理内存的限制;可以对key value设置过期时间(类似memcache)。memcache可以修改最大可用内存,采用LRU算法
  4. 可用性(单点问题):对于单点问题,redis,依赖客户端来实现分布式读写;主从复制时,每次从节点重新连接主节点都要依赖整个快照,无增量复制,因性能和效率问题,所以单点问题比较复杂;不支持自动sharding,需要依赖程序设定一致hash 机制。一种替代方案是,不用redis本身的复制机制,采用自己做主动复制(多份存储),或者改成增量复制的方式(需要自己实现),一致性问题和性能的权衡。Memcache本身没有数据冗余机制,也没必要;对于故障预防,采用依赖成熟的hash或者环状的算法,解决单点故障引起的抖动问题。
  5. 可靠性(持久化):对于数据持久化和数据恢复,redis支持(快照、AOF):依赖快照进行持久化,aof增强了可靠性的同时,对性能有所影响memcache不支持,通常用在做缓存,提升性能;
  6. 数据一致性(事务支持):Memcache 在并发场景下,用cas保证一致性redis事务支持比较弱,只能保证事务中的每个操作连续执行
  7. 应用场景:  redis:数据量较小的更性能操作和运算上,memcache:用于在动态系统中减少数据库负载,提升性能;做缓存,提高性能(适合读多写少,对于数据量比较大,可以采用sharding)

转载于:https://www.cnblogs.com/liang-io/p/10322718.html

Redis和Mecahe的简介相关推荐

  1. Redis Cluster搭建方法简介22211111

    Redis Cluster搭建方法简介 (2013-05-29 17:08:57) 转载▼ Redis Cluster即Redis的分布式版本,将是Redis继支持Lua脚本之后的又一重磅功能,官方声 ...

  2. php redis list llen,redis llen list 命令简介

    一.命令简介 llen list命令在redis中的主要功能是: 返回一个list(列表)中的元素个数. 二.命令使用说明 命令语法如下: redis 192.168.8.123>llen li ...

  3. redis 自减命令_Redis 实战 —— 04. Redis 数据结构常用命令简介

    字符串 P39 Redis 的字符串是一个有字节组成的序列,可以存储以下 3 种类型的值:字节串(byte string).整数.浮点数. 在需要的时候, Redis 会将整数转换成浮点数.整数的取值 ...

  4. Redis 一个key-value存储系统 简介

    简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些 ...

  5. Redis分布锁原理简介和实现过程

    前言 这篇文章介绍下如何实现redis来实现分布式锁及原理简介 原理简介 redis 获取分布式锁使用lua脚本的命令 setnx pexpire(提供了毫秒的过期时间,expire提供了基于秒的过期 ...

  6. redis学习之redis的安装和简介

    redis简介 Redis是一个开源的,高性能的,基于键值对的缓存与存储系统,通过设置各种键值数据类型来适应不同场景下的缓存与存储需求.同时redis的诸多高层级功能使其可以胜任消息队列,任务队列等不 ...

  7. redis系列之1----redis简介以及linux上的安装

    redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssd ...

  8. Redis进阶-发布订阅简介

    1. Redis 发布订阅简介 Redis 发布订阅(pub/sub)是一种消息通信模式: 发送者(pub):发送消息 订阅者(sub):接收消息 Redis的 subscribe命令可以让客户端订阅 ...

  9. redis(一)--简介

    redis是一个可以替换memcached使用的,key--object类型的分布式数据存储节点.(非关系型数据库,算是nosql吧~). 与memcached对比,窃以为最大的不同点是: 1.可持久 ...

最新文章

  1. 灰度值取值范围_一幅灰度图像,用8bit量化,取值范围为[0,255],其中0表示(),255表示()。...
  2. 网站互点排名掉了网站互点排名掉了网站互点_7天上百度首页排名优化技巧有哪些?...
  3. thinking-in-java(20)注解
  4. 小学计算机教师德育工作计划,小学教师个人德育工作计划
  5. [转载] Python字典的setdefault()方法
  6. MongoDB应用上的坑
  7. 服装PDM产品数据管理
  8. C语言 基础的数学思维题
  9. 电容的耐压值选择---陶瓷电容、钽电容、电解电容
  10. 二十五、PHP内核探索:常量的实现 ☞ 脱离C语言和数学讨论底层都是耍流氓
  11. 计算机类期刊投稿心得
  12. char类型数据说明
  13. 防护器件-ESD管知识普及
  14. 从0开发游戏引擎之引擎基础组件-Node类实现
  15. 封闭类(Sealed Classes)
  16. 干货分享:大数据可视决策关键技术有哪些?分析篇
  17. 情感驿站 | 大学生应该明白的事情
  18. 周报2京东页面及js
  19. 关于微服务,这些你都了解吗-微服务介绍
  20. CPU密集型、数据密集型与IO密集型

热门文章

  1. C#实现拉格朗日、牛顿、Hermite插值
  2. Java遍历目录下的所有文件
  3. 歌唱大赛选手成绩计算
  4. ps中海报设计的设计思路
  5. Nubia Z18 联通VoLte修复,基带文件
  6. 微信公众平台测试帐号申请最新地址
  7. python网络数据采集 Tesseract
  8. inter cpu 测试软件,Intel官方CPU检测工具
  9. VSCode搭建Vue项目及服务器部署
  10. ARM处理器的 Handler mode 与 Thread mode 以及 MSP 和 PSP