美文网首页
Redis简单使用

Redis简单使用

作者: Steven_SHH | 来源:发表于2021-03-04 11:34 被阅读0次

    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简单使用

          本文链接:https://www.haomeiwen.com/subject/nuzhqltx.html