博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
面试真题-----redis与memcached
阅读量:6072 次
发布时间:2019-06-20

本文共 1180 字,大约阅读时间需要 3 分钟。

Redis与Memcached的不同

1.网络IO模型

Memcached是多线程,非阻塞IO复用的网络模型,分为监听主线程和worker子线程,监听线程监听网络连接,接受请求后,将连接描述字pipe 传递给worker线程,进行读写IO, 网络层使用libevent封装的事件库,多线程模型可以发挥多核作用,但是引入了cache coherency和锁的问题,比如,Memcached最常用的stats 命令,实际Memcached所有操作都要对这个全局变量加锁,进行计数等工作,带来了性能损耗。 

Redis使用单线程的IO复用模型,自己封装了一个简单的AeEvent事件处理框架,主要实现了epoll、kqueue和select,对于单纯只 有IO操作来说,单线程可以将速度优势发挥到最大,但是Redis也提供了一些简单的计算功能,比如排序、聚合等,对于这些操作,单线程模型实际会严重影 响整体吞吐量,CPU计算过程中,整个IO调度都是被阻塞住的。

2.内存管理方面

Memcached使用预分配的内存池的方式,使用slab和大小不同的chunk来管理内存,Item根据大小选择合适的chunk存储,内存池的方式可以省去申请/释放内存的开销,并且能 减小内存碎片产生,但这种方式也会带来一定程度上的空间浪费,并且在内存仍然有很大空间时,新的数据也可能会被剔除,原因可以参考Timyang的文 章: 

Redis使用现场申请内存的方式来存储数据,并且很少使用free-list等方式来优化内存分配,会在一定程度上存在内存碎片,Redis跟据存储命 令参数,会把带过期时间的数据单独存放在一起,并把它们称为临时数据,非临时数据是永远不会被剔除的,即便物理内存不够,导致swap也不会剔除任何非临 时数据(但会尝试剔除部分临时数据),这点上Redis更适合作为存储而不是cache。

3.数据一致性问题

Memcached提供了cas命令,可以保证多个并发访问操作同一份数据的一致性问题。 Redis没有提供cas 命令,并不能保证这点,不过Redis提供了事务的功能,可以保证一串 命令的原子性,中间不会被任何操作打断。

4.存储方式及其它方面

Memcached基本只支持简单的key-value存储,不支持枚举,不支持持久化和复制等功能。Redis除key/value之外,还支持list,set,sorted set,hash等众多数据结构,提供了KEYS进行枚举操作,但不能在线上使用,如果需要枚举线上数据,Redis提供了工具可以直接扫描其dump文件,枚举出所有数据,Redis还同时提供了持久化和复制等功能。

 

转载---

转载于:https://www.cnblogs.com/technologykai/articles/9041838.html

你可能感兴趣的文章
我的友情链接
查看>>
Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
查看>>
网盘的另类玩法——命令行
查看>>
C++:一段代码,了解拷贝构造函数、move构造函数、拷贝赋值函数、move赋值函数、右值引用...
查看>>
linux下连接github并进行提交
查看>>
IdentityServer4 实现 OpenID Connect 和 OAuth 2.0
查看>>
【Java ThreadLocal的使用】
查看>>
tcp/ip学习笔记
查看>>
Android 浏览器的研究(五)--- 浏览器APK的Eclipse开发环境搭建
查看>>
Rsync企业实战之自动异地备份
查看>>
Spring cloud 学习资料汇总
查看>>
对网卡流量监控的一些想法
查看>>
团队 ≠ 人 + 人
查看>>
我的友情链接
查看>>
C89和C99标准比较
查看>>
PHP5.6和PHP7中函数中的一些新特性
查看>>
oracle linux 5.7 布署ogg v11 oracle to oracle之Configure Change Capture and delivery
查看>>
课余时间技术方面晋级
查看>>
算法数据结构复习[单链表]
查看>>
mongodb非关系型数据库nosql与关系型数据库sql对应学习
查看>>