Redis 安装
- 安装依赖
yum install -y gcc tcl
- 上传安装包并解压
tar -zxvf redis-6.2.6.tar.gz
链接: https://pan.baidu.com/s/1uBw8qC2JMcbagrX7U9mlOA 提取码: wbs6
- 编译
make && make install
Redis 启动
- 前台启动
redis-server
指定配置文件启动
- 备份
cp redis.conf redis.conf.bck
- 修改配置文件
# 允许访问地址 bind 0.0.0.0 # 日志输出 logfile "redis.log" # 密码 requirepass ruochen666
- 使用 systemctl 配置
vim /etc/systemd/system/redis.service
# 写入内容如下
[Unit]
Description=redis-server
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/bin/redis-server /usr/local/src/redis-6.2.6/redis.conf
PrivateTmp=true
[Install]
WantedBy=multi-user.target
# 重载系统服务
systemctl daemon-reload
Redis 命令
通用命令(generic)
- keys:查看符合模板的所有 key,
不建议在生产环境设备上使用
- del:删除指定的 key
- exists:判断 key 是否存在
- expire:给 key 设置有效期,有效期到期时该 key 会被自动删除
- ttl:查看 key 的剩余有效期
String 类型
- set:添加/修改已经存在的一个 String 类型的键值对
- get:根据 key 获取 String 类型的 value
- mset:批量添加
- mget:批量获取
- incr:让一个整型的 key 自增 1
- incrby:让一个整型的 key 自增并指定步长
incrby num 2
:num 自增 2 - incrbyfloat:浮点数自增长(必须指定增长步长)
- setnx:添加一个 String 类型的键值对(前提是这个 key 不存在,否则不执行)
- setex:添加一个 String 类型的键值对,并且指定有效期
Key 的层级结构
- Redis 的 key 允许有多个单词形成层级结构,多个单词之间用
:
隔开,例如项目名:业务名:类型:id
例如项目名称为
ruochen
,有user
和product
两种不同类型的数据,我们可以这样定义 key:- user 相关的 key:
ruochen:user:1
- product 相关的 key:
ruochen:product:1
- user 相关的 key:
set ruochen:user:1 '{"id":1, "name":"Jack", "age": 21}'
set ruochen:user:2 '{"id":2, "name":"Rose", "age": 18}'
set ruochen:product:1 '{"id":1, "name":"小米11", "price": 4999}'
set ruochen:product:2 '{"id":2, "name":"荣耀6", "price": 2999}'
Hash 类型
- Value 是一个无序字典,类似于 Java 中的 HashMap 结构
- String 结构存储的是对象序列化后的 json 数据,修改某个字段很不方便
- Hash 结构可以将对象中的每个字段独立存储,可以针对单个字段做 CRUD(相对于 String 结构更加灵活)
常用命令
- hset key field value:添加/修改 hash 类型 key 的 field 的值,eg:
hset ruochen:user:3 name Lucy
- hget key field:获取一个 hash 类型 key 的 field 值,eg:
hget ruochen:user:3 name
- hmset:批量新增,eg:
hmset ruochen:user:4 name Tom age 22 sex man
- hmget:批量获取,eg:
hmget ruochen:user:4 name age sex
- hgetall:获取一个 hash 类型的 key 中的所有的 field 和 value,eg:
hgetall ruochen:user:4
- hkeys:获取一个 hash 类型的 key 中所有的 field,eg:
hkeys ruochen:user:4
- hvals:获取一个 hash 类型的 key 中所有的 value,eg:
hvals ruochen:user:4
- hincrby:让一个 hash 类型 key 的字段值自增长并指定步长,eg:
hincrby ruochen:user:4 age 2
- hsetnx:添加一个 hash 类型的 key 的 field 值(前提是这个 field 不存在,否则不执行)
- hset key field value:添加/修改 hash 类型 key 的 field 的值,eg:
List 类型
- Redis 中的 List 类型与 Java 中的 LinkedList 类似,可以看作是一个双向链表架构(既支持正向检索,也支持反向检索)
特征
- 有序
- 元素可以重复
- 插入和删除快
- 查询速度一般
- 使用场景:朋友圈点赞列表,评论列表等
常用命令
- lpush key element ...:向列表左侧插入一个或多个元素(队首),eg:
lpush users 1 2 3
- lpop key:移除并返回列表左侧的第一个元素,没有则返回 nil,eg:
lpop users 1
- rpush key element ...:向列表右侧插入一个或多个元素(队尾),eg:
rpush users 4 5 6
- rpop key:移除并返回列表右侧的第一个元素,没有则返回 nil,eg:
rpop users 1
- lrange key start end:返回一段角标范围内的所有元素(角标从 0 开始),eg:
lrange users 1 2
- blpop 和 brpop:与 lpop 和 rpop 类似,只不过在没有元素时等待指定时间,而不是直接返回 nil,eg:
blpop users2 100
lpush users2 jack
- lpush key element ...:向列表左侧插入一个或多个元素(队首),eg:
如何利用 list 结构模拟一个栈?
- 入口和出口在同一边
lpush + lpop
或者rpush + rpop
如何利用 list 结构模拟一个队列?
- 入口和出口在不同边
lpush + rpop
或者rpush + lpop
如何利用 list 结构模拟一个阻塞队列?
- 入口和出口在不同边
- 出对时采用
blpop
或brpop
Set 类型
Redis 的 Set 结构与 Java 中的 HashSet 类似,可以看作是一个 value 为 null 的 HashMap。因为也是一个 hash 表,因此具备与 HashSet 类似的特征
- 无序
- 元素不可重复
- 查找快
- 支持交集、并集、差集等功能
常用命令
- sadd key member ... :向 set 中添加一个或多个元素,eg:
sadd s1 a b c
- srem key member ... :移除 set 中的指定元素,eg:
srem s1 a
- scard key:返回 set 中元素的个数,eg:
scard s1
- sismember key member:判断一个元素是否存在于 set 中,eg:
sismember s1 a
- smembers:获取 set 中的所有元素,eg:
smembers s1
- sinter key1 key2 ... :求 key1 和 key2 的交集
- sdiff key1 key2 ... :求 key1 和 key2 的差集
- sunion key1 key2 ... :求 key1 和 key2 的并集
- sadd key member ... :向 set 中添加一个或多个元素,eg:
SortedSet 类型
- 可排序集合,与 Java 中的 TreeSet 有些类似,但底层数据结构却差别很大。SortedSet 中的每一个元素都带有一个 score 属性,可以基于 score 属性对元素排序,底层的实现是一个跳表(SkipList)加 hash 表
特性
- 可排序
- 元素不重复
- 查询速度快
- 应用场景:排行榜
常用命令
- zadd key score member:添加一个或多个元素到 sorted set,如果已经存在则更新其 score 值,eg:
zadd stus 85 Jack 89 Lucy 82 Rose 95 Tom 78 Jerry 92 Amy 76 Miles
- zrem key member:删除 sorted set 中的一个指定元素,eg:
zrem stus Tom
- zscore key member:获取 sorted set 中的指定元素的 score 值
- zrank key member:获取 sorted set 中指定元素的排名,eg:
zrevrank stus Rose
- zcard key:获取 sorted set 中的元素个数,eg:
zcard stus
- zcount key min max:统计 score 值在给定范围内的所有元素的个数,eg:
zcount stus 0 80
- zincrby key increment member:让 sorted set 中的指定元素自增,步长为指定的 increment 值,eg:
zincrby stus 2 Amy
- zrange key min max:按照 score 排序后,获取指定排名范围内的元素,eg:
zrevrange stus 0 2
- zrangebyscore key min max:按照 score 排序后,获取指定 score 范围内的元素,eg:
zrangebyscore stus 0 80
- zdiff、zinter、zunion:求差集、交集、并集
- zadd key score member:添加一个或多个元素到 sorted set,如果已经存在则更新其 score 值,eg:
所有的排名默认都是升序,如果要降序则命令的z
后面添加rev
即可