Redis简单使用

Redis

简介

概念

基于键值对key-value的数据库,value可以为sting、hash、list、set、zset等多种数据结构。提供键过期,发布订阅,事务,流水线等功能。默认数据库有16个,使用select index 进行选择数据库 0-15

特性

  1. 速度快。数据存储在内存中。QPS=10万/s
  2. 单线程,避免多线程竞争问题,C语言实现。
  3. 持久化。可以将数据持久化到硬盘
  4. 主从复制。实现多个相同数据的redis副本
  5. 高可用和分布式。哨兵机制实现高可用,保证Redis节点故障发现和自动转移

使用场景

  1. 缓存:合理使用缓存加快数据访问速度,降低后端数据源压力
  2. 排行榜:按照热度排名,按照发布时间排行,主要用到列表和有序集合
  3. 计数器应用:视频网站播放数,网站浏览数,使用 redis 计数
  4. 社交网络:赞、踩、粉丝、下拉刷新
  5. 消息队列:发布和订阅

全局命令

  1. 查看所有键:keys *

  2. 键总数: dbsize //如果存在大量键,线上禁止使用此指令

  3. 检查键是否存在:exists key //存在返回 1,不存在返回 0

  4. 删除键:del key //返回删除键个数,删除不存在键返回 0

  5. 键过期:expire key seconds //设置键的过期时间(单位:秒) ttl:查看剩余的过期时间

  6. 值的数据结构类型:type key //键不存在返回 none

值的类型

字符串 String

存储结构

可以是字符串、xml、Json、数字、二进制。最大不能超过512M。

存取值

设置值:set age 18 ex 10 (键的存活时间为10秒)

获取值: get age

批量设置值:mset country china city sz

批量获取值:mget country city 使用mget= 1次网络请求+redis内部n次查询

计数

自加:

incr age // age的值必须为整数 非整数返回错误,无age键从0自增返回1

incrby age 2 // 自增2

Incrbyfloat score 1.1 // 浮点型自增

自减:

decr age // 减1

decrby age 2 // 自减2

其它

append 追加指令:append keyName value

字符串长度:strlen keyName // 每个中文占用3个字节

截取字符串:getrange keyName 2 4 // 从下标0开始计算截取[2,4]。截取之后,原数据不变

内部编码:object encoding keyName

键值设计

业务名:对象名:id:[属性] order:user:1:age

哈希Hash

存储结构

一个String类型的filed和value的映射表,适用于存储对象

存取值

存值:

hset key filed value

hmset key filed value filed2 value ...// 批量设置值

取值:

hget key filed

hmget key filed filed2 ... // 批量取值

删值:hdel key filed

判断filed是否存在:hexists key filed

获取key所有的属性:hkeys key

获取key所有的值:hvals key

计数

增加:

hincrby key value 1 // value+1

hincrbyfloat key value 2.1 //浮点型+2.1

使用场景

可以将关系型数据表的数据转换成redis的hash进行存储。

列表List

存储结构

存储多个有序的字符串,一个列表最多可存储2的32次方减1个元素,可以在列表左右两边进行插入。

存取值

添加:

rpush key a b c ... // 往右边依此插入a b c,返回值3,lrange key 0 -1输出数据 a b c

lpush key a b c d ...// 往左边依此插入a b c d,返回值4,lrange key 0 -1 输出数据 d c b a

linsert key before/after listValue insertValue// 往列表的某个值前/后插入一个值 只按照从左至右的顺序插入一个

查找:

lrange key startPos endPos // 从左到右按照下标输出值。从0开始 0 -1 输出全部

lindex key pos // 返回从左至右下标的元素,从0开始。-1表示最右边的元素,-2右边第二个

llen key // 返回列表的长度

修改:

lset key 2 value // 替换第三个元素的值

删除:

lpop key // 删除最左边的元素

rpop key // 删除最右边的元素

lrem key count value // 删除count个值为value的元素,大于的话就是删除全部。存在值的话会最少会删除一个,count传0删除一个,负数取绝对值。

ltrim key startPos endPos // 只保留开始到结束位置的下标值 从0开始

应用场景

单个键对应多个值的情况,如单个用户多个订单。

集合Set

存储结构

保存多个不重复的元素,最多存2的32次方减1个元素。支持增删改查和集合的交、并、差集的运算。

存取值

exists key // 检查键值是否存在

sadd key a b c // 添加元素

smember key // 获取所有元素

srem key a // 删除a元素

scard key // 计算元素个数

sismember key a // 判断元素是否存在,存在返回1

srandmember key 2 // 随机返回2个元素

spop key 2 // 随机返回2个元素,并且从集合中删除

sinter key1 key2 key3 ... // 返回集合的交集

sunion key1 key2 key3 ...// 返回集合的并集

sdiff key1 key2 // 返回集合的差集 key1-key2

sinterstore key key1 key2 // 将key1和key2的交集保存到key中 sunionstore sdiffstore

应用场景

用户标签,社交,查询共同爱好的人,智能推荐

有序集合Zset

存储类型

存储不可重复的有序的元素,每个元素后面会有一个分值,表示存储的顺序。

存取值

zadd key score member [score member...] // 存储值

zadd key nx score member // key必须不存在

zadd key xx incr score member // key必须存在,增加分数

zrange key 0 -1 withscores // 查看分数与成员名

zcard key // 计算成员个数

zscore key member // 查看成员分数

zrank key member // 返回成员排名,从0开始,分数越高越靠后

zrevrank key member// 反排序 点赞数最高的排名为0

zrem key member member...// 删除成员

使用场景

主要用于排行榜系统。

你可能感兴趣的:(Redis简单使用)