Redis 面试深度解析(redis 深度面试题)
Redis 面试深度解析
Redis 是一个高性能的键值存储系统,因其数据结构简单、读写性能高,在企业应用中得到了广泛的应用。在Redis的应用和开发中,Redis的面试也被越来越多的企业看作是衡量一个程序员的技术水平的重要指标。如何在面试中脱颖而出呢?下面是一份 Redis 面试深度解析,希望能对你在Redis的面试中有所帮助。
1. Redis 的五种数据结构类型是什么?
– String(字符串)
– Hash(哈希)
– List(列表)
– Set(集合)
– Sorted Set(有序集合)
代码演示:
“`python
# 连接 Redis
import redis
r = redis.Redis(host=’localhost’, port=6379, db=0)
# 操作 String 数据结构
r.set(‘name’, ‘Tom’) # 设置 key-value
name = r.get(‘name’) # 获取 key 对应的 value
print(name)
# 操作 Hash 数据结构
r.hset(‘user’, ‘name’, ‘Tom’) # 设置哈希的 k-v
r.hset(‘user’, ‘age’, 20)
user = r.hgetall(‘user’) # 获取哈希键对应的值
print(user)
# 操作 List 数据结构
r.lpush(‘numbers’, 1) # 从左边添加值
r.lpush(‘numbers’, 2)
r.lpush(‘numbers’, 3)
numbers = r.lrange(‘numbers’, 0, -1) # 获取列表值
print(numbers)
# 操作 Set 数据结构
r.sadd(‘colors’, ‘red’) # 是用 SADD 添加 value
r.sadd(‘colors’, ‘blue’)
r.sadd(‘colors’, ‘yellow’)
colors = r.smembers(‘colors’) # 获取 set 的所有成员
print(colors)
# 操作 Sorted Set 数据结构
r.zadd(‘students’, {‘Tom’: 80, ‘Jerry’: 90, ‘Tony’: 85}) # 添加有序集合
students = r.zrange(‘students’, 0, -1, withscores=True) # 获取有序集合成员以及分数
print(students)
2. Redis 常用的命令有哪些?
- SET:设置值。- GET:获取值。
- EXISTS:检查键是否存在。- DEL:删除键。
- INCR:递增一个值。- DECR:递减一个值。
- HSET:设置哈希表一个字段的值。- HGET:获取哈希表一个字段的值。
- LPUSH:将一个值插入到列表头部。- RPUSH:将一个值插入到列表尾部。
- LPOP:移除并返回列表的头元素。- RPOP: 移除并返回列表的尾元素。
- SADD:向集合添加一个或多个成员。- SMEMBERS: 返回集合中的所有成员。
- ZADD:向有序集合添加一个或多个成员。- ZRANGE:通过索引区间返回有序集合成指定区间内的所有成员。
- EXPIRE:设置键的过期时间。
3. Redis 的持久化机制有哪些?
- RDB(Redis DataBase): 将 Redis 在内存中的数据以快照的形式保存到磁盘上- AOF(Append Only File): 把所有的写操作都保存起来,Redis 重启时会从文件中重放这些命令来恢复原始的数据
代码演示:
```bash# 启用 AOF 持久化
appendonly yesappendfilename "appendonly.aof"
# 设置持久化方式为 AOFsave 900 1 # 将900秒内对数据进行了至少1次修改
save 300 10 # 将300秒内对数据进行了至少10次修改save 60 10000 # 将60秒内对数据进行了至少10000次修改
# 设置 RDB 快照保存save 900 1
save 300 10save 60 10000
4. Redis 的缓存淘汰策略有哪些?
– LRU(Least Recently Used):移除最近最少使用的缓存。
– LFU(Least Frequently Used):删除一定时间内被访问频次最少的那些缓存。
– FIFO(First In First Out):先进先出,移除最早加入缓存的缓存。
代码演示:
“`bash
# 使用 LFU 淘汰策略
maxmemory 100mb
maxmemory-policy allkeys-lfu
# 使用 LRU 淘汰策略
maxmemory 100mb
maxmemory-policy allkeys-lru
# 使用 FIFO 淘汰策略
maxmemory 100mb
maxmemory-policy allkeys-fifo
5. Redis 的主从复制原理是什么?
主从复制是 Redis 的一个比较常用的功能,常用于数据备份、故障恢复以及性能扩展等场景。Redis 主从复制的原理:首先我们需要有一个主节点,主节点可以写数据,也可以读数据;然后我们需要一个或多个从节点,从节点只能读数据,不可以写数据。主节点会将写入的数据同步到从节点,从而实现数据备份、故障恢复以及性能扩展。从节点会定时向主节点发送 SYNC 命令,主节点在收到该命令之后,会发送 RDB 文件或增量数据给从节点,从节点接收到数据后,通过缓存内存复制主节点的数据。
代码演示:
```bash# 在主节点创建一个账号
127.0.0.1:6379> set name Tom
# 在从节点访问账号127.0.0.1:6380> get name
"Tom"
# 查看主从节点的状态127.0.0.1:6379> info replication
# Replicationrole:master
connected_slaves:1slave0:ip=127.0.0.1,port=6380,state=online,offset=366,lag=1
以上就是 Redis 面试深度解析,希望对你在Redis的应用和开发中有所帮助。