redis部署与使用(二)

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,即删除所有数据,慎用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值