1、redis介绍
Redis:REmote Dictionary Server(远程字典服务器)
官网解释:
- Redis是一个开源的(BSD许可)内存数据结构存储,用作数据库、缓存、消息代理和流引擎。Redis提供数据结构,例如 字符串、散列、列表、集合、带范围查询的排序集合、位图、超级日志、地理空间索引和流。Redis具有内置的复制、Lua脚本、LRU逐出、事务和不同级别的磁盘持久性,并通过Redis Sentinel和Redis Cluster的自动分区提供高可用性。
Redis之父:
- Salvatore Sanfilippo
- 一名意大利程序员
- 大家更习惯称呼他Antirez
Antirez的GitHub账号
Antirez的个人博客:
2、redis的功能
2.1、主流功能和应用
- 分布式缓存,挡在mysql数据库之前的带刀护卫
Redis VS MySql
-
Redis是key-value数据库(NoSQL一种),mysql是关系数据库
-
Redis数据操作主要在内存,而mysql主要存储在磁盘
-
Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面
-
Redis通常用于一些特定场景,需要与Mysql一起配合使用
-
两者并不是相互替换和竞争关系,而是共用和配合使用
- 内存存储和持久化(RDB+AOF)——redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务
- 高可用架构搭配
- 单机
- 主从
- 哨兵
- 集群
- 缓存穿透、击穿、雪崩
- 分布式锁
- 队列
- Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。
- 我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。
- 排行版+点赞
- 在互联网应用中,有各种各样的排行榜,如电商网站的月度销量排行榜、社交APP的礼物排行榜、小程序的投票排行榜等等。Redis提供的zset数据类型能够快速实现这些复杂的排行榜。
- 比如小说网站对小说进行排名,根据排名,将排名靠前的小说推荐给用户。
2.2、总体功能概述
2.3、优势
- 性能极高-Redis能读的速度是110000次/秒,写的速度是81000次/秒
- Redis数据类型丰富,不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储
- Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
- Redis支持数据的备份,即master-slave模式的数据备份
总的来说:Redis是一种Key-Value类型的缓存数据库