文章目录
redis数据类型
数据类型:是一个值的集合和定义在这个值集上的一组操作的总称,限制你程序所做的事情
http://www.redis.cn/topics/data-types.html
字符串(string)
字符串是所有编程语言中最常见的和最常用的数据类型,而且也是redis最基本的数据类型之一,而且redis中所有
的key的类型都是字符串。
添加一个key:
127.0.0.1:6379> set key1 value1
OK
127.0.0.1:6379> get key1
"value1"
127.0.0.1:6379> TYPE key1
string
127.0.0.1:6379> SET name2 jack2 ex 3 #添加一个key并设置自动过期时间3s
OK
获取一个key的内容
127.0.0.1:6379> get key1
"value1"
删除一个key
127.0.0.1:6379> DEL key1
(integer) 1
批量设置多个key
127.0.0.1:6379> MSET key1 value1 key2 value2
OK
批量获取多个key
127.0.0.1:6379> MGET key1 key2
OK
追加数据
127.0.0.1:6379> set key1 value1
OK
127.0.0.1:6379> get key1
"value1"
127.0.0.1:6379> append key1 append
(integer) 12
127.0.0.1:6379> get key1
"value1append"
数据递增
127.0.0.1:6379> set num 10
OK
127.0.0.1:6379> INCR num
(integer) 11
127.0.0.1:6379> get num
"11"
数据递减
127.0.0.1:6379> set num 10
OK
127.0.0.1:6379> DECR num
(integer) 9
127.0.0.1:6379> get num
"9"
返回字符串key长度: 建议添加|删除|新建数据前先查看数据长度
127.0.0.1:6379> STRLEN key1
(integer) 12
判断key是否存在
127.0.0.1:6379> EXISTS key1
(integer) 1 #存在
127.0.0.1:6379> EXISTS key2
(integer) 0 #不存在
查看key的过期时间
ttl #查看key的剩余生存时间
-1 #负一为永不过期,默认创建的key是永不过期,重新对key赋值,也会从有剩余生命周期变成永不过期
-2 #为没有此key
num #key的剩余有效期
127.0.0.1:6379> TTL key1
(integer) -1
设置key的过期时间
127.0.0.1:6379> EXPIRE key1 86400 #默认时间单位s(秒)
(integer) 1
127.0.0.1:6379> ttl key1
(integer) 86397
设置key的过期时间
127.0.0.1:6379> PERSIST key1
(integer) 1
127.0.0.1:6379> ttl key1
(integer) -1
列表(list)
列表是一个双向可读写的管道,其头部是左侧尾部是右侧,一个列表最多可以包含2^32-1个元素即4294967295个
元素。
生成列表并插入数据
127.0.0.1:6379> LPUSH list1 jack tom jhon #根据顺序逐个从右至左写入list1,最后的jhon会在列表的最左侧。
(integer) 3
127.0.0.1:6379> TYPE list1
list
127.0.0.1:6379> RPUSH list1 zhang wang li zhao #根据顺序逐个从左至右写入list2,最前的zhao会在列表的最右侧。
(integer) 4
127.0.0.1:6379> TYPE list1
list
获取列表指定位置数据
127.0.0.1:6379[1]> lrange list1 0 0 #指定范围
1) "jhon"
127.0.0.1:6379[1]> lrange list2 -1 -1
1) "zhao"
#列表范围[0,+]
# -1 表示最后一个值
向列表追加数据
127.0.0.1:6379> LPUSH list1 tom #向最左边追加
(integer) 2
127.0.0.1:6379> RPUSH list1 jack #向最右边追加
(integer) 3
获取列表长度
127.0.0.1:6379> LLEN list1
(integer) 3
集合(set)
Set 是 String 类型的无序集合,集合中的成员是唯一的,这就意味着集合中不能出现重复的数据,可以在两个不同的集合中对数据进行对比并取值。
生成集合key
127.0.0.1:6379> SADD set1 v1
(integer) 1
127.0.0.1:6379> SADD set2 v2 v4
(integer) 2
127.0.0.1:6379> TYPE set1
set
127.0.0.1:6379> TYPE set2
set
追加数值
# 追加的时候不能追加已经存在的数值
127.0.0.1:6379> SADD set1 v2 v3 v4
(integer) 3
127.0.0.1:6379> SADD set1 v2 #没有追加成功
(integer) 0
127.0.0.1:6379> TYPE set1
set
127.0.0.1:6379> TYPE set2
set
获取集合的差集
差集: 已属于A而不属于B元素的称为A与B的差(集)
127.0.0.1:6379> SDIFF set1 set2
1) "v1"
2) "v3"
获取集合的交集:
交集:已属于A且属于B的元素称为A与B的交(集)
127.0.0.1:6379> SINTER set1 set2
1) "v4"
2) "v2"
获取集合的并集:
并集:已属于A或属于B的元素为称为A与B的并(集)
127.0.0.1:6379> SUNION set1 set2
1) "v2"
2) "v4"
3) "v1"
4) "v3"
有序集合(sorted set)
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员,不同的是每个元素都会关联一个double(双精度浮点型)类型的分数,redis正是通过该分数来为集合中的成员进行从小到大的排序,有序集合的成员是唯一的,但分数(score)却可以重复,集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1), 集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个成员)。
生成有序集合
127.0.0.1:6379> ZADD zset1 1 v1
(integer) 1
127.0.0.1:6379> ZADD zset1 2 v2
(integer) 1
127.0.0.1:6379> ZADD zset1 2 v3
(integer) 1
127.0.0.1:6379> ZADD zset1 3 v4
(integer) 1
127.0.0.1:6379> TYPE zset1
zset
一次生成多个数据:
192.168.7.101:6379> ZADD zset2 1 v1 2 v2 3 v3 4 v4 5 v5
(integer) 5
127.0.0.1:6379> TYPE zset2
zset
集合排行案例
192.168.7.104:6379> ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia
(integer) 4
192.168.7.101:6379> ZRANGE paihangbang 0 -1 #显示集合内所有的key
1) "gangtiexia"
2) "zhuluoji"
3) "nezha"
4) "zhanlang"
192.168.7.104:6379> ZREVRANGE paihangbang 0 -1 withscores #显示指定集合内所有key和得分情况
1) "zhuluoji" #键
2) "60" #值
3) "nezha"
4) "90"
5) "zhanlang"
6) "199"
获取集合的长度数
127.0.0.1:6379> ZCARD zset1
(integer) 4
127.0.0.1:6379> ZCARD zset2
(integer) 4
基于索引返回数值
127.0.0.1:6379> ZRANGE zset1 1 3
1) "v2"
2) "v3"
3) "v4"
127.0.0.1:6379> ZRANGE zset1 0 2
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> ZRANGE zset1 2 2
1) "v3"
返回某个数值的索引
127.0.0.1:6379> ZRANK zset1 v2
(integer) 1
127.0.0.1:6379> ZRANK zset1 v3
(integer) 2
哈希(hash)
hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象,Redis 中每个 hash 可以存储 2^32-1 键值对(40多亿)。
生成hash key
127.0.0.1:6379> HSET hash1 name tom age 18
(integer) 1
127.0.0.1:6379> TYPE hash1
hash
获取hash key字段值
127.0.0.1:6379> HGET hash1 name
"tom"
127.0.0.1:6379> HGET hash1 age
"18"
删除一个hash key的字段
127.0.0.1:6379> HDEL hash1 age
(integer) 1
获取所有hash表中的key
127.0.0.1:6379> HMSET hash1 name tom age 19
(integer) 1
127.0.0.1:6379> HKEYS hash1
1) "name"
2) "age"
h获取指定hash的所有key及value
127.0.0.1:6379> HGETALL hash1
1) "name"
2) "tom"
3) "age"
4) "19"
消息队列
消息队列主要分为两种,分别是生产者消费者模式和发布者订阅者模式,这两种模式Redis都支持。
Producer/Consumer模式
在生产者消费者(Producer/Consumer)模式下,上层应用接收到的外部请求后开始处理其当前步骤的操作,在执行完成后将已经完成的操作发送至指定的频道(channel)当中,并由其下层的应用监听该频道并继续下一步的操作,如果其处理完成后没有下一步的操作就直接返回数据给外部请求,如果还有下一步的操作就再将任务发布到另外一个频道,由另外一个消费者继续监听和处理。
模式介绍:
生产者消费者模式下,多个消费者同时监听一个队里,但是一个消息只能被最先抢到消息的消费者消费,即消息任
务是一次性读取和处理,此模式在分布式业务架构中非常常用,比较常用的软件还有RabbitMQ、Kafka、
RocketMQ、ActiveMQ等。
队列介绍
队列当中的 消息由不同的生产者写入也会有不同的消费者取出进行消费处理,但是一个消息一定是只能被取出一次也就是被消费一次
生产者发布消息
# redis-cli
127.0.0.1:6379> LPUSH channel1 msg1 #从管道的左侧写入
(integer) 1
127.0.0.1:6379> LPUSH channel1 msg2
(integer) 2
127.0.0.1:6379> LPUSH channel1 msg3
(integer) 3
127.0.0.1:6379> LPUSH channel1 msg4
(integer) 4
127.0.0.1:6379> LPUSH channel1 msg5
(integer) 5
查看队列所有消息
127.0.0.1:6379> LRANGE channel1 0 -1
1) "msg5"
2) "msg4"
3) "msg3"
4) "msg2"
5) "msg1"
消费者消费信息
127.0.0.1:6379> RPOP channel1 #从管道的右侧消费
"msg1"
127.0.0.1:6379> RPOP channel1
"msg2"
127.0.0.1:6379> RPOP channel1
"msg3"
127.0.0.1:6379> RPOP channel1
"msg4"
127.0.0.1:6379> RPOP channel1
"msg5"
127.0.0.1:6379> RPOP channel1
(nil)
再次验证队列消息
127.0.0.1:6379> LRANGE channel1 0 -1
(empty list or set) #队列中的消息已经被已全部消费完毕
Publisher/Subscriber模式
模式简介
在发布者订阅者模式下,发布者将消息发布到指定的channel里面,凡是监听该channel的消费者都会收到同样的一份消息,这种模式类似于是收音机的广播模式,即凡是收听某个频道的听众都会收到主持人发布的相同的消息内容。
此模式常用语群聊天、群通知、群公告等场景。
Subscriber:订阅者
Publisher:发布者
Channel:频道
订阅者监听频道
# redis-cli
127.0.0.1:6379> AUTH 123456
OK
127.0.0.1:6379> SUBSCRIBE channel1 #订阅者订阅指定的频道
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel1"
3) (integer) 1
发布者发布消息
127.0.0.1:6379> PUBLISH channel1 test1 #发布者发布消息
(integer) 2
127.0.0.1:6379> PUBLISH channel1 test2
(integer) 2
各订阅者验证消息
127.0.0.1:6379[2]> subscribe channel1
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel1"
3) (integer) 1
1) "message"
2) "channel1"
3) "test1" #接收到的第一个消息
1) "message"
2) "channel1"
3) "test2" #第二个消息
#注:订阅者只能接受监听后发生的消息,如果在监听之前发生的消息,无法查看
订阅多个频道
订阅指定的多个频道
> SUBSCRIBE channel1 channel2
订阅所有频道
127.0.0.1:6379> PSUBSCRIBE *
订阅匹配频道
127.0.0.1:6379> PSUBSCRIBE chann* #匹配订阅多个频道
redis常用命令
CONFIG
config 命令用于查看当前redis配置、以及不重启更改redis配置等
更改最大内存
127.0.0.1:6379> CONFIG set maxmemory 8589934592
OK
127.0.0.1:6379> CONFIG get maxmemory
1) "maxmemory"
2) "8589934592"
设置连接密码
127.0.0.1:6379[1]> config set requirepass "123456" #通过config设置密码,立即生效
OK
127.0.0.1:6379> AUTH 123456 #验证密码
OK
127.0.0.1:6379> auth pass #误输入错误密码
(error) ERR invalid password
127.0.0.1:6379> info
NOAUTH Authentication required. #验证失败,无法访问数据
获取当前配置
127.0.0.1:6379> config get *
1) "dbfilename"
2) "dump.rdb"
3) "requirepass"
4) "pass"
5) "masterauth"
6) ""
7) "cluster-announce-ip"
8) ""
9) "unixsocket"
10) ""
...
info
显示当前节点redis运行状态信息
127.0.0.1:6379> info
# Server
redis_version:4.0.14
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:2cb7c66593b8efb3
redis_mode:standalone
os:Linux 3.10.0-957.el7.x86_64 x86_64
arch_bits:64
...
SELECT
切换数据库,等于MySQL的use DBNAME指令
127.0.0.1:6379> SELECT 1
OK
127.0.0.1:6379[1]>
keys
查看当前库下的所有key
127.0.0.1:6379[1]> keys *
1) "zset2"
2) "list2"
3) "zset1"
4) "hash1"
BGSAVE
手动在后台执行RDB持久化操作
127.0.0.1:6379[1]> BGSAVE
Background saving started
127.0.0.1:6379[1]>
DBSIZE
返回当前库中的所有key数量
127.0.0.1:6379[1]> DBSIZE
(integer) 5
127.0.0.1:6379[1]>
FLUSHDB
强制清空当前库中的所有key,慎用
FLUSHALL
强制清空当前redis服务器所有数据库中的所有key,即删除所有数据,慎用