简介
redis在国内被众多的企业作为使用内存来实现高性能的io的解决方案。使用场景包括了数据库,缓存,消息中间件等。支持多种类型的数据结构,以及提供持久化,LRU,事务,负载均衡等多种功能
redis的数据结构
redis支持的数据结构包括了stirng、list、set、sorted set、hashes等多种形式
redis key
redis key值是二进制安全的,意思是可以使用任何的二进制序列作为key值,包括了空字符串。
不宜设置太长的key,因为消耗内存,对查找key的计算成本很高。
太短也不利于提高代码的易读性
redis基本操作
基础的get和set操作
set myKey myValue
get myKey
set get的操作升级版还有mset mget 批量赋值和批量取值
mset a 10 b 20 c 30
mget a b c
1) "10"
2) "20"
3) "30"
自增操作
set counter 100
incr counter (自增 counter++)
incrby counter 50 (自增50 counter+=50)
incr操作是一个原子操作,可以多线程执行也不造成混乱,类似的还有decr、decrby
对键空间的操作
exists myKey(是否存在myKey)
del myKey(删除)
type myKey(返回类型)
过期时间
redis所有的key值都存在一个默认的超期时间,默认情况下为-1,表示永不过期
使用expire myKey 10 可以设置过期时间
persist 命令可以去除过期时间
ttl myKey 可以查看离过期时间还有多久
List
redis的list是基于linkedList实现的,这个意味着redis 的list在头部以及尾部添加或删除数据是非常快的,缺点就是无法往中间插入数据,以及读取中间的数据是非常的缓慢。
当需要快速访问整个集合时,可以尝试使用sorted set排序集合
list的基础操作
list (也包括set、sorted set、hash)不需要创建或者删除操作,当推入一个值或者最后一个值被推出时,list就会自动被创建或删除
lpush myList A (向左边添加一个新元素\向队头添加新元素)
rpush myLisy B (向右边添加一个新元素\向队尾添加新元素)
rpush myLisy A B C D (批量操作)
rpop myList(取出最后一个元素并将元素从list中删除)
lrange myList 0 -1(取出从第0个元素到第-1个元素的所有值)
0表示第一个元素,-1表示倒数第一个元素(就是最后一个元素),-2表示倒数第二个元素
ltrim myList 0 2 (截取从0到2的所有元素作为新的myList)
list的阻塞操作
brpop和blpop ,可以指定在某一段时间内阻塞性的获取数据,获取不到数据就会一直阻塞,直到获取成功或者超时。同时redis会为阻塞的消费者顺序排队
可以解决一些需要轮询的场景的出现
hash
hash类似于将map存入redis
hmset myHash username zhangsan password 123456
hget myHash username
> zhangsan
hget myHash password
> 123456
hgetall myHash
> "username"
> "zhangsan"
> "password"
> "123456"
hash可以便捷的存储object
hash也可以对里面单独的域进行操作
如自增操作:
hincrby myHash birthyear 10
有一个点需要注意的是,hash里面的小的hash,被特殊的方式编码,非常节约内存
Set
set是string的无序列表,无法保存相同的数据
常见的使用场景包括了判断一个元素是否存在,两个set之间的交集、并集、差、获取随机元素等操作
读取操作
sadd mySet 1 2 3
smembers mySet
>2
>1
>3
sismember mySet 3 (是否存在元素3)
>1 (存在)
order set
相当于一个有序的set
在写入数据的时候需要多写入一个得分的值
zadd myOrdersSet 20 A
zadd myOrderSet 10 B
zadd myOrderSet 30 C
zrange myOrderSet 0 -1 (按得分升序读取从第0个元素到最后一个元素)
> B
> A
> C
zrevrange myOrdereSet 0 -1 (降序排序)
如果得分相同,会按照value的字符字典顺序排序
zrangebyscore myOrderSet -inf 20(读取小于等于20分的数据)
zremrangebyscore myOrderSet 10 20 (10分到20分的数据)
可以使用的场景包括排行榜等
参考文献:redis官方文档