文档章节

Redis与Memcached的区别

underA
 underA
发布于 2013/05/15 23:25
字数 991
阅读 126
收藏 1
点赞 0
评论 0

memcached和redis的区别

区别:

1、数据类型不同,memcached只支持key-value,redis支持String,List,Map,set,sorted Set

 

2、memcached保存在内存中,redis内存和文件里面都有保存,宕机之后memcached完全丢失,redis还可以从文件中恢复到内存中

3、memcahed的内存分配是基于slab划分的,通过page(默认1M)申请内存,然后每个slab会划分为好多的chunk,数据都存储在chunk中,redis为了屏蔽不同平台之间的差异,redis对内存分配函数进行了一层封装,程序中统一使用zmalloc,zfree一系列函数

 

4、memcahed基于libevent网络库,而redis是基于epoll网络模型,紧接着说下,

select,poll,epoll的区别

select同步阻塞,最大文件描述符1024,

poll同步阻塞,没有最大文件描述符限制,

epoll异步非阻塞,没有最大文件描述符限制。

select是轮询式的事件通知,

epoll是回调事件通知callback

5、memcahed多线程的,redis是单线程的,redis使用epoll,这就是redis为什么使用单线程性能一点也不逊于memcahed的原因

 

 

6、key过期策略,memcahed采用的消极策略,也就是get时候判定做删除,redis除了消极策略,还有积极策略,积极清理就是每秒钟有一个定时任务会扫描10次

    1.随机测试100个设置了过期时间的key
    2.删除所有发现的已过期的key
    3.若删除的key超过25个则重复步骤1

7、memcahed只支持客户端的分布式,采用consistent hashing,redis有基于服务端的集群模式

 

8、memcached采用cas来保证数据一致性,redis有比较弱的事务支持

 

 

redis笔记

1、redis的数据类型

2、redis的key过期机制(消极过期和主动清理(积极过期))

3、redis的客户端jedis,序列化之类的

4、redis的集群怎么做的,jedis自带有一致性hash,但是不能自动剔除节点,twemproxy,可以自动剔除节点,但是它本身是个单点,需要用keepalive做个VIP高可用,cluster 3.0以后推出的方案 16384个slot,每个节点负责一部分的slot

5、redis采用了epoll机制,epoll异步非阻塞,并且是触发式的callback,顺带提一下,select同步阻塞的,最大文件描述符1024,poll同步阻塞的,最大文件描述符没有限制,epoll,异步非阻塞,没有最大文件描述符限制

 

Redis淘汰策略

Redis提供了下面几种淘汰策略供用户选择,其中默认的策略为noeviction策略:

  • noeviction:当内存使用达到阈值的时候,所有引起申请内存的命令会报错。
  • allkeys-lru:在主键空间中,优先移除最近未使用的key。
  • volatile-lru:在设置了过期时间的键空间中,优先移除最近未使用的key。
  • allkeys-random:在主键空间中,随机移除某个key。
  • volatile-random:在设置了过期时间的键空间中,随机移除某个key。
  • volatile-ttl:在设置了过期时间的键空间中,具有更早过期时间的key优先移除。

 

值得一提的是将key设置过期时间实际上会消耗更多的内存,因此我们建议使用allkeys-lru策略从而更有效率的使用内存。

 

下面看看几种策略的适用场景:

  • allkeys-lru:如果我们的应用对缓存的访问符合幂律分布(也就是存在相对热点数据),或者我们不太清楚我们应用的缓存访问分布状况,我们可以选择allkeys-lru策略。
  • allkeys-random:如果我们的应用对于缓存key的访问概率相等,则可以使用这个策略。
  • volatile-ttl:这种策略使得我们可以向Redis提示哪些key更适合被eviction。

© 著作权归作者所有

共有 人打赏支持
underA
粉丝 11
博文 143
码字总数 41595
作品 0
海淀
程序员
redis和其他缓存数据库的区别

Redis 与其他 key - value 缓存产品有以下三个特点: (1)Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。 (2)Redis不仅仅支持简单的key-val...

码上青天
05/03
0
0
Memcache与Redis有什么区别?

Redis 和 Memcache 都是基于内存的数据存储系统。Memcached是高性能分布式内存缓存服务,其本质上就是一个内存key-value数据库。Redis是一个开源的key-value存储系统。与Memcached类似,Red...

PaaS小魔仙
07/16
0
0
MongoDB与Redis的区别?他们分别用在什么场景下最合适?

最近在学习的时候,感觉对MongoDB与Redis的应用场景有点蒙,不知道这两个东西有什么核心应用区别,另外,还有人把这两个东西与Memcached比较,更是感觉风马牛不相及。 个人理解Memcached纯粹...

bluntFish
2016/05/22
10.4K
3
redis和memcache的区别

简单区别: 1. Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcached相比一个最大的区别。 2. redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储...

1243983186
2017/06/20
0
0
memcached和redis的区别

Redis的作者Salvatore Sanfilippo曾经对这两种基于内存的数据存储系统进行过比较,总体来看还是比较客观的,现总结如下: 1)性能对比:由于Redis只使用单核,而Memcached可以使用多核,所以...

疯狂的兔子
2015/03/09
168
0
PHPer面试指南-PHP 篇

本书的 GitHub 地址:https://github.com/todayqq/PHPerInterviewGuide PHP 篇收集了一些常见的基础、进阶面试题,基础的面试题不再作答。 基础篇 Get 和 POST 的区别 Cookie 和 Session 的区...

angkee
01/24
0
0
Redis 和 Memcached 的区别

了解过两者有个大致的印象:redis与memcached相比,不仅支持简单的key-value数据类型,同时还提供list,set,zset,hash等数据结构的存储;redis支持数据的备份,即master-slave模式的数据备份;...

爪哇程序猿
2017/10/19
0
0
Redis与Memcached的区别

传统MySQL+ Memcached架构遇到的问题   实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的不断增加...

蓝狐乐队
2014/05/22
0
0
也谈谈 Redis 和 Memcached 的区别

本文作者:伯乐在线 -朱小厮 。未经作者许可,禁止转载! 欢迎加入伯乐在线专栏作者。 说到redis就会联想到memcached,反之亦然。了解过两者的同学有那么个大致的印象: redis与memcached相比...

伯乐在线
2016/07/20
0
0
Memcached, Redis, MongoDB区别

mongodb和memcached不是一个范畴内的东西。mongodb是文档型的非关系型数据库,其优势在于查询功能比较强大,能存储海量数据。mongodb和memcached不存在谁替换谁的问题。 和memcached更为接近...

雍雍_yoyo
2016/03/01
70
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

SpringBoot | 第十章:Swagger2的集成和使用

前言 前一章节介绍了mybatisPlus的集成和简单使用,本章节开始接着上一章节的用户表,进行Swagger2的集成。现在都奉行前后端分离开发和微服务大行其道,分微服务及前后端分离后,前后端开发的...

oKong
今天
9
0
Python 最小二乘法 拟合 二次曲线

Python 二次拟合 随机生成数据,并且加上噪声干扰 构造需要拟合的函数形式,使用最小二乘法进行拟合 输出拟合后的参数 将拟合后的函数与原始数据绘图后进行对比 import numpy as npimport...

阿豪boy
今天
4
0
云拿 无人便利店

附近(上海市-航南路)开了家无人便利店.特意进去体验了一下.下面把自己看到的跟大家分享下. 经得现场工作人员同意后拍了几张照片.从外面看是这样.店门口的指导里强调:不要一次扫码多个人进入....

周翔
昨天
1
0
Java设计模式学习之工厂模式

在Java(或者叫做面向对象语言)的世界中,工厂模式被广泛应用于项目中,也许你并没有听说过,不过也许你已经在使用了。 简单来说,工厂模式的出现源于增加程序序的可扩展性,降低耦合度。之...

路小磊
昨天
177
1
npm profile 新功能介绍

转载地址 npm profile 新功能介绍 npm新版本新推来一个功能,npm profile,这个可以更改自己简介信息的命令,以后可以不用去登录网站来修改自己的简介了 具体的这个功能的支持大概是在6这个版...

durban
昨天
1
0
Serial2Ethernet Bi-redirection

Serial Tool Serial Tool is a utility for developing serial communications, custom protocols or device testing. You can set up bytes to send accordingly to your protocol and save......

zungyiu
昨天
1
0
python里求解物理学上的双弹簧质能系统

物理的模型如下: 在这个系统里有两个物体,它们的质量分别是m1和m2,被两个弹簧连接在一起,伸缩系统为k1和k2,左端固定。假定没有外力时,两个弹簧的长度为L1和L2。 由于两物体有重力,那么...

wangxuwei
昨天
0
0
apolloxlua 介绍

##项目介绍 apolloxlua 目前支持javascript到lua的翻译。可以在openresty和luajit里使用。这个工具分为两种模式, 一种是web模式,可以通过网页使用。另外一种是tool模式, 通常作为大规模翻...

钟元OSS
昨天
2
0
Mybatis入门

简介: 定义:Mybatis是一个支持普通SQL查询、存储过程和高级映射的持久层框架。 途径:MyBatis通过XML文件或者注解的形式配置映射,实现数据库查询。 特性:动态SQL语句。 文件结构:Mybat...

霍淇滨
昨天
2
0
开发技术瓶颈期,如何突破

前言 读书、学习的那些事情,以前我也陆续叨叨了不少,但总觉得 “学习方法” 就是一个永远在路上的话题。个人的能力、经验积累与习惯方法不尽相同,而且一篇文章甚至一本书都很难将学习方法...

_小迷糊
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部