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(从文件加载内存)两个函数
- AOF:Aof是Append-only file缩写,每当执行服务器(定时)任务或者函数时flushAppendOnlyFile 函数都会被调用, 这个函数执行以下两个工作
aof写入保存:
WRITE:根据条件,将 aof_buf 中的缓存写入到 AOF 文件
SAVE:根据条件,调用 fsync 或 fdatasync 函数,将 AOF 文件保存到磁盘中。
存储结构:内容是redis通讯协议(RESP )格式的命令文本存储。
区别:
- aof文件比rdb更新频率高,优先使用aof还原数据。
- aof比rdb更安全也更大
- rdb性能比aof好
- 如果两个都配了优先加载AOF
3.什么是Redis的通讯协议(RESP)?有什么特点?
RESP是Redis客户端与服务端之前使用的一种通讯协议;RESP 的特点:实现简单、快速解析、可读性好
4.Redis有哪些架构模式?它们有什么特点?
- 单机版:
- 特点:简单 ;问题:内存容量有限,处理能力有限,无法高可用
2.主从复制:Redis 的复制(replication)功能允许用户根据一个 Redis 服务器来创建任意多个该服务器的复制品,其中被复制的服务器为主服务器(master),而通过复制创建出来的服务器复制品则为从服务器(slave)。 只要主从服务器之间的网络连接正常,主从服务器两者会具有相同的数据,主服务器就会一直将发生在自己身上的数据更新同步 给从服务器,从而一直保证主从服务器的数据相同。
- 特点:master/slave角色;master/salve数据相同;降低master读压力转给从库;
- 问题:无法保证高可用;没有解决master写的压力
3.哨兵:Redis sentinel 是一个分布式系统中监控 redis 主从服务器,并在主服务器下线时自动进行故障转移。其中三个特性:
- 监控(Monitoring): Sentinel 会不断地检查你的主服务器和从服务器是否运作正常。
- 提醒(Notification): 当被监控的某个 Redis 服务器出现问题时, Sentinel 可以通过 API 向管理员或者其他应用程序发送通知。
- 自动故障迁移(Automatic failover): 当一个主服务器不能正常工作时, Sentinel 会开始一次自动故障迁移操作。
特点:保证高可用;监控各个节点,自动故障迁移;缺点:主从模式切换需要时间丢失数据,没有解决master写的压力