二、缓存数据库--Redis(1) Redis是什么

一、简介

Redis 是一个开源的内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。

二、存储数据结构 

它支持多种类型的数据结构,如字符串(Strings),散列(Hashes),列表(Lists),集合(Sets),有序集合(Sorted Sets或者是ZSet) 与范围查询, Bitmaps,Hyperloglogs 和 地理空间(Geospatial)索引半径查询。 其中常见的数据结构类型有String、List、Set、Hash、ZSet这5种。

三、提供的多项功能 

Redis 内置了复制(Replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(Transactions) 和不同级别的磁盘持久化(Persistence), 并通过 Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(High Availability)。

四、数据持久化

Redis也提供了持久化的选项,这些选项可以让用户将自己的数据保存到磁盘上面进行存储。根据实际情况, 可以每隔一定时间将数据集导出到磁盘(快照),或者追加到命令日志中(AOF只追加文件),他会在执行写命令时,将被执行的写命令复制到硬盘里面。您也可以关闭持久化功能,将Redis作为一个高效的网络的缓存数据功能使用。

Redis不使用表,他的数据库不会预定义或者强制去要求用户对Redis存储的不同数据进行关联。

数据库的工作模式按存储方式可分为:硬盘数据库和内存数据库。Redis 将数据储存在内存里面,读写数据的时候都不会受到硬盘 I/O 速度的限制,所以速度极快。

(1)硬盘数据库的工作模式:

二、缓存数据库--Redis(1) Redis是什么

(2)内存数据库的工作模式:

二、缓存数据库--Redis(1) Redis是什么

五、Redis与其他nosql数据库的区别

1.Redis自身特性
(1)性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。(直接操作内存)

(2)丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

(3)原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。(单线程)

(4)丰富的特性 – Redis还支持 publish/subscribe(发布/订阅), 通知, key 过期等等特性。

  (5)  Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。

(3)Redis支持数据的备份,即master-slave模式的数据备份。

2.Redis与其他数据库的区别

二、缓存数据库--Redis(1) Redis是什么

参考文章:

https://blog.csdn.net/xlgen157387/article/details/60761232