Redis(Remote Dictionary Server)是一个开源的内存中数据结构存储系统,可以用作数据库、缓存和消息中间件。
以下是一些Redis的基本操作和示例代码:
- 连接Redis服务器
import redis
# 连接本地Redis服务
r = redis.Redis(host='localhost', port=6379, db=0)
# 连接远程Redis服务
r = redis.Redis(host='remote_host', port=6379, db=0, password='your_password')
- 设置键值对
r.set('key', 'value')
- 获取键的值
value = r.get('key')
print(value)
- 设置带有过期时间的键值对
r.setex('key', 10, 'value') # 键在10秒后过期
- 更新键的值
r.set('key', 'new_value')
- 删除键
r.delete('key')
- 检查键是否存在
exists = r.exists('key')
print(exists)
- 获取键的其他信息
ttl = r.ttl('key') # 获取键的剩余生存时间
type = r.type('key') # 获取键的数据类型
- 使用列表
# 在列表左侧插入值
r.lpush('list_key', 'element')
# 在列表右侧插入值
r.rpush('list_key', 'element')
# 获取列表的长度
length = r.llen('list_key')
# 获取列表的元素
elements = r.lrange('list_key', 0, -1)
- 使用集合
# 添加元素到集合
r.sadd('set_key', 'member')
# 获取集合的所有成员
members = r.smembers('set_key')
# 计算集合的成员数
count = r.scard('set_key')
- 使用有序集合
# 添加成员到有序集合
r.zadd('sorted_set_key', {'member': score})
# 获取有序集合的成员数
count = r.zcard('sorted_set_key')
# 获取有序集合指定范围内的成员
members = r.zrange('sorted_set_key', 0, -1)
- 使用哈希
# 设置哈希字段的值
r.hset('hash_key', 'field', 'value')
# 获取哈希字段的值
value = r.hget('hash_key', 'field')
# 获取哈希中的所有字段和值
fields_and_values = r.hgetall('hash_key')
- 事务
# 开始事务
pipeline = r.pipeline()
# 将多个命令加入到事务中
pipeline.set('key1', 'value1')
pipeline.set('key2', 'value2')
# 执行事务
pipeline.execute()
- 监听键
# 使用发布/订阅模式监听键
pubsub = r.pubsub()
pubsub.subscribe('__keyevent@0__:set', 'key')
# 等待并接收消息
for message in pubsub.listen():
print(message)
- 持久化
# 手动触发RDB持久化