为什么不用redis做主数据库,只用它做缓存?
一、为什么不用redis做主数据库,只用它做缓存
1.Redis的内存架构
Redis是内存数据库,这意味着它将所有数据存储在内存中,而不是在硬盘上。这使得Redis的读写速度非常快,但也使得它非常适合存储临时数据,而不是持久数据。如果我们将Redis用作主数据库,我们的数据将不能持久化,也就是说,如果服务器崩溃或断电,我们将失去所有数据。这是因为Redis的数据存储在内存中,一旦服务器重启,内存中的数据将被清空,所有的数据将丢失。
2.Redis的单线程架构
Redis是单线程的,这意味着它一次只能处理一个请求。如果我们将Redis用作主数据库,当并发请求增加时,Redis将无法处理它们,从而导致性能问题和响应时间延迟。相比之下,像MySQL这样的关系型数据库可以处理多个请求。如果我们有大量的并发请求需要处理,Redis可能会成为性能瓶颈。
3.Redis不支持SQL查询
Redis不支持SQL查询,这意味着我们无法使用SQL语言来查询数据。虽然Redis提供了一些基本的查询功能,但它无法处理复杂的查询请求。相比之下,像MySQL这样的关系型数据库提供了强大的SQL查询功能。如果我们需要进行复杂的查询,Redis可能会无法胜任。
4.示例:Redis作为主数据库可能会导致数据丢失
以下是一个简单的示例,主要说明为什么使用Redis作为主数据库可能会导致数据丢失。假设我们正在构建一个在线商店,并使用Redis来存储库存量。我们将商品数量存储在Redis中,并在每次销售后减少库存量。如果我们使用Redis作为主数据库,当服务器崩溃时,我们将失去所有库存数据。如果我们使用MySQL等关系型数据库,我们可以将库存数据持久化并在服务器崩溃后恢复它们。
import redis
r = redis.Redis(host=’localhost’, port=6379, db=0)
# 假设我们有100个商品
r.set(‘inventory’, 100)
# 当有人购买一个商品时,我们减少库存量
r.decr(‘inventory’)
# 当服务器崩溃并重启时,我们将失去所有库存数据
延伸阅读:
二、主要的单机存储引擎
1、哈希存储:hash的CRUD是非常快的。但缺点是不支持顺序扫描。bitcask是一个基于hash表结构的存储系统。他将写操作(包括删除标识)追加到文件尾。并定期合并新老文件&记录。
2、B树:既支持随机读取又支持范围查找的系统。查找时间复杂度为logd(n)(d为每个节点的出度)。Mysql的InnoDB的引擎和OS的文件系统使用的就是B+树。(为什么选择使用B树的变种B+树,读者有兴趣可以去探究下。提示:磁盘读取)
3、LSM树(Log Structured Merge Tree):由B+数改进而来。其思想为:将增量写操作保存在内存中,超过阈值时刷入磁盘,从而减少随机写磁盘操作。读操作则需要合并磁盘数据和内存中的写操作。通过Memtable/SSTable实现,实现细节在此不做深入探究。比较适合写操作较多的业务场景。BigTable/HBase/Cassandra中的列簇的数据存储方式采用的即是LSM树。

猜你喜欢LIKE
相关推荐HOT
更多>>
为什么Oracle数据库没有很好的卸载工具?
一、Oracle数据库没有很好的卸载工具的原因1、安装程序以压缩包形式存在大部分Oracle数据库安装程序都是以压缩包存在的,没有独立的卸载程序。...详情>>
2023-10-18 18:40:58
mysql的Innodb引擎中,主键索引和普通索引的工作原理是什么?
一、mysql的Innodb引擎中,主键索引和普通索引的工作原理在InnoDB中,表都是根据主键顺序以索引的形式存放的,这种存储方式的表称为索引组织表...详情>>
2023-10-18 15:19:29
非常适合移动和桌面应用的JavaScript框架是什么?
一、React NativeReact Native是一个广受欢迎的JavaScript框架,特别适合移动应用开发。它允许开发者使用JavaScript和React的语法来构建原生移...详情>>
2023-10-18 13:10:11
一个事务提交时,redo log和undo log以及bin log的生成流程是怎么样的?
一、redo log和undo log以及bin log的生成流程1.undolog是在innodb的回滚段里的(确切是rollback segment->undo segment),这个也是buff...详情>>
2023-10-18 12:35:31热门推荐
用什么数据库存储大量简单数据比较合适?
沸JAVA实现短网址服务的原理是什么?
热安卓原生app开发为什么要用sql本地数据库?
热oracle数据库库中两个表之间怎么同步数据?
新为什么Oracle数据库没有很好的卸载工具?
怎样用java向MySQL中的表插入1亿条数据?
做一个公司内部使用的小程序,应该用什么语言和数据库?
如何建立数据库,利用什么软件建立数据库?
org.Hs.eg.db包载入失败是为什么?
mysql update主键更新很慢会是什么原因?
如果同一条记录同时多个进程可能对不同的字段进行修改,怎么保证列锁?
mysql的Innodb引擎中,主键索引和普通索引的工作原理是什么?
Plugin解决了什么问题?
Python的pymysql、mysql、mysqlx库都有什么区别?
技术干货






