Redis 的键(Key)是其数据模型的核心组成部分,几乎所有的数据操作都是围绕键来进行的。键在 Redis 中用于唯一标识数据,可以存储各种类型的数据,包括字符串、哈希、列表、集合、有序集合等。本文将深入探讨 Redis 键的管理,包括键的命名规范、键的生命周期管理、键的模式匹配以及 KEYS
和 SCAN
等命令的使用,通过具体的案例来展示键在实际项目中的应用和管理策略。
键的命名规范对于数据的组织和管理至关重要。良好的命名规范可以使数据结构更加清晰,便于维护和查询。
user:123:profile
表示用户ID为123的个人资料。
假设我们正在构建一个电子商务网站,需要存储用户信息、购物车和订单数据。
# 用户信息
redis-cli SET user:123:name "John Doe"
redis-cli SET user:123:email "john.doe@example.com"
# 购物车
redis-cli SADD cart:123 item1
redis-cli SADD cart:123 item2
# 订单
redis-cli HMSET order:123:details status "pending" total "100"
Redis 键具有生命周期,可以通过设置过期时间来自动删除不再需要的键,以释放内存。
EXPIRE
和 PEXPIRE
EXPIRE
命令用于设置键的生存时间,以秒为单位。PEXPIRE
类似,但时间单位为毫秒。
# 设置键过期时间
redis-cli EXPIRE user:123:session 3600 # 1小时后过期
TTL
和 PTTL
TTL
命令用于查询键的剩余生存时间,以秒为单位。PTTL
类似,但返回毫秒为单位的时间。
# 查询键的剩余生存时间
redis-cli TTL user:123:session
假设我们正在实现一个用户会话管理系统,需要确保用户会话在一段时间后自动失效。
# 设置用户会话
redis-cli SET user:123:session "session_data"
redis-cli EXPIRE user:123:session 1800 # 30分钟后过期
# 查询会话剩余时间
redis-cli TTL user:123:session
Redis 提供了模式匹配功能,用于查找符合特定模式的键。
KEYS pattern
KEYS
命令用于查找所有符合给定模式的键。然而,KEYS
命令在大数据集上可能会导致阻塞,因此在生产环境中应谨慎使用。
# 查找所有用户相关的键
redis-cli KEYS user:*
SCAN cursor [MATCH pattern] [COUNT count]
SCAN
命令提供了一种迭代查找键的方式,可以避免阻塞问题,更适用于生产环境。
# 使用 SCAN 迭代查找所有用户相关的键
redis-cli SCAN 0 MATCH user:* COUNT 100
假设我们需要清理过期的用户会话,但又不想影响当前的数据库操作。
# 使用 SCAN 查找所有用户会话键
SCAN 0 MATCH user:*:session
# 遍历并删除过期的会话
while true; do
redis-cli SCAN $cursor MATCH user:*:session COUNT 100 | while read cursor keys; do
for key in $keys; do
if [[ $(redis-cli TTL $key) -lt 0 ]]; then
redis-cli DEL $key
fi
done
done
done