redis的相关面试问题

redis教程:http://www.redis.net.cn/tutorial/3501.html

===============================================================================

1.redis如何实现高并发

redis通过一主多从,主节点负责写,从节点负责读,读写分离,从而实现高并发。

https://www.cnblogs.com/mengchunchen/p/10044603.html

===============================================================================

2.redis如何实现高可用

主备切换,哨兵集群,主节点宕机的情况下,自动选举出一个从节点变成主节点,从而保证了redis集群的高可用。

https://www.cnblogs.com/mengchunchen/p/10044840.html

===============================================================================

3.redis是单线程还是多线程?为什么单线程还能处理速度那么快?

  首先,redis是单进程单线程的k-v内存型可持久化数据库。

  单线程还能处理速度很快的原因:

    1》redis操作是基于内存的,内存的读写速度非常快

    2》正是由于redis的单线程模式,避免了线程上下文切换的损耗

    3》redis采用的IO多路复用技术,可以很好的解决多请求并发的问题。  多路代表多请求,复用代表多个请求重复使用同一个线程。epoll

  IO多路复用原理图如下:

===============================================================================

4.redis的应用场景

  1》key-value结构,内存存取,速度快,做缓存

  2》list或sort set 实现消息队列

  3》list的有序性,也可以做时间轴

  4》sort set的权重特性,可以做排行榜

  5》redis的原子性自增,可以实现计数器

  6》redis的set,实现好友关系的功能   A关注的人存放set   被谁关注存放set,B也同样存放两个set,A的关注的人set和B的关注的人set求交集,可以得到共同关注;A的关注的人set和A的被关注的set求交集,获取互相关注好友列表。

  7》分布式锁,可以设置过期时间,注意使用完成要delete掉

https://www.cnblogs.com/mengchunchen/p/9691021.html

===============================================================================

5.redis如何保证原子性,又是如何解决异步以及并发阻塞的?

  redis可以保证操作的原子性,是因为redis本身就是单进程单线程的。

  那既然是单进程的如何解决异步以及并发阻塞的?

  是通过IO多路复用技术解决的这个问题!

===============================================================================

6.redis 缓存穿透、缓存雪崩、缓存击穿

https://baijiahao.baidu.com/s?id=1619572269435584821&wfr=spider&for=pc

https://www.cnblogs.com/duanxz/p/3788366.html

https://www.cnblogs.com/dream-to-pku/p/9153999.html

这些问题的处理核心思想,就是尽可能的减小DB的访问压力!!

缓存穿透:无效ID,在redis缓存中查不到,去查询DB,造成DB压力增大。

解决方法:

  1》解决方法1:布隆过滤器,提供一个很大的Bit-Map,提供多个hash函数,分别对查询参数值【比如UUID】,进行求hash,然后分别对多个hash结果,在对应位置对比是否全为1或者某个位置为0,

          一旦有一个位置标识为0,表示本次查询UUID,不存在于缓存,再去查询DB.

    起到一个再过滤的效果。

  2》解决方法2:把无效的ID,也在redis缓存起来,并设置一个很短的超时时间。

缓存雪崩:缓存同一时间批量失效,导致大量的访问直接访问DB

解决方法:

  在做缓存时候,就做固定失效时间+随机时间段,保证所有的缓存不会同一时间失效

缓存击穿:在缓存失效的时候,会有高并发访问失效的缓存【热点数据】

解决方法:

  最简单的解决方法,就是将热点数据设置永不超时!

  第二个解决方法:对访问的Key加上互斥锁,请求的Key如果不存在,则加锁,去数据库取,新请求过来,如果相同KEy,则暂停10s再去缓存取值;如果Key不同,则直接去缓存取!

===============================================================================

7.redis的两种持久化策略  RDB和AOF 【深入一下,重启以后的备份恢复】

https://www.cnblogs.com/mengchunchen/p/10057485.html

===============================================================================

8.AOF的瘦身重写机制【实际应用才会碰到】

===============================================================================

9.Redis过期策略

===============================================================================

10.redis调用了flushdb 或者flushAll,之后,重启后数据还存在么

===============================================================================

11.redis中的lua脚本【涨姿势】

===============================================================================

===============================================================================

【面试 redis】【第十二篇】redis的相关面试问题的更多相关文章

  1. redis(十二):Redis 集合(Set)

    Redis 集合(Set) Redis 的 Set 是 String 类型的无序集合.集合成员是唯一的,这就意味着集合中不能出现重复的数据. Redis 中集合是通过哈希表实现的,所以添加,删除,查找 ...

  2. 【面试 SQL】【第十六篇】SQL相关面试

    =================================================================================== 1.一张表,姓名,科目,成绩,一 ...

  3. Python开发【第二十二篇】:Web框架之Django【进阶】

    Python开发[第二十二篇]:Web框架之Django[进阶]   猛击这里:http://www.cnblogs.com/wupeiqi/articles/5246483.html 博客园 首页 ...

  4. 解剖SQLSERVER 第十二篇 OrcaMDF 行压缩支持(译)

    解剖SQLSERVER 第十二篇   OrcaMDF 行压缩支持(译) http://improve.dk/orcamdf-row-compression-support/ 在这两个月的断断续续的开发 ...

  5. 第十二篇 SQL Server代理多服务器管理

    本篇文章是SQL Server代理系列的第十二篇,详细内容请参考原文 在这一系列的上一篇,我们查看了维护计划,一个维护计划可能会创建多个作业,多个计划.你还简单地看了SSIS子系统,并查看了维护计划作 ...

  6. 第十二篇 Integration Services:高级日志记录

    本篇文章是Integration Services系列的第十二篇,详细内容请参考原文. 简介在前一篇文章我们配置了SSIS内置日志记录,演示了简单和高级日志配置,保存并查看日志配置,生成自定义日志消息 ...

  7. Python之路【第十二篇】:JavaScrpt -暂无内容-待更新

    Python之路[第十二篇]:JavaScrpt -暂无内容-待更新

  8. 【译】第十二篇 Integration Services:高级日志记录

    本篇文章是Integration Services系列的第十二篇,详细内容请参考原文. 简介在前一篇文章我们配置了SSIS内置日志记录,演示了简单和高级日志配置,保存并查看日志配置,生成自定义日志消息 ...

  9. 【译】第十二篇 SQL Server代理多服务器管理

    本篇文章是SQL Server代理系列的第十二篇,详细内容请参考原文 在这一系列的上一篇,我们查看了维护计划,一个维护计划可能会创建多个作业,多个计划.你还简单地看了SSIS子系统,并查看了维护计划作 ...

  10. 跟我学SpringCloud | 第十二篇:Spring Cloud Gateway初探

    SpringCloud系列教程 | 第十二篇:Spring Cloud Gateway初探 Springboot: 2.1.6.RELEASE SpringCloud: Greenwich.SR1 如 ...

随机推荐

  1. 《java程序设计》结对编程-四则运算整体总结

    需求分析(描述自己对需求的理解,以及后续扩展的可能性) 实现一个命令行程序,要求: 自动生成小学四则运算题目(加,减,乘,除) 支持整数 支持多运算符(比如生成包含100个运算符的题目) 支持真分数 ...

  2. Myeclipse10.7安装git插件并将Java项目上传到码云(github)

    注:本文来源:外匹夫的<Myeclipse10.7安装git插件并将Java项目上传到码云(github)> 一.先说说安装egit插件的步骤(安装egit不成功的原因主要是下载的egit ...

  3. LeetCode(29): 两数相除

    Medium! 题目描述: 给定两个整数,被除数 dividend 和除数 divisor.将两数相除,要求不使用乘法.除法和 mod 运算符. 返回被除数 dividend 除以除数 divisor ...

  4. jquery----数据增删改

    简单版本 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...

  5. NOI 2012 随机数生成器

    看到全是矩阵的题解,我来一发递推+分治 其实这题一半和poj1845很像(或是1875?一个叫Sumdiv的题) 言归正传,我们看看怎么由f(0)推出f(n) 我们发现,题目中给出了f(n)=af(n ...

  6. [转] web无插件播放RTSP摄像机方案,拒绝插件,拥抱H5!

    需求 问题:有没有flash播放RTSP的播放器?H5能不能支持RTSP播放? 答案:没见过,以后估计也不会有: 问题:可以自己做浏览器插件播放RTSP吗? 答案:可以的,chrome做ppapi插件 ...

  7. JdbcType类型和Java类型的对应关系

    在Oracle中有些字段不是必填时在用户使用的时候会出现数据null的情况.这个时候在Oracle中是无法进行插入的. JDBC Type Java Type CHAR String VARCHAR ...

  8. 6-1 平衡的括号 uva673

    简单栈题 #include<bits/stdc++.h> using namespace std; int main() { int cas;cin>>cas;getchar( ...

  9. 【Java】 剑指offer(55-1) 二叉树的深度

      本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 输入一棵二叉树的根结点,求该树的深度.从根结点到叶结点依次经过 ...

  10. 二分搜索-poj2785

    题目链接:http://poj.org/problem?id=2785 题目大意:要求输入A,B,C,D四个数组,从每个数组中分别取出一个数来相加,求出相加后 和为0 总共有多少种加法. #inclu ...