• 018-redis-命令合计


    1.redis启动连接相关

     

    命令

    说明

    redis-server

    启动服务端

    redis-cli redis.conf

    启动客户端

    redis-cli  -h  {host}  -p  {port}  -a  {password}

    配置客户端启动的主机和端口

     

    2.获取redis配置信息

    序号

    配置项

    说明

    1

    daemonize no

    配置Redis是否以守护线程的方式启动,默认为NO

    2

    port 6379

    Redis 监听端口,默认为 6379

    3

    bind 127.0.0.1

    绑定的主机地址

    4

    timeout 300

    客户端闲置多少秒后关闭连接,如果为0,表示关闭该功能

    5

    loglevel notice

    日志记录级别,总共四个级别:debug、verbose、notice、warning,默认为 notice

    6

    databases 16

    设置数据库的数量,默认16个库(0-15),默认初始使用的库为0,可以使用SELECT 命令在连接上指定数据库id

    7

    save <seconds> <changes>

     

    在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合。

    Redis 配置文件默认3个条件:

    save 900 1     900秒内有1个更改

    save 300 10    300秒内有10个更改

    save 60 10000  60秒内有10000个更改

    8

    rdbcompression yes

    存储至本地数据库时是否压缩数据,默认为 yes,Redis 采用 LZF 压缩,如果为了节省 CPU 时间,可以关闭该选项,但会导致数据库文件变的巨大

    9

    dbfilename dump.rdb

    本地数据库文件名,默认值为 dump.rdb

    10

    appendonly no

    是否在每次更新操作后进行日志记录,默认为 no

    11

    appendfilename appendonly.aof

    指定更新日志文件名,默认为 appendonly.aof

    12

    appendfsync everysec

    异步更新日志条件:

    no:表示等操作系统进行数据缓存同步到磁盘(快)

    always:表示每次更新操作后手动调用 fsync() 将数据写到磁盘(慢,安全)

    everysec:表示每秒同步一次(折中,默认值)

    13

    dir ./

    指定本地数据库存放目录

    14

    slaveof <masterip> <masterport>

    当本机为 slave 时,设置 master 的 IP 地址及端口

     

     

    3.数据类型

    类型

    特性

    String

    可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512M

    Hash

    适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值(Memcached中需要取出整个字符串反序列化成对象修改完再序列化存回去)

    List

    增删快,提供了操作某一段元素的API

    Set

    1. 添加、删除,查找的复杂度都是O(1)

    2、为集合提供了求交集、并集、差集等操作

    Sorted Set

    数据插入集合时,已经进行天然排序

    4.Redis keys 命令

    序号

    命令

    描述

    1

    EXPIRE key seconds

    为 key指定过期时间,秒。

    2

    EXPIREAT key timestamp

    为 key指定过期时间, UNIX 时间戳(unix timestamp)。

    3

    PEXPIRE key milliseconds

    设置 key 的过期时间以毫秒计。

    4

    PEXPIREAT key milliseconds-timestamp

    设置 key 过期时间的时间戳(unix timestamp) 以毫秒计

    5

    PERSIST key

    持久化key,移除key的过期时间,key 将持久保持。

    6

    PTTL key

    以毫秒为单位返回 key 的剩余的过期时间。

    7

    TTL key

    以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。

    8

    KEYS pattern

    查找所有符合给定模式( pattern)的 key 。如: keys *

    9

    RENAME key newkey

    修改 key 的名称

    10

    RENAMENX key newkey

    仅当 newkey 不存在时,将 key 改名为 newkey 。

    11

    MOVE key db

    将当前数据库的 key 移动到给定的数据库 db 当中。

    12

    RANDOMKEY

    从当前数据库中随机返回一个 key 。

    13

    DUMP key

    序列化给定 key ,并返回被序列化的值。

    14

    EXISTS key

    检查给定 key 是否存在。

    15

    TYPE key

    返回 key 所储存的值的类型。

    16

    SCAN cursor [MATCH pattern] [COUNT count]

    迭代数据库中的数据库键。

    17

    DEL key

    该命令用于在 key 存在时删除 key。

     

     

    5.字符串命令

    序号

    命令

    描述

    1

    SET key value

    设置指定 key 的值

    2

    GET key

    获取指定 key 的值。

    3

    MSET key value [key value ...]

    同时设置一个或多个 key-value 对。

    4

    MSETNX key value [key value ...]

    同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在时才全部成功。

    5

    MGET key1 [key2..]

    获取所有给定 key 的值。

    6

    SETEX key seconds value

    设置指定key的值,并将 key 的过期时间设为 seconds (以秒为单位)。

    7

    SETNX key value

    只有在 key 不存在时设置 key 的值。

    8

    SETBIT key offset value

    对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)。

    9

    GETBIT key offset

    对 key 所储存的字符串值,获取指定偏移量上的位(bit)。

    10

    SETRANGE key offset value

    从偏移量 offset 开始,用value覆盖key所存储的字符串信息。

    11

    GETRANGE key start end

    返回 key 中指定位置的字符串的值

    12

    STRLEN key

    返回 key 所储存的字符串值的长度。

    13

    GETSET key value

    将给定 key 的值设为 value ,并返回 key 的旧值(old value)。

    14

    PSETEX key milliseconds value

    这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位。

    15

    INCR key

    将 key 中储存的数字值增一。

    16

    INCRBY key increment

    将 key 所储存的值加上给定的增量值(increment) 。

    17

    INCRBYFLOAT key increment

    将 key 所储存的值加上给定的浮点增量值(increment) 。

    18

    DECR key

    将 key 中储存的数字值减一。

    19

    DECRBY key decrement

    key 所储存的值减去给定的减量值(decrement) 。

    20

    APPEND key value

    将指定的 value 追加到key原来值(value)的末尾。

    6.哈希(Hash)

    序号

    命令

    描述

    1

    HSET key field value

    将哈希表 key 中的字段 field 的值设为 value 。

    2

    HSETNX key field value

    只有在字段 field 不存在时,设置哈希表key中field字段的值value。

    3

    HGET key field

    获取存储在哈希表中指定字段的值。

    4

    HGETALL key

    获取在哈希表中指定 key 的所有字段和值

    5

    HMSET key field1 value1 [field2 value2 ]

    同时将多个 field-value (域-值)对设置到哈希表 key 中。

    6

    HMGET key field1 [field2]

    获取所有给定字段的值

    7

    HKEYS key

    获取所有哈希表中key的字段

    8

    HVALS key

    获取哈希表中key的所有值。

    9

    HLEN key

    获取哈希表中字段key的数量

    10

    HINCRBY key field increment

    为哈希表 key 中的指定字段的整数值加上增量 increment 。

    11

    HINCRBYFLOAT key field increment

    为哈希表 key 中的指定字段的浮点数值加上增量 increment 。

    12

    HEXISTS key field

    查看哈希表 key 中,指定的字段是否存在。

    13

    HSCAN key cursor [MATCH pattern] [COUNT count]

    迭代哈希表中的键值对。

    14

    HDEL key field1 [field2]

    删除一个或多个哈希表字段

    7.列表(list)

    序号

    命令

    描述

    1

    LPUSH key value1 [value2]

    将一个或多个值插入到列表头部

    2

    LPUSHX key value

    将一个值插入到已存在的列表头部

    3

    LSET key index value

    通过索引设置列表元素的值

    4

    LINDEX key index

    通过索引获取列表中的元素

    5

    LINSERT key BEFORE|AFTER pivot value

    在列表的元素前或者后插入元素

    6

    LLEN key

    获取列表长度

    7

    LRANGE key start stop

    获取列表指定范围内的元素

    8

    LPOP key

    移出并获取列表的第一个元素

    9

    LTRIM key start stop

    对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。

    10

    LREM key count value

    移除列表元素

    11

    RPUSH key value1 [value2]

    在列表中添加一个或多个值

    12

    RPUSHX key value

    为已存在的列表添加值

    13

    RPOP key

    移除列表的最后一个元素,返回值为移除的元素。

    14

    RPOPLPUSH source destination

    移除列表的最后一个元素,并将该元素添加到另一个列表并返回

    15

    BLPOP key1 [key2 ] timeout

    移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

    16

    BRPOP key1 [key2 ] timeout

    移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

    17

    BRPOPLPUSH source destination timeout

    从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

     

    8.集合(Set)

    序号

    命令

    描述

    1

    SADD key member1 [member2]

    向集合添加一个或多个成员

    2

    SCARD key

    获取集合的成员数

    3

    SDIFF key1 [key2]

    返回给定所有集合的差集

    4

    SDIFFSTORE destination key1 [key2]

    返回给定所有集合的差集并存储在 destination 中

    5

    SINTER key1 [key2]

    返回给定所有集合的交集

    6

    SINTERSTORE destination key1 [key2]

    返回给定所有集合的交集并存储在 destination 中

    7

    SISMEMBER key member

    判断 member 元素是否是集合 key 的成员

    8

    SMEMBERS key

    返回集合中的所有成员

    9

    SMOVE source destination member

    将 member 元素从 source 集合移动到 destination 集合

    10

    SPOP key

    移除并返回集合中的一个随机元素

    11

    SRANDMEMBER key [count]

    返回集合中一个或多个随机数

    12

    SREM key member1 [member2]

    移除集合中一个或多个成员

    13

    SUNION key1 [key2]

    返回所有给定集合的并集

    14

    SUNIONSTORE destination key1 [key2]

    所有给定集合的并集存储在 destination 集合中

    15

    SSCAN key cursor [MATCH pattern] [COUNT count]

    迭代集合中的元素

     

    9.有序集合(sorted set)

    序号

    命令

    描述

    1

    ZADD key score1 member1 [score2 member2]

    向有序集合添加一个或多个成员,或者更新已存在成员的分数

    2

    ZCARD key

    获取有序集合的成员数

    3

    ZCOUNT key min max

    计算在有序集合中指定区间分数的成员数

    4

    ZINCRBY key increment member

    有序集合中对指定成员的分数加上增量 increment

    5

    ZINTERSTORE destination numkeys key [key ...]

    计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中

    6

    ZLEXCOUNT key min max

    在有序集合中计算指定字典区间内成员数量

    7

    ZRANGE key start stop [WITHSCORES]

    通过索引区间返回有序集合指定区间内的成员

    8

    ZRANGEBYLEX key min max [LIMIT offset count]

    通过字典区间返回有序集合的成员

    9

    ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

    通过分数返回有序集合指定区间内的成员

    10

    ZRANK key member

    返回有序集合中指定成员的索引

    11

    ZREM key member [member ...]

    移除有序集合中的一个或多个成员

    12

    ZREMRANGEBYLEX key min max

    移除有序集合中给定的字典区间的所有成员

    13

    ZREMRANGEBYRANK key start stop

    移除有序集合中给定的排名区间的所有成员

    14

    ZREMRANGEBYSCORE key min max

    移除有序集合中给定的分数区间的所有成员

    15

    ZREVRANGE key start stop [WITHSCORES]

    返回有序集中指定区间内的成员,通过索引,分数从高到低

    16

    ZREVRANGEBYSCORE key max min [WITHSCORES]

    返回有序集中指定分数区间内的成员,分数从高到低排序

    17

    ZREVRANK key member

    返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序

    18

    ZSCORE key member

    返回有序集中,成员的分数值

    19

    ZUNIONSTORE destination numkeys key [key ...]

    计算给定的一个或多个有序集的并集,并存储在新的 key 中

    20

    ZSCAN key cursor [MATCH pattern] [COUNT count]

    迭代有序集合中的元素(包括元素成员和元素分值)

     

    10.发布订阅

    Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

    Redis 客户端可以订阅任意数量的频道。

     

     

     

     

    1. 订阅:

    SUBSCRIBE redisChat

    1. 发布:

    PUBLISH redisChat "hello from redis publish demo"

     

    序号

    命令

    描述

    1

    SUBSCRIBE channel [channel ...]

    订阅给定的一个或多个频道的信息。

    2

    PSUBSCRIBE pattern [pattern ...]

    订阅一个或多个符合给定模式的频道。

    3

    PUBLISH channel message

    将信息发送到指定的频道。

    4

    PUNSUBSCRIBE [pattern [pattern ...]]

    退订所有给定模式的频道。

    5

    UNSUBSCRIBE [channel [channel ...]]

    指退订给定的频道。

    6

    PUBSUB subcommand [argument [argument ...]]

    查看订阅与发布系统状态。

     

    11.事务

    Redis 事务可以一次执行多个命令,并且带有以下三个重要的保证:

    批量操作在发送 EXEC 命令前被放入队列缓存。

    收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。

    在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

    一个事务从开始到执行会经历以下三个阶段:

    开始事务。 ——  MULTI

    命令入队。

    执行事务。 ——  EXEC

    单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。

    事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。

     

     

    如果在 set b bbb 处失败,set a 已成功不会回滚,set c 还会继续执行。

     

     

    序号

    命令

    描述

    1

    MULTI

    标记一个事务块的开始。

    2

    EXEC

    执行所有事务块内的命令。

    3

    DISCARD

    取消事务,放弃执行事务块内的所有命令。

    4

    WATCH key [key ...]

    监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

    5

    UNWATCH

    取消 WATCH 命令对所有 key 的监视。

     

    12.服务器命令

    序号

    命令

    描述

    1

    BGREWRITEAOF

    异步执行一个 AOF(AppendOnly File) 文件重写操作

    2

    BGSAVE

    在后台异步保存当前数据库的数据到磁盘

    3

    CLIENT KILL [ip:port] [ID client-id]

    关闭客户端连接

    4

    CLIENT LIST

    获取连接到服务器的客户端连接列表

    7

    CLIENT SETNAME connection-name

    设置当前连接的名称

    8

    CLUSTER SLOTS

    获取集群节点的映射数组

    12

    TIME

    返回当前服务器时间

    14

    CONFIG GET parameter

    获取指定配置参数的值

    15

    CONFIG REWRITE

    对启动 Redis 服务器时所指定的 redis.conf 配置文件进行改写

    16

    CONFIG SET parameter value

    修改 redis 配置参数,无需重启

    18

    DBSIZE

    返回当前数据库的 key 的数量

    21

    FLUSHALL

    删除所有数据库的所有key

    22

    FLUSHDB

    删除当前数据库的所有key

    23

    INFO [section]

    获取 Redis 服务器的各种信息和统计数值

    24

    LASTSAVE

    返回最近一次 Redis 成功将数据保存到磁盘上的时间,以 UNIX 时间戳格式表示

    27

    SAVE

    同步保存数据到硬盘

    28

    SHUTDOWN [NOSAVE] [SAVE]

    异步保存数据到硬盘,并关闭服务器

    29

    SLAVEOF host port

    将当前服务器转变为指定服务器的从属服务器(slave server)

    原文地址:https://blog.csdn.net/weixin_42389216/article/details/106792627

    转载请注明出处,感谢。
    作者:李宏旭
    阅罢此文,如果您觉得本文不错并有所收获,请【打赏】或【推荐】,也可【评论】留下您的问题或建议与我交流。
    你的支持是我不断创作和分享的不竭动力!
  • 相关阅读:
    图解修改mysql的默认数据库存放目录
    使用IHTMLDocument2解决弹出"为了让该网站给你提供个人化信息,是否允许在你计算机放置cookie?"
    HTML解析器HtmlAgilityPack的一些使用总结(C#)
    VS2013使用滚动条缩略图、双击选中高亮、配色方案、代码竖虚线(缩进标尺)
    css疑难汇总
    MySQL字段数据类型表
    修改Windows Server 2008密码策略,设置简单密码
    成功进行了一次UDP打洞
    c语言指针疑惑[转载]
    一个转子
  • 原文地址:https://www.cnblogs.com/bjlhx/p/15044760.html
Copyright © 2020-2023  润新知