Redis是一个开源的使用C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
以下是Redis的一些重要知识点:
- 数据类型:Redis支持字符串、列表、集合、有序集合、哈希表等数据类型。
- 持久化:Redis支持两种持久化方式,RDB(默认方式)和AOF。
- 内存管理:Redis使用了高效的内存管理机制,如在内存不足时,会使用虚拟内存(swap)。
- 性能优化:Redis包含多种性能优化策略,如内存优化、连接优化等。
- 事务:Redis的事务可以一次性按顺序执行多个命令,与传统事务不同,Redis事务不保证原子性。
- 发布/订阅:Redis提供发布/订阅功能,可以用于消息订阅和发布。
- 分布式锁:Redis可以作为分布式锁使用,解决多线程、多进程中的同步问题。
- 集群:Redis支持集群模式,可以通过Redis Sentinel和Redis Cluster实现高可用性。
示例代码(Python使用redis-py库):
import redis
# 连接Redis
r = redis.Redis(host='localhost', port=6379, db=0)
# 设置键值对
r.set('key', 'value')
# 获取键对应的值
value = r.get('key')
print(value)
# 列表操作
r.lpush('mylist', 'value1')
r.lpush('mylist', 'value2')
print(r.lrange('mylist', 0, -1)) # 获取列表所有元素
# 集合操作
r.sadd('myset', 'value1')
r.sadd('myset', 'value2')
print(r.smembers('myset')) # 获取集合所有元素
# 哈希操作
r.hset('myhash', 'field1', 'value1')
print(r.hgetall('myhash')) # 获取哈希所有字段和值
# 使用事务
pipeline = r.pipeline()
pipeline.set('key1', 'value1')
pipeline.set('key2', 'value2')
pipeline.execute()
# 发布订阅
pubsub = r.pubsub()
pubsub.subscribe('channel1')
pubsub.publish('channel1', 'message1')
以上代码展示了如何使用Python的redis-py库进行Redis的基本操作,包括字符串、列表、集合、哈希表的增删改查,以及事务处理和发布/订阅。