• redis 常用命令


    redis 介绍
    1、基于内存key-value 的非关系型数据库
    2、基于c语言编写的,可以支持多种语言api //set 每秒11万次,取get 81000 次
    3、支持数据持久化
    4、多种数据类型:string 、hash、list 、set、sorted set

    使用场景:
    1、取最新的n个数据的操作
    2、排行榜,取top n个数据 //最佳人气前10
    3、精确的设置过期时间
    4、计数器
    5、实时系统、反垃圾系统
    6、pub、sub发布订阅构建实时消息系统
    7、构建消息队列
    8、缓存

    String:缓存、限流、计数器、分布式锁、分布式session

    Hash:存储用户信息、用户主页访问量、组合查询

    List:微博关注人时间轴列表、简单队列

    Set:赞、踩、标签、共同好友

    Zset: 排行榜

    cmd 下访问redis
    redis-cli.exe -h host -p port -a password
    加 --raw 防止中文乱码
    退出当前返回到windows命令:quit

    key

    key * 获取所有的key
    select 0 选择第一个库
    move myString 1 将当前的数据库key移动到某个数据库、目标库由、则不能移动
    flush db 清除指定库
    randomkey 获取随机key 的值
    type key 获取键对应的值类型

    set key1 value1 设置key
    get key1 获取key
    mset key1 value1 [key2 value2] 批量设置
    mget key1 key2 批量获取
    del key1 删除 key
    exists key 判断是否存在key
    expire key 10 设置key10秒过期
    pexpire key 10 设置key 10 毫秒过期

    数据类型及命令

    一、String

    set keyname value1 设置
    get keyname 获取
    getrange name 0 -1 字符串分段
    getset keyname new_value 设置新值、返回旧值
    mset key1 value1 [key2 value2 ] 批量设置
    setnx key value 不存在就插入,存在就插入失败
    setex key time value 设置key 同时设置 过期时间
    setrange key index value 从指定下标替换值
    incr key 给key对应的值递增
    incrby key 10 给key 对应的值按所给的量递增
    decr key 递减
    decrby key 10 按指定值递减
    incrbyfloat key 10.2 增减浮点数
    append key value 给key对应的值追加value
    strlen key 获取key值长度
    getbit/setbit/bitcount/bitop 位操作

    二、Hash

    hset key field value 一个key一个字段
    hget key name 获取 指定key指定字段的值
    hmset key field value [field value] 批量设置(name haha age 18 sex "男")
    hmget key field1 filed2 filed3 批量获取key对应字段值
    hgetall key 获取所有(字段和值)
    hexists key filed 查看字段是否存在
    hsetnx key filed value 设置key 中不存在的field
    hincrby key filed 1 字段递增1
    hdel key filed 删除字段
    hkeys key 获取key对应的所有字段
    hvals key 获取key对应字段中的所有值
    hlen key 长度

    三、List
    lpush key 1 2 3 左插入
    rpush key 4 5 6 右插入
    lrange key 0 1 数据集合
    l'pop key 从左弹出元素
    rpop key 从右弹出元素
    llen key 长度
    lrem key count value 删除
    lindex key 2 获取指定索引的值
    lset key 2 n 给指定索引设值
    ltrim key start stop 从指定位置start 删除到stop中的值
    linsert key before a 在最前面插入a
    linsert key after a 在后面插入a
    rpoplpush list list2 转移列表的数据

    四、set

    sadd key aa bb cc cuan 创建集合 (aa bb cc)
    smembers key 获取集合
    srem key member 删除集合成员
    sismember key member1 判断成员member1是否在集合中
    scard key 集合成员个数
    sdiff key1 key2 ... 取两个或多个集合差集
    sinter key1 key2 ... 取两个或多个集合交集
    sunion key1 key2 ... 取两个或多个集合并集
    srandmember 随机获取集合中的元素
    spop 从集合中弹出一个元素

    五、zset

    zadd zset 1 one
    zadd zset 2 two
    zadd zset 3 three
    zincrby zset 1 one 增长分数
    zscore zset two 获取分数
    zrange zset 0 -1 withscores 范围值
    zrangebyscore zset 10 25 withscores 指定范围的值
    zrangebyscore zset 10 25 withscores limit 1 2 分页
    Zrevrangebyscore zset 10 25 withscores 指定范围的值
    zcard zset 元素数量
    Zcount zset 获得指定分数范围内的元素个数
    Zrem zset one two 删除一个或多个元素
    Zremrangebyrank zset 0 1 按照排名范围删除元素
    Zremrangebyscore zset 0 1 按照分数范围删除元素
    Zrank zset 0 -1 分数最小的元素排名为0
    Zrevrank zset 0 -1 分数最大的元素排名为0
    Zinterstore
    zunionstore rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 weights 1 1 1 1 1 1 1

    排序

    sort listkey(列表key) 默认asc排序
    sort listkey alpaha desc limit 0 2 字母排序
    sort list by it:* desc 倒序
    sort list by it:* desc get it:* get参数
    sort list by it:* desc get it:* store sorc:result sort命令之store参数:表示把sort查询的结果集保存起来

    订阅与发布:
    订阅频道:subscribe chat1
    发布消息:publish chat1 "hell0 ni hao"
    查看频道:pubsub channels
    查看某个频道的订阅者数量: pubsub numsub chat1
    退订指定频道: unsubscrible chat1 , punsubscribe java.*
    订阅一组频道: psubscribe java.*

    redis事物
    隔离性,原子性,
    步骤: 开始事务,执行命令,提交事务
    multi //开启事务
    sadd myset a b c
    sadd myset e f g
    lpush mylist aa bb cc
    lpush mylist dd ff gg

    服务器管理
    dump.rdb
    appendonly.aof
    //BgRewriteAof 异步执行一个aop(appendOnly file)文件重写
    会创建当前一个AOF文件体积的优化版本

    //BgSave 后台异步保存数据到磁盘,会在当前目录下创建文件dump.rdb
    //save同步保存数据到磁盘,会阻塞主进程,别的客户端无法连接

    //client kill 关闭客户端连接
    //client list 列出所有的客户端

    //给客户端设置一个名称
    client setname myclient1
    client getname

    config get port
    //configRewrite 对redis的配置文件进行改写

    rdb
    save 900 1
    save 300 10
    save 60 10000

    aop备份处理
    appendonly yes 开启持久化
    appendfsync everysec 每秒备份一次

    命令:
    bgsave异步保存数据到磁盘(快照保存)
    lastsave返回上次成功保存到磁盘的unix的时间戳
    shutdown同步保存到服务器并关闭redis服务器
    bgrewriteaof文件压缩处理(命令)

     推荐博文:https://www.cnblogs.com/jasonZh/p/9513948.html

  • 相关阅读:
    阮一峰的网络日志
    解决Windows路径太长的目录以及文件名超长删除的问题
    LVM扩容根分区
    Centos7 搭建prometheus+Grafana监控
    python3 读取txt文件数据,绘制趋势图,matplotlib模块
    linux python3安装whl包时报错解决:is not a supported wheel on this platform
    堆排序
    nginx: [emerg] "upstream" directive is not allowed here in .../.../.../*.conf
    Github私有仓库使用设置
    AWK处理重复Hosts
  • 原文地址:https://www.cnblogs.com/vilucky/p/12574915.html
Copyright © 2020-2023  润新知