目录:

  • redis是什么?都有哪些使用场景?
  • redis有哪些功能?
  • redis和memecache有什么区别?
  • redis为什么是单线程的?
  • 什么是缓存穿透?怎么解决?
  • redis支持的数据类型有哪些?
  • redis支持的java客户端都有哪些?
  • jedis和 redisson 有哪些区别?
  • 怎么保证缓存和数据库数据的一致性?
  • redis持久化有几种方式?
  • redis怎么实现分布式锁?
  • redis分布式锁有什么缺陷?
  • redis如何做内存优化?
  • redis淘汰策略有哪些?

redis是什么?都有哪些使用场景?

1、Redis是一款开源的、基于C语言编写的key value数据库,其数据读写基于内存,性能高。

2、Redis使用场景很多:

  • 可作用于底层DB的缓存层
  • 分布式锁
  • 使用list做热点数据排行
  • GEO做地理位置统计
  • 等等。。。。。。

redis有哪些功能?

数据持久化、事务、发布订阅消息、主从复制、集群、哨兵等等。

redis和memecache有什么区别?

memecache目前仅支持k/v类型的数据存储,而redis支持的存储方式更加丰富

memecache挂掉了数据就没了,redis有持久化策略。

。。。。。。

redis为什么是单线程的?

我们首先要知道Redis是一个高效的key/value数据库,且采用内存读写数据

那么既然是内存读写数据的话单线程的效率肯定是最高的,因为多线程的本质就是CPU模拟出来多个线程的情况,这种模拟出来的线程势必会有上下文切换的消耗,所以对于内存系统来说没有上下文的切换就是最高效的

参考:https://blog.csdn.net/world6/article/details/79381682

什么是缓存穿透?怎么解决?

1、什么是缓存穿透:缓存穿透查询一个根本不存在的数据,导致每次请求都不会命中缓存,请求都进到DB,导致DB压力过大而降低DB吞吐量,严重时可能会让DB宕机;一般是自身业务代码或数据出现问题,或是一个恶意攻击、爬虫等造成的。

2、怎么解决:

  • 缓存null值,将那些不可能存在的数据也做一层缓存,如缓存值为null;这样便不会将这些数据命中到DB层了。
  • 布隆过滤器

redis支持的数据类型有哪些?

String、List、Hash、Set、Sorted Set。

可以再细说下编码以及这些数据类型的特性等等。

redis支持的java客户端都有哪些?

Jedis、Redisson、lettuce等等,官方推荐使用Redisson

jedis和redisson有哪些区别?

简介:

  • Jedis:redis的java客户端的实现,提供了比较全面的redis命令支持。
  • Redisson:实现了分布式和可扩展的Java数据结构。

区别:

  • 封装:jedis只是简单封装了redis的api库,它的方法和redis命令类似;redisson不仅封装了redis命令,还封装了更多的数据结构以及锁等功能。
  • 灵活性:jedis对于redisson来说更加灵活。

怎么保证缓存和数据库数据的一致性?

1、读数据:先读缓存,后读数据库。

2、写数据:先写数据库,后写缓存。

3、每次更新数据都要把缓存清掉。

4、缓存设置过期时间,保持与数据库的最终一致性。

参考:https://blog.csdn.net/cwb521sxm/article/details/96182882

redis持久化有几种方式?

见:https://www.cnblogs.com/bzfsdr/p/12043669.html Redis持久化

redis怎么实现分布式锁?

1、手动实现:如果key存在则返回已锁,不存在则加锁,还可以设置锁的时间,并需要及时解锁。

2、使用redisson api实现

redis分布式锁有什么缺陷?

1、可能会造成死锁

客户端A获取锁成功了,但释放锁的时候崩溃了,导致锁依然存在。我们可以通过设置过期时间来解决这一问题。

2、错误的获取锁

上面说到可以设置过期时间来预防死锁,但若客户端A执行之间过长或因为某些原因导致客户端A阻塞了,这是锁可能已经过期了,然后客户端B又拿到了锁。

此时客户端A又恢复了过来,这样便会有两个线程执行操作,导致最终的数据不一致。

参考:https://blog.csdn.net/twt936457991/article/details/90181855

redis如何做内存优化?

1、设置内存上限:maxmemory

2、可根据实际情况调整内存淘汰策略

3、压缩键值对的长度

4、尽可能的使用hash结构,减少key的数量(对ziplist编码的妙用)

redis淘汰策略有哪些?

见:https://www.cnblogs.com/bzfsdr/p/12043669.html 缓存设计第a节

菜鸟刷面试题(三、Redis篇)的更多相关文章

  1. 菜鸟刷面试题(四、Spring/Spring MVC/Spring Boot/Spring Cloud篇)

    目录: 为什么要使用 spring? 解释一下什么是 aop? 解释一下什么是 ioc? spring 有哪些主要模块? spring 常用的注入方式有哪些? spring 中的 bean 是线程安全 ...

  2. 菜鸟刷面试题(二、RabbitMQ篇)

    目录: rabbitmq 的使用场景有哪些? rabbitmq 有哪些重要的角色? rabbitmq 有哪些重要的组件? rabbitmq 中 vhost 的作用是什么? rabbitmq 的消息是怎 ...

  3. 菜鸟刷面试题(一、Java基础篇)

    目录: JDK 和 JRE 有什么区别? == 和 equals 的区别是什么? 两个对象的 hashCode()相同,则 equals()也一定为 true,对吗? final 在 java 中有什 ...

  4. 菜鸟刷面试题(五、Java容器篇)

    目录: java 容器都有哪些? Collection 和 Collections 有什么区别? List.Set.Map 之间的区别是什么? HashMap 和 Hashtable 有什么区别? 如 ...

  5. Java面试题整理---Redis篇

    1.redis支持五种数据结构类型?   2.redis内部结构?   3.redis持久化机制?   4.redis集群方案与实现?   5.redis为什么是单线程的?   6.redis常见回收 ...

  6. Java面试题(Redis篇)

    Redis 179.redis 是什么?都有哪些使用场景? Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. ...

  7. Python自动化测试面试题-Redis篇

    目录 Python自动化测试面试题-经验篇 Python自动化测试面试题-用例设计篇 Python自动化测试面试题-Linux篇 Python自动化测试面试题-MySQL篇 Python自动化测试面试 ...

  8. 《【面试突击】— Redis篇》-- Redis哨兵原理及持久化机制

    能坚持别人不能坚持的,才能拥有别人未曾拥有的.关注编程大道公众号,让我们一同坚持心中所想,一起成长!! <[面试突击]— Redis篇>-- Redis哨兵原理及持久化机制 在这个系列里, ...

  9. 《【面试突击】— Redis篇》--Redis都有哪些数据类型?分别在哪些场景下使用比较合适?

    能坚持别人不能坚持的,才能拥有别人不能拥有的.关注编程大道公众号,让我们一同坚持心中所想,一起成长!! <[面试突击]— Redis篇>--Redis都有哪些数据类型?分别在哪些场景下使用 ...

随机推荐

  1. Zabbix 监控MySQL、Apache、Nginx应用监控

    zabbix对第三方应用软件的监控,主要有两个工作难点,一个是编写自定义监控脚本,另一个是在编写模板并导入zabbix web中,编写脚本这个要根据 监控需求定制即可,而编写模板文件有些难度,不过网上 ...

  2. linux—netstat

    netstat--option -a: 列出所有端口,监听的没有监听的     -t: 显示tcp相关的选项 -u: 显示udp相关的选项 -l: 仅仅显示监听选项 -p:  显示与连接有关的程序名和 ...

  3. 基于 raft 协议的 RocketMQ DLedger 多副本日志复制设计原理

    目录 1.RocketMQ DLedger 多副本日志复制流程图 1.1 RocketMQ DLedger 日志转发(append) 请求流程图 1.2 RocketMQ DLedger 日志仲裁流程 ...

  4. hdu 6318 Swaps and Inversions (线段树求逆序对数)

    Swaps and Inversions Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth ...

  5. 1.1 Spring 概述

    1.1 Spring 概述 1.1.1 Spring 的简史 第一阶段:xml配置 Spring 1.x时代使用xml配置Bean 第二阶段:注解配置 Spring2.x  Spring 提供了声明B ...

  6. 集群环境下,你不得不注意的ASP.NET Core Data Protection 机制

    引言 最近线上环境遇到一个问题,就是ASP.NET Core Web应用在单个容器使用正常,扩展多个容器无法访问的问题.查看容器日志,发现以下异常: System.Security.Cryptogra ...

  7. HttpRunner学习6--使用parameters参数化

    前言 在使用HttpRunner测试过程中,我们可能会遇到这种场景: 账号登录功能,需要输入用户名和密码,设计测试用例后有 N 种组合情况 如果测试组合比较少,比如只有2个,那我们直接在YAML脚本中 ...

  8. 一起学MyBatis之入门篇

    概述 本文以一个简单的小例子,简述在Java项目开发中MyBatis的基本用法,属于入门级文章,仅供学习分享使用,如有不足之处,还请指正. 什么是MyBatis? MyBatis 是一款优秀的持久层框 ...

  9. linux 定时备份数据库

    说明 检查Crontab是否安装 若没有 需要先安装Crontab定时工具 安装定时工具参考(https://www.cnblogs.com/shaohuixia/p/5577738.html) 需要 ...

  10. 《Hands-On System Programming with Go》之读文件

    有点全,但不是很全. 一次读入,分批次读入,缓存读入. 要记得这几种不同读取的应用场景. package main import ( "bufio" "bytes&quo ...