1,什么是redis?
    是一个支持持久化的非关系型数据库。
    2,使用场景?
    缓存 ,列队 ,计数器 ,发布与订阅
    3,redis有哪些功能?
    数据缓存功能:
    分布式锁功能:
    加锁机制
    锁互斥机制
    watch dog自动延期机制
    可重入加锁机制
    释放锁机制
    持久化功能:
    RDB:定期时间保存
    AOF:写入就保存
    支持事务:
    Multi:标记事务的开始
    Exec:执行事务的commands队列
    Discard:结束事务,并清除commands队列
    支持消息队列
    实现原理 redis的list列表 左进右出 或 右进左出,
    4,redis支持的数据类型有哪些?
    list,set,zset, hash, string 等 还有其他类型不常用
    5,redis的淘汰策略
    有过期时间:淘汰快要过期的 或 最近很少用的 或 随机淘汰
    无过期时间: 淘汰最近很少用的 或 随机淘汰
    禁止淘汰
    6,redis分布式项目中央缓存的问题
    1.缓存穿透:数据库 redis都没有数据 大量查询导致数据库宕机
    解决办法:①接口层增加校验 防止恶意攻击
    ②将查询的null 保存在redis缓存中 请求的参数为K,null为v保存并设置过期时间。
    ③布隆过滤器
    2.缓存击穿:数据库中有数据 redis没有(缓存到期) 导致数据库压力变大
    解决办法:① 将热点数据设置永远不过期
    ②接口限流与熔断,降级
    ③加互斥锁
    3.缓存雪崩:redis缓存大批量同时到期 导致服务器压力变大
    解决办法:① 缓存的过期时间设置随机
    ② 如果缓存数据库是分布式部署,将热点数据均匀分布在不同搞得缓存数据库中
    ③ 设置热点数据永远不过期。
    4.缓存的一致性(分布式项目的数据更新与缓存数据的问题)
    解决办法:①采用延时双删 也有其他的方式
    7,redis与 Memcached有哪些优势?
    相同点:都是key-value Nosql,数据存储在内存中,读写效率高,都支持存储过期.
    不同点:redis有丰富的数据类型
    redis支持持久化 速度比他快
    8,Memcached与 Redis的区别有哪些?
    ⒈储存方式 Memcached:储存在内存中 Redis:除了内存还有磁盘(RDB,AOF)
    ⒉数据类型 Memcached:数据单一 Redis:数据类型丰富
    ⒊底层模型 Memcached: Redis:有自己的VM机制
    9,Reids是单进程单线程的吗?
    ⒈Redis 是单进程单线程的,redis 利用队列技术将并发访问变为串行访问,消除了传统数据库串行控制的开销。
    10,为什么redis 需要把所有数据放到内存中
    ⒈为了达到最快的读写速度,并通过异步方式将数据写入磁盘
    11,Redis的同步机制了解吗?

    12,是否使用过 Redis 集群,集群的原理是什么

    13,Redis 集群方案什么情况下会导致整个集群不可用?

    14,Redis 支持的 Java 客户端都有哪些?官方推荐用哪个?

    15,Jedis 与 Redisson 对比有什么优缺点?

    16,说说 Redis 哈希槽的概念?

    17,Redis 集群的主从复制模型是怎样的

    18,Redis 集群会有写操作丢失吗?为什么

    19,Redis 集群之间是如何复制的
    ①异步复制
    20,Redis 集群如何选择数据库
    ①Redis集群目前无法选择数据库 默认为0
    21,怎么测试 Redis 的连通性?
    ①使用ping命令
    22,怎么理解 Redis 事务?
    ①事务是一个单独的隔离操作:事务中的所有命令都会序列化,按顺序地执行。事务在执行过程中,不会被其他客户端发送的命令打断
    ②事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行
    23,Redis 事务相关的命令有哪几个
    ①MULTI EXEC DISCARD WATCH
    24,Redis key 的过期时间和永久有效分别怎么设置?
    ①EXPIRE 和 PEESIST 命令。 Explpe.persist
    25,Redis 如何做内存优化
    ①尽可能使用散列表(hashes) : 说散列表里面存储的数少 占用的内存非常少
    26,Redis 回收进程如何工作的

    27,Redis 的内存用完了会发生什么?
    ①如果达到设置的上限,Redis的写命令会返回错误信息(但是读命令还是可以正常返回)
    ②或者将Redis当缓存来使用配置淘汰机制,当Redis达到内存上限时会冲刷旧的内容
    28,一个 Redis 实例最多能存放多少的 keys?List、Set,Sorted Set他们最多能存放多少元素
    ①理论上Redis可以处理多达2^32的keys, 并且在实际中的测试 每个实例至少存放2亿到5亿
    ②任何数据类型(list,set….)都可以存放2^32 换句话说,Redis的存储极限是系统中的可用内存值
    29,MySQL 里有 2000w 数据,redis 中只存 20w 的数据,如何保证 redis 中的数据都是热点数据
    ①内存数据集大小上升到一定大小的时候,就会执行数据淘汰策略
    30,如果有大量的 key 需要设置同一时间过期,一般需要注意什么
    ①如果大量的key过期时间设置的过于集中,到期的那个时间点,redis可能会出现卡顿的现象,一般需要在时间上加上一个随机值,使得过期时间分散一些。比如缓存雪崩
    31,使用过 Redis 做异步队列么,你是怎么用的
    ①一般使用List结构作为队列,rpush生产消息,lpop消费消息。当lpop没有消息的时候,要适当sleep一会再重试
    32,Redis为什么是单线程的而不是多线程的?从cpu的角度来看,单线程和多线程有什么性能的区别?为什么单线程也能实现这么高的性能
    33,有没有做Redis的集群?有哪几种方式,Redis的集群最少要有多少个节点?如果其中一个节点挂掉会怎样?如果只有两个主节点Redis能不能跑起来
    34,Redis分布式锁,解决的是分布式的线程问题,Redis分布式锁的实现思路,怎样做到线程安全
    35,Redis 实现分布式锁原理流程
    36,Redis 分布式锁有什么缺陷
    37,Redisson(redis集群的分布式锁)