Redis 基础命令
| 命令 | 描述 |
|---|---|
| ping | 用于检测 redis 服务是否启动 |
| info | 查看redis信息 |
| select | 选择不同的keyspace,或者说database |
| keys * | 查看当前keyspace下所有的keys |
| keys prefix_* | 查看前缀为prefix_的所有keys |
| flushdb | 清空当前keyspace下的数据 |
| flushall | 清空所有的keyspace下的数据 |
| dbsize | 查看当前keyspace下的一个键值对数量 |
| quit | 退出客户端命令行 |
Redis 键命令
| 命令 | 描述 |
|---|---|
| del key | 该命令用于在 key 存在时删除 key |
| dump key | 序列化给定 key ,并返回被序列化的值 |
| exists key | 检查给定 key 是否存在,存在返回1,不存在返回0 |
| expire key seconds | 为给定 key 设置过期时间 |
| expireat key timestamp | EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。 不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳(unix timestamp) |
| pexpire key milliseconds | 设置 key 的过期时间以毫秒计 |
| pexpireat key milliseconds-timestamp | 设置 key 过期时间的时间戳(unix timestamp) 以毫秒计 |
| keys pattern | 查找所有符合给定模式( pattern)的 key |
| move key db | 将当前数据库的 key 移动到给定的数据库 db 或者说 keyspace 当中 |
| persist key | 移除 key 的过期时间,key 将持久保持 |
| pttl key | 以毫秒为单位返回 key 的剩余的过期时间,-1表示没有过期时间,-2表示该key不存在 |
| ttl key | 以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live),-1表示没有过期时间,-2表示该key不存在 |
| randomkey | 从当前数据库中随机返回一个 key |
| rename key newkey | 修改 key 的名称 |
| renamenx key newkey | 仅当 newkey 不存在时,将 key 改名为 newkey |
| type key | 返回 key 所储存的值的类型 |
Redis 数据结构
String 字符串
| 命令 | 描述 |
|---|---|
| set key value | 设置指定 key 的值 |
| get key | 获取指定 key 的值 |
| getrange key start end | 返回 key 中字符串值的子字符 |
| getset key value | 将给定 key 的值设为 value ,并返回 key 的旧值(old value) |
| getbit key offset | 对 key 所储存的字符串值,获取指定偏移量上的位(bit) |
| mget key1 [key2..] | 获取所有(一个或多个)给定 key 的值 |
| setbit key offset value | 对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit) |
| setex key seconds value | 将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位) |
| setnx key value | 只有在 key 不存在时设置 key 的值 |
| setrange key offset value | 用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始 |
| strlen key | 返回 key 所储存的字符串值的长度 |
| mset key value [key value …] | 时设置一个或多个 key-value 对 |
| msetnx key value [key value …] | 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在 |
| psetex key milliseconds value | 这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位 |
| incr key | 将 key 中储存的数字值增一 |
| incrby key increment | 将 key 所储存的值加上给定的增量值(increment) |
| incrbyfloat key increment | 将 key 所储存的值加上给定的浮点增量值(increment) |
| decr key | 将 key 中储存的数字值减一 |
| decrby key decrement | key 所储存的值减去给定的减量值(decrement) |
| append key value | 如果 key 已经存在并且是一个字符串, APPEND 命令将 指定value 追加到改 key 原来的值(value)的末尾 |
hash 哈希
| 命令 | 描述 |
|---|---|
| hset key field value | 将哈希表 key 中的字段 field 的值设为 value |
| hdel key field1 [field2] | 删除一个或多个哈希表字段 |
| hexists key field | 查看哈希表 key 中,指定的字段是否存在 |
| hget key field | 获取存储在哈希表中指定字段的值 |
| hgetall | 获取在哈希表中指定 key 的所有字段和值 |
| hincrby key field increment | 为哈希表 key 中的指定字段的整数值加上增量 increment |
| hincrbyfloat key field increment | 为哈希表 key 中的指定字段的浮点数值加上增量 increment |
| hkeys key | 获取所有哈希表中的字段 |
| hlen key | 获取哈希表中字段的数量 |
| hmget key field1 [field2] | 获取所有给定字段的值 |
| hmset key field1 value1 [field2 value2 ] | 同时将多个 field-value (域-值)对设置到哈希表 key 中 |
| hsetnx key field value | 只有在字段 field 不存在时,设置哈希表字段的值 |
| hvals key | 获取哈希表中所有值 |
| hscan key cursor [MATCH pattern] [COUNT count] | 迭代哈希表中的键值对 |
list 列表
| 命令 | 描述 |
|---|---|
| blpop key1 [key2 ] timeout | 移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 |
| brpop key1 [key2 ] timeout | 移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 |
| brpoplpush source destination timeout | 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止 |
| lindex key index | 通过索引获取列表中的元素 |
| linsert key before|after pivot value | 在列表的元素前或者后插入元素 |
| llen key | 获取列表长度 |
| lpop key | 移出并获取列表的第一个元素 |
| lpush key value1 [value2] | 将一个或多个值插入到列表头部 |
| lpushx key value | 将一个值插入到已存在的列表头部 |
| lrange key start stop | 获取列表指定范围内的元素 |
| lrem key count value | 移除列表元素 |
| lset key index value | 通过索引设置列表元素的值 |
| ltrim key start stop | 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除 |
| rpop key | 移除并获取列表最后一个元素 |
| rpoplpush source destination | 移除列表的最后一个元素,并将该元素添加到另一个列表并返回 |
| rpush key value1 [value2] | 在列表中添加一个或多个值 |
| rpushx key value | 为已存在的列表添加值 |
set 集合
| 命令 | 描述 |
|---|---|
| sadd key member1 [member2] | 向集合添加一个或多个成员 |
| scard key | 获取集合的成员数 |
| sdiff key1 [key2] | 返回给定所有集合的差集 |
| sdiffstore destination key1 [key2] | 返回给定所有集合的差集并存储在 destination 中 |
| sinter key1 [key2] | 返回给定所有集合的交集 |
| sinterstore destination key1 [key2] | 返回给定所有集合的交集并存储在 destination 中 |
| sismember key member | 判断 member 元素是否是集合 key 的成员 |
| smembers key | 返回集合中的所有成员 |
| smove source destination member | 将 member 元素从 source 集合移动到 destination 集合 |
| spop key | 移除并返回集合中的一个随机元素 |
| srandmember key [count] | 随机返回集合中的成员 |
| srem key member1 [member2] | 移除集合中一个或多个成员 |
| sunion key1 [key2] | 返回所有给定集合的并集 |
| sunionstore destination key1 [key2] | 所有给定集合的并集存储在 destination 集合中 |
| sscan key cursor [MATCH pattern] [COUNT count] | 迭代集合中的元素 |
sorted set 有序集合
| 命令 | 描述 |
|---|---|
| zadd key score1 member1 [score2 member2] | 向有序集合添加一个或多个成员,或者更新已存在成员的分数 |
| zcard key | 获取有序集合的成员数 |
| zcount key min max | 计算在有序集合中指定区间分数的成员数 |
| zincrby key increment member | 有序集合中对指定成员的分数加上增量 increment |
| zincrbystore destination numkeys key [key …] | 计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中 |
| zlexcount key min max | 在有序集合中计算指定字典区间内成员数量 |
| zrange key start stop [WITHSCORES] | 通过索引区间返回有序集合成指定区间内的成员 |
| zrangebylex key min max [LIMIT offset count] | 通过字典区间返回有序集合的成员 |
| zrangebyscore key min max [WITHSCORES] [LIMIT] | 通过分数返回有序集合指定区间内的成员 |
| zrank key member | 返回有序集合中指定成员的索引 |
| zrem key member [member …] | 移除有序集合中的一个或多个成员 |
| zremrangebylex key min max | 移除有序集合中给定的字典区间的所有成员 |
| zremrangebyrank key start stop | 移除有序集合中给定的排名区间的所有成员 |
| zremrangebyscore key min max | 移除有序集合中给定的分数区间的所有成员 |
| zrevrange key start stop [WITHSCORES] | 返回有序集中指定区间内的成员,通过索引,分数从高到底 |
| zrevrangebyscore key max min [WITHSCORES] | 返回有序集中指定分数区间内的成员,分数从高到低排序 |
| zrevrank key member | 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序 |
| zscore key member | 返回有序集中,成员的分数值 |
| zunionstore destination numkeys key [key …] | 计算给定的一个或多个有序集的并集,并存储在新的 key 中 |
| zscan key cursor [MATCH pattern] [COUNT count] | 迭代有序集合中的元素(包括元素成员和元素分值) |
Redis 订阅与发布
| 命令 | 描述 |
|---|---|
| PSUBSCRIBE pattern [pattern …] | 订阅一个或多个符合给定模式的频道 |
| PUBSUB subcommand [argument [argument …]] | 查看订阅与发布系统状态 |
| PUBLISH channel message | 将信息发送到指定的频道 |
| PUNSUBSCRIBE [pattern [pattern …]] | 退订所有给定模式的频道 |
| SUBSCRIBE channel [channel …] | 订阅给定的一个或多个频道的信息 |
| UNSUBSCRIBE [channel [channel …]] | 指退订给定的频道 |
Redis 事物
| 命令 | 描述 |
|---|---|
| DISCARD | 取消事务,放弃执行事务块内的所有命令 |
| EXEC | 执行所有事务块内的命令 |
| MULTI | 标记一个事务块的开始 |
| UNWATCH | 取消 WATCH 命令对所有 key 的监视 |
| WATCH key [key …] | 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 |
Redis 脚本命令
| 命令 | 描述 |
|---|---|
| EVAL script numkeys key [key …] arg [arg …] EVALSHA sha1 numkeys key [key …] arg [arg …] | 执行 Lua 脚本 |
| SCRIPT EXISTS script [script …] | 查看指定的脚本是否已经被保存在缓存当中 |
| SCRIPT FLUSH | 从脚本缓存中移除所有脚本 |
| SCRIPT KILL | 杀死当前正在运行的 Lua 脚本 |
| SCRIPT LOAD script | 将脚本 script 添加到脚本缓存中,但并不立即执行这个脚本 |
Redis 服务器命令
| 命令 | 描述 |
|---|---|
| BGREWRITEAOF | 异步执行一个 AOF(AppendOnly File) 文件重写操作 |
| BGSAVE | 在后台异步保存当前数据库的数据到磁盘(可用于备份) |
| SAVE | 持久化redis中存储的数据到磁盘中(可用于备份),还原数据只需要通过config get dir 查询redis安装目录后,将备份的rdb文件放到该目录下后重启redis服务 |
| SHUTDOWN [NOSAVE] [SAVE] | 异步保存数据到硬盘,并关闭服务器 |
| CLIENT KILL [ip:port] [ID client-id] | 关闭客户端连接 |
| CLIENT LIST | 获取连接到服务器的客户端连接列表 |
| CLIENT GETNAME | 获取连接的名称 |
| CLIENT PAUSE timeout | 在指定时间内终止运行来自客户端的命令 |
| CLIENT SETNAME connection-name | 设置当前连接的名称 |
| CLUSTER SLOTS | 获取集群节点的映射数组 |
| COMMAND | 获取 Redis 命令详情数组 |
| COMMAND COUNT | 获取 Redis 命令总数 |
| COMMAND GETKEYS | 获取给定命令的所有键 |
| TIME | 返回当前服务器时间(时间戳) |
| COMMAND INFO command-name [command-name …] | 获取指定 Redis 命令描述的数组 |
| CONFIG GET parameter | 获取指定配置参数的值 |
| CONFIG REWRITE | 对启动 Redis 服务器时所指定的 redis.conf 配置文件进行改写 |
| CONFIG SET parameter value | 修改 redis 配置参数,无需重启 |
| CONFIG RESETSTAT | 重置 INFO 命令中的某些统计数据 |
| LASTSAVE | 返回最近一次 Redis 成功将数据保存到磁盘上的时间,以 UNIX 时间戳格式表示 |
| DEBUG OBJECT key | 获取 key 的调试信息 |
| DEBUG SEGFAULT | 执行一个非法的内存访问从而让 Redis 崩溃,仅在开发时用于 BUG 调试 |
| MONITOR | 实时打印出 Redis 服务器接收到的命令,调试用 |
| ROLE | 返回主从实例所属的角色 |
| SLAVEOF host port | 将当前服务器转变为指定服务器的从属服务器(slave server) |
| SLOWLOG subcommand [argument] | 管理 redis 的慢日志 |
| SYNC | 用于复制功能(replication)的内部命令 |
| info keyspace | 统计每个db中keys的数量 |
| redis-cli -n 0 --bigkeys | 扫描redis db0中的大key |
info 查看redis 内存占用
1 | 127.0.0.1:6379> info |
查找 redis 哪个key占用空间最大
1、使用 redis-cli --bigkeys 命令
1 | $ redis-cli -n 0 --bigkeys |
该指令原理比较简单,使用scan命令去遍历所有的键,对每个键根据其类型执行 STRLEN,LLEN,SCARD,HLEN,ZCARD 这些命令获取其长度或者元素个数。
该方法有两个缺点:
- 线上使用:虽然scan命令通过游标遍历建空间并且在生产上可以通过对从服务执行该命令,但毕竟是一个线上操作;
- set,zset,list以及hash类型只能获取有多少个元素,但其实元素多的不一定占用空间大。
2、从rdb文件获取,使用到开源工具rdr
1 | # 下载rdr工具 |