Redis教程

018-redis-命令合计

本文主要是介绍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

这篇关于018-redis-命令合计的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!