什么是 Redis?
官网的介绍:“Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。”除此之外,你还应该了解,它是一个高性能的 key-value 数据库。它具有以下三个特点:
- Redis 支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis 不仅仅支持简单的 key-value 类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储。
- Redis 支持数据的备份,即 master-slave 模式的数据备份。(这里有一篇文章,简单介绍了主从结构,有很多图,可以更直观的理解。)
相比于其他 key-value 存储有什么不同?
- Redis 有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis 的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。
- Redis 运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上存储相同的复杂度的数据结构,在内存中操作起来更简单,这样 Redis 可以做很多内部复杂性很强的事情。同时,在磁盘格式方面 他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。
使用 redis 有什么好处?
- 速度快,因为数据存在内存中,类似于 HashMap,HashMap 的优势就是查找和操作的时间复杂度都是 O1。
- 支持丰富数据类型,支持 string,list,set,Zset,hash 等。
- 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行。
- 丰富的特性:可用于缓存或同步消息,按 key 设置过期时间,过期后将会自动删除。
它有哪些数据结构?
Redis 支持五种数据类型: string(字符串),hash(哈希),list(列表),set(集合)及 zsetsorted set:有序集合)。我们实际项目中比较常用的是 string,hash 如果你是 Redis 中高级用户,还需要加上下面几种数据结构 HyperLogLog、Geo、Pub/Sub。如果你说还玩过 Redis Module,像 BloomFilter,RedisSearch,Redis-ML,那你就很优秀了。
相比于 Memcached 有哪些优势?
- Memcached 所有的值均是简单的字符串,redis 作为其替代者,支持更为丰富的数据类型。
- Redis 的速度比 Memcached 更快。
- Redis 可以持久化数据。
今天的内容就聊到这里,Redis 的应用非常广泛,想要用好 redis,涉及的知识点也非常多,这里非常推荐一个网站,这个网站推荐的内容也很有价值,未来我还会继续学习相关内容。