Redis简介(基础篇系列一)
本篇会介绍关于Redis的基本知识,关于Redis的介绍和特点等。Redis是比较热门的数据库,所以我觉得学好和用好在工作上的帮助还是挺大的。
Redis是什么
来看一下官网的介绍:Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。
Redis全称:**REmote DIctionary Server(远程字典服务器)**。是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能的(key/value)分布式内存数据库,基于内存运行,并支持持久化的NoSQL数据库,是当前最热门的NoSQL数据库之一,也被人们称为数据结构服务器。
Redis的八大特性
速度快
正常情况下,Redis执行命令的速度非常快,官方给出的数字是读写性 能可以达到10万/秒,当然这也取决于机器的性能。后续的Redis高级文章会探究Redis为什么这么快。
基于键值对的数据结构服务器
Redis支持5种数据结构:字符串、哈希、列表、集合、有序集合。
丰富的功能
(1)提供了键过期功能,可以用来实现缓存。
(2)提供了发布订阅功能,可以用来实现消息系统。
(3)支持Lua脚本功能,可以利用Lua创造出新的Redis命令。
(4)提供了简单的事务功能,能在一定程度上保证事务特性。
(5)提供了流水线(Pipeline)功能,这样客户端能将一批命令一次性传到 Redis,减少了网络的开销。
简单稳定
首先,Redis的源码很少;其次,Redis使用单线程模型,这样不仅使得Redis服务端处理模型变得简单,而且也使得客户端开发变得简单。
客户端语言多
Redis提供了简单的TCP通信协议,很多编程语言可以很方便地接入到 Redis,并且由于Redis受到社区和各大公司的广泛认可,所以支持Redis的客户端语言也非常多,几乎涵盖了主流的编程语言,例如Java、PHP、 Python、C、C++、Nodejs等
持久化
持久化基本是数据库必备的功能,同样,Redis也提供了两种持久化方式:RDB和 AOF,即可以用两种策略将内存的数据保存到硬盘中,这样就保证了数据的可持久性,
主从复制
Redis提供了复制功能,实现了多个相同数据的Redis副本,复制功能也是分布式Redis的基础。
高可用和分布式
Redis从2.8版本正式提供了高可用实现Redis Sentinel,它能够保证Redis 节点的故障发现和故障自动转移。Redis从3.0版本正式提供了分布式实现 Redis Cluster,它是Redis真正的分布式实现,提供了高可用、读写和容量的扩展性。
Redis的五大数据类型
前面介绍Redis的特点有说到,Redis支持五大数据类型的数据,具体是key-value、list、set、hash、zset;下面我们就这五大数据类型,还有Redis的key(键)来分别介绍下:
key(键)
Redis 键命令用于管理 redis 的键。
关于键的常用操作:keys *
:查看所有key,key的数量较大的时候会造成redis阻塞,谨慎使用;*号符合其实是正则里面的*,所以keys命令后面可以写正则匹配key。exists key
:判断某个key是否存在,返回1代表存在,0代表不存在。move key db
:把该key从当前库移除。expire key 秒钟
:给这个key设置过期时间。ttl key
:查看这个key的生存时间,-1代表用不过期,-2代表已过期。type key
:查看这个key的类型。
String(字符串)
String是Redis的最基本的类型,一个key对应一个value;他是二进制安全的,意思就是Redis的String可以包含任何数据,例如jpg图片或者序列化的对象;Redis中一个字符串的value最多可以是512M。
关于字符串的常用操作:SET key value
:设置指定 key 的值。GET key
:获取指定 key 的值。GETSET key value
:将给定 key 的值设为 value ,并返回 key 的旧值(old value)。MGET key1 [key2..]
:获取所有(一个或多个)给定 key 的值。SETEX key seconds value
:将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)。SETNX key value
:只有在 key 不存在时设置 key 的值。STRLEN key
:返回 key 所储存的字符串值的长度。MSET key value [key value ...]
:同时设置一个或多个 key-value 对。MSETNX key value [key value ...]
:同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。INCR key
:将 key 中储存的数字值增一。DECR key
:将 key 中储存的数字值减一。
List(列表)
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。它的底层实际是个链表。一个列表最多可以包含 2的32次方 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
关于List的常用操作:LLEN key
:获取列表长度。LPOP key
:移出并获取列表的第一个元素。LPUSH key value1 [value2]
:将一个或多个值插入到列表头部。LRANGE key start stop
:获取列表指定范围内的元素。RPOP key
:移除列表的最后一个元素,返回值为移除的元素。RPUSH key value1 [value2]
:在列表中添加一个或多个值。RPUSHX key value
:为已存在的列表添加值。
set(集合)
Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
关于set的常用操作:SADD key member1 [member2]
:向集合添加一个或多个成员SCARD key
:获取集合的成员数SDIFF key1 [key2]
:返回第一个集合与其他集合之间的差异。SISMEMBER key member
:判断 member 元素是否是集合 key 的成员SMEMBERS key
:返回集合中的所有成员
zset(有序集合)
Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
关于zset的常用操作:ZADD key score1 member1 [score2 member2]
:向有序集合添加一个或多个成员,或者更新已存在成员的分数。ZCARD key
:获取有序集合的成员数。ZCOUNT key min max
:计算在有序集合中指定区间分数的成员数。
hash(哈希)
Redis hash 是一个 string 类型的 field(字段) 和 value(值) 的映射表,hash 特别适合用于存储对象。
Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。
关于hash的常用操作:HGETALL key
:获取在哈希表中指定 key 的所有字段和值。HKEYS key
:获取所有哈希表中的字段。HLEN key
:获取哈希表中字段的数量。HVALS key
:获取哈希表中所有值。
Redis使用场景
(1)缓存
Redis提供了键值过期时间设置,并且也提供了灵活控制最大内存和内存溢出后的淘汰策略。合理地使用Redis做缓存不仅可以加快数据的访问速度,而且能够有效地降低后端数据源的压力。
(2)排行榜系统
排行榜系统几乎存在于所有的网站,例如按照热度排名的排行榜,按照 发布时间的排行榜,按照各种复杂维度计算出的排行榜,Redis提供了列表 和有序集合数据结构,合理地使用这些数据结构可以很方便地构建各种排行 榜系统。
(3)计数器应用
Redis天然支持计数功能而且计数的性能也非常好,可以说是计数器系统的重要选择。例如视频网站有播放数、电商网站有浏览数,为了保证数据的实时性,每一次播放和浏览都要做加1的操作,如果并发量很大对于传统关系型数据的性能是一种挑战。
(4)社交网络
赞/踩、粉丝、共同好友/喜好、推送、下拉刷新等是社交网站的必备功能,由于社交网站访问量通常比较大,而且传统的关系型数据不太适合保存这种类型的数据,Redis提供的数据结构可以相对比较容易地实现这些功能。