mysql的MEMORY引擎为什么没有redis的应用广泛?
一、mysql的MEMORY引擎为什么没有redis的应用广泛
从kv缓存的作用看,mysql优点不在kv缓存上,用它做kv缓存维护成本高,redis安装启动使用简单,mysql效率功能也没redis强大,
redis专门针对一些场景做了优化,例如计数器,可以精确计数,精度要求不高也可以模糊计数,占用内存更少;集合间的各种操作更简单高效,典型应用场景社交应用下好友,粉丝各种操作。
redis支持两种数据持久化方式:RDB和AOF,这也是redis区别与其他nosql内存数据库的一个主要特点。
RDB主要可以用作冷备,默认情况下每5分钟将会fork出一个子进程,进行当前数据快照的持久化(这里的内存为了保证备份期间数据的一致性,这里还用到了一个概念:写时复制COW)。除此之外,RDB还具备一下几个特点:
生成一组持久化文件,每一个文件都代表了某一时刻的内存数据快照。
数据恢复速度快。
由于是由后台子进程进行数据备份,对线上系统的QPS影响较小。但如果后台需要备份的数据量较大,则由于进程调度原因,可能会导致线上业务停滞。
默认每五分钟生成一次数据副本,数据的可靠性并不高。
AOF则是以追加写的方式,将对Redis的更新操作全部写入aof文件。aof具有以下特点:
AOF默认每1s通过后台线程进行一次fsync操作,数据的可靠性比较高,非常多丢失1s的数据。
AOF采用append-only的方式写入日志文件,由于是顺序写,没有磁盘寻址的开销,速度很快。
AOF日志的可读性很强,可以执行一些紧急处理。
但是AOF日志普遍要比RDB文件大,这是由于AOF日志需要记录redis实例启动以来的所有更新操作,以便对数据库进行重放,恢复数据。
由于需要保证数据的可靠性而每秒执行的fsync操作,会降低线上的QPS。
因此通过RDB和AOF的配合使用,就可以在保证效率的同时尽可能的保证数据的可靠性。这是Memory存储引擎所不具备的。
除此之外,Redis通过nio模型,利用单个线程监听多个socket,将对redis的操作全部转换为文件事件操作。大大提高了并发性。
延伸阅读:
二、什么是Memory引擎
Memory引擎是Mysql的内存引擎,在实现上,Memory存储引擎不同于Innodb这种组织索引结构(索引即是数据,即数据存放在主键索引上),而是将索引和数据分开存储。索引采用Hash的形式,存放主键id和指向数据的指针,而数据则按插入顺序存放。我们称这种数据组织方式为堆组织方式。

相关推荐HOT
更多>>
mysql的MEMORY引擎为什么没有redis的应用广泛?
一、mysql的MEMORY引擎为什么没有redis的应用广泛从kv缓存的作用看,mysql优点不在kv缓存上,用它做kv缓存维护成本高,redis安装启动使用简单,...详情>>
2023-10-20 18:38:17
什么是PWA?
一、什么是PWAPWA是渐进式 Web 应用,运用现代的 Web API 以及传统的渐进式增强策略来创建跨平台 Web 应用程序。。这些应用无处不在、功能丰富...详情>>
2023-10-20 14:02:19
软件包“被标记为手动安装”是什么意思?
一、软件包“被标记为手动安装”是什么意思当你尝试安装已安装的库或开发包时,你会看到此消息。意味着该软件包是由用户手动安装的,而不是通过...详情>>
2023-10-20 11:47:20
什么是Flash?
一、什么是FlashFlash是一种基于向量图形的动画技术,由Adobe公司开发。它支持多媒体、游戏、网站设计等应用,可以在各种平台和设备上实现高质...详情>>
2023-10-20 10:24:01热门推荐
一个优异的web前端,需要具备哪些条件?
沸华为自研的数据库gaussdb有哪些优势?
热数据库ER图是怎么做的?
热为什么使用MySQL?
新什么是synchronized?
既然MySQL中InnoDB使用MVCC,为什么REPEATABLE-READ不能消除幻读?
分布式系统里用户ID生成有什么好的方法和规则能满足“少数、尽量短、不能直接看出规则”这几个条件?
isKindOfClass、isMemberOfClass 作用分别是什么?
APP开发流程步骤有哪些?
mysql的MEMORY引擎为什么没有redis的应用广泛?
webpack proxy工作原理为什么能解决跨域?
python的五个特点?
staticmethod和classmethod的区别?
Android App设计开发应遵循哪些原则?
技术干货






