1.什么是Redis?

Redis是一个开源的使用ANSI C语言编写、遵守BSD协议(一种开源协议,除此之外还有GPL、LGPL、MIT、Apache)、支持网络、可基于内存亦可持久化的日志类型、Key-Value数据库,并提供多种语言API的非关系型数据库。传统数据库遵循ACID规则(原子性,一致性,持久性,隔离性),而NoSql一般为分布式,遵循CAP定理(一致性,可用性,分区容错性)。

2.Redis支持的数据类型?

  • String类型:String类型是Redis最基本的数据类型,一个键最大能存储512M,String类型是二进制安全的。意思是Redis的String可以包含任何数据,包括jpg或序列化对象
  • Hash(哈希):Redis Hash是一个键值对集合,是一个String类型的field和value的映射表,hash特别适合存储对象
  • List(列表):Redis 列表是简单的字符串列表,按照插入顺序排序。
  • Set(集合):Redis的Set是String类型的无序集合,集合通过哈希表实现,所以添加、删除、查找的复杂度都是O(1)
  • ZSet(sorted set,有序集合):Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但是分数却可以重复

3.什么是Redis持久化?Redis由哪几种持久化方式?各有什么优缺点?

持久化就是把内存的数据写入磁盘中,防止服务宕机了内存数据丢失。Redis提供两种持久化方式:RDB(默认)和AOF。

  • RDB:RDB是Redis Database缩写,功能核心函数rdbSave(生成RDB文件)和rdbLoad(从文件加载内存)两个函数

Redis相关问题 - 图1

  • AOF:Aof是Append-only file缩写,每当执行服务器(定时)任务或者函数时flushAppendOnlyFile 函数都会被调用, 这个函数执行以下两个工作

aof写入保存:
WRITE:根据条件,将 aof_buf 中的缓存写入到 AOF 文件
SAVE:根据条件,调用 fsync 或 fdatasync 函数,将 AOF 文件保存到磁盘中。
Redis相关问题 - 图2
存储结构:内容是redis通讯协议(RESP )格式的命令文本存储。
区别:

  1. aof文件比rdb更新频率高,优先使用aof还原数据。
  2. aof比rdb更安全也更大
  3. rdb性能比aof好
  4. 如果两个都配了优先加载AOF


3.什么是Redis的通讯协议(RESP)?有什么特点?

RESP是Redis客户端与服务端之前使用的一种通讯协议;RESP 的特点:实现简单、快速解析、可读性好

4.Redis有哪些架构模式?它们有什么特点?

  1. 单机版
  • 特点:简单 ;问题:内存容量有限,处理能力有限,无法高可用

Redis相关问题 - 图3
2.主从复制:Redis 的复制(replication)功能允许用户根据一个 Redis 服务器来创建任意多个该服务器的复制品,其中被复制的服务器为主服务器(master),而通过复制创建出来的服务器复制品则为从服务器(slave)。 只要主从服务器之间的网络连接正常,主从服务器两者会具有相同的数据,主服务器就会一直将发生在自己身上的数据更新同步 给从服务器,从而一直保证主从服务器的数据相同。

  • 特点:master/slave角色;master/salve数据相同;降低master读压力转给从库;
  • 问题:无法保证高可用;没有解决master写的压力

Redis相关问题 - 图4
3.哨兵:Redis sentinel 是一个分布式系统中监控 redis 主从服务器,并在主服务器下线时自动进行故障转移。其中三个特性:

  • 监控(Monitoring): Sentinel 会不断地检查你的主服务器和从服务器是否运作正常。
  • 提醒(Notification): 当被监控的某个 Redis 服务器出现问题时, Sentinel 可以通过 API 向管理员或者其他应用程序发送通知。
  • 自动故障迁移(Automatic failover): 当一个主服务器不能正常工作时, Sentinel 会开始一次自动故障迁移操作。

特点:保证高可用;监控各个节点,自动故障迁移;缺点:主从模式切换需要时间丢失数据,没有解决master写的压力