1.如果在setnx之后执行expire之前进程意外crash或者要重启维护了,那会怎么样?

  1. set指令有非常复杂的参数,这个应该是可以同时setnx和expire合成一条指令来用的!

2.使用过Redis分布式锁吗?它是如何实现的?

  1. 先拿setnx来争抢锁,抢到之后,再用expire给锁加一个过期时间防止锁忘记了释放。

3.使用过Redis做异步队列吗?是怎么用的,有什么缺点?

  1. 一般会用list结构作为消息队列,rpush生产消息,lpop消费消息。当lpop没有消息的时候,要适当sleep一会再重试。在消费者下线的情况下,生产的消息会丢失,得使用专业的消息队列如RabbitMQ等。

4.能不能生产一次消费多次?

  1. 使用pub/sub主题订阅者模式,可以实现1:N的消息队列。

5.什么是缓存穿透?如何避免?什么是缓存雪崩?如何避免?

  缓存穿透:

    一般的缓存系统,都是按照key去缓存查询,如果不存在对应的value,就应该去后端系统查找(比如:DB)。一些恶意的请求会故意查询不存在的key,请求量很大,就会对后端系统造成很大的压力。叫做恶意穿透。

  如何避免:

  1. 对查询为空的结果可以进行缓存,缓存时间设置短一些,或者该key对应的数据insert了之后清理缓存。
  2. 对一定不存在的key进行过滤。可以把所有的可能存在的key放到一个大的Bitmap中,查询时通过该bitmap过滤。

  缓存雪崩:

    当缓存服务器重启或者大量缓存集中在某一个时间段失效,这样在失效的时候,会给后端系统造成很大的压力,导致系统奔溃。

  如何避免?

  1. 在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。比如对某个key只允许一个线程读数据和写缓存,其他线程等待。
  2. 做二级缓存,A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,A1缓存失效时间设置为短期,A2设置为长期。
  3. 不同的key,设置不同的过期时间,让缓存的失效时间尽量均匀。

6.什么是Redis持久化,Redis持久化的方式有几种?优缺点是什么?

  1. 持久化就是把内存的数据放到磁盘中去,防止服务器宕机导致内存数据丢失。
  2. Redis提供了2中持久化方式:RDB(默认)和AOF

    RDB:把缓存中数据保存到磁盘中。

    AOF写入保存:

    WRITE:根据条件,将aof_buf中的缓存写入到AOF文件中

    SAVE:根据条件,调用 fsync 或者 fdatasync 函数,将AOF文件保存到磁盘中。

    比较:

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

7.Redis 有哪些架构模式?讲讲各自的特点

  1. 客户端到服务端直接缓存,特点:简单,问题:1、内存容量有限,2、处理能力有限,3、无法高可用
  2. 从主服务器复制到从服务器,比较复杂一点:

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


8.Redis的数据类型有哪些?

  1. Set、List、String、Sorted Set、Hashes

9.Redis主要消耗什么物理资源

  1. 内存

10.Redis官方为什么不提供Windows版本?

  1. 因为目前Linux版本已经相当稳定,而且用户量也很大,无需开发windows版本,反而会带来版本兼容性等问题。

11.一个字符串类型的值能存储最大容量是多少?

  1. 512M

12.怎么理解Redis事务?

  1. 事务是一个单独的隔离操作:事务中所有命令都会序列化,按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
  2. 事务是一个原子操作:事务中的命令要么全部执行,要么全部都不执行。

【面试】Redis的更多相关文章

  1. 【面试 redis】【第十二篇】redis的相关面试问题

    redis的相关面试问题 redis教程:http://www.redis.net.cn/tutorial/3501.html ==================================== ...

  2. 突破Java面试-Redis集群模式的原理

    1 面试题 Redis集群模式的工作原理说一下?在集群模式下,key是如何寻址的?寻址都有哪些算法?了解一致性hash吗? 2 考点分析 Redis不断在发展-Redis cluster集群模式,可以 ...

  3. 搞定redis面试--Redis的过期策略?手写一个LRU?

    1 面试题 Redis的过期策略都有哪些?内存淘汰机制都有哪些?手写一下LRU代码实现? 2 考点分析 1)我往redis里写的数据怎么没了? 我们生产环境的redis怎么经常会丢掉一些数据?写进去了 ...

  4. 2020PHP面试-Redis篇

    一.Redis 数据类型 1. string 字符型. 2.hash hash  结构化的对象.  key不可重复 3.list 队列  lpush rpop  lpop rpush 4. set 集 ...

  5. 害...原来阿里面试Redis最常问的是它呀

    一提到Redis缓存,我们不得不了解的三个问题就是:缓存雪崩.缓存击穿和缓存穿透.这三个问题一旦发生,会导致大量的请求直接请求到数据库层.如果并发压力大,就会导致数据库崩溃.那p0级的故障是没跑了. ...

  6. 阿里面试Redis常考问题

    一提到Redis缓存,我们不得不了解的三个问题就是:缓存雪崩.缓存击穿和缓存穿透.这三个问题一旦发生,会导致大量的请求直接请求到数据库层.如果并发压力大,就会导致数据库崩溃.那p0级的故障是没跑了. ...

  7. LinkedHashMap源码解读

    1. 前言 还是从面试中来,到面试中去.面试官在面试 Redis 的时候经常会问到,Redis 的 LRU 是如何实现的?如果让你实现 LRU 算法,你会怎么实现呢?除了用现有的结构 LinkedHa ...

  8. Redis的那些最常见面试问题

    随笔:经过长达一周的奔波和面试,电话面试,回首今天终于成功的入职了,总共面试了大概10家公司,包括阿里,京东,IBM等等,京东技术过了,学历因为非统招就被pass了,阿里面了2次电话面试就没下文了,估 ...

  9. Redis和MongoDB的区别(面试受用)

    项目中用的是MongoDB,但是为什么用其实当时选型的时候也没有太多考虑,只是认为数据量比较大,所以采用MongoDB. 最近又想起为什么用MongoDB,就查阅一下,汇总汇总: 之前也用过redis ...

  10. 【原创】那些年用过的Redis集群架构(含面试解析)

    引言 今天是2019年2月12号,也就是大年初八,我接到了高中同学刘有码面试失利的消息. 他面试的时候,身份是某知名公司的小码农一枚,却因为不懂自己生产上Redis是如何部署的,导致面试失败! 人间惨 ...

随机推荐

  1. Python活力练习Day7

    Day7:写出一个程序,接受一个由字母和数字组成的字符串和一个字符,输出输入字符串中含有该字符的个数,不区分大小写 eg:input : a = '123ASVFBVESS'  b = 's' out ...

  2. vue页面中图片不显示解决

    在做新版组态界面的时候,用vue框架实现,在配置页面图片的时候发现有一张图片明明页面输入的路径是对的可是图片就是不显示出来 现象: network页面资源也不报错,而且状态码竟然还是200,点prev ...

  3. Vue中的key到底有什么用?

    key是为Vue中的vnode标记的唯一id,通过这个key,我们的diff操作可以更准确.更快速 diff算法的过程中,先会进行新旧节点的首尾交叉对比,当无法匹配的时候会用新节点的key与旧节点进行 ...

  4. Delphi10.2.3利用THttpClient实现http异步下载

    随着Delphi 10.2.3的发布,随之带来更稳定.更完善的版本.今天借官方的例子,解读一下如何实现Http异步下载并显示下载进度. 使用的核心组件是THttpClient,首先建立一个THttpC ...

  5. STM32输出比较模式

    搜索好久,各种文章良莠不齐,转载以下几篇 http://www.eeworld.com.cn/mcu/article_2016101130334.html(输出比较冻结模式) http://www.e ...

  6. 【转】关于 Error[Pe020]: identifier "HAL_StatusTypeDef" is undefined

    @2019-06-06 [小记] 这个bug比较常见,右键可以定位到相关头文件,但系统依旧报错,其实主要还是头文件的问题. 1.需要检查头文件中关于主程序所用到的部分是否已经使能,尤其是 “stm32 ...

  7. DA_06_高级文本处理命令

    Linux中没有盘符这个概念,只有一个根目录“/”,所有文件都在它下面:点击计算机,下面存放的都是根目录下的东西: 2.6 文本文件编辑命令 1.cat 命令用于查看纯文本文件(内容较少的:一次性全部 ...

  8. php将数组中某个元素置顶设为第一个元素

    一个数组$a0有N个元素,要将其中第3个元素,排在数组的首位. 第一种做法是: 取出第3个元素,赋值给变量$a unset 第3个元素 array_unshift 将$a添加到数组头部. 如果是数字下 ...

  9. java合并数组的几种方法,stream流合并数组

    一.实例代码 package cc.ash; import org.apache.commons.lang3.ArrayUtils; import java.lang.reflect.Array; i ...

  10. CSS基础学习-6.CSS属性_列表、表格