目录:

  • 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. Nginx(二)--nginx的核心功能

    反向代理 nginx反向代理的指令不需要新增额外的模块,默认自带proxy_pass指令,只需要修改配置文件就可以实现反向代理. proxy_pass 既可以是ip地址,也可以是域名,同时还可以指定端 ...

  2. 35个Java代码优化的细节,你知道几个?

    前言 代码 优化 ,一个很重要的课题.可能有些人觉得没用,一些细小的地方有什么好修改的,改与不改对于代码的运行效率有什么影响呢?这个问题我是这么考虑的,就像大海里面的鲸鱼一样,它吃一条小虾米有用吗?没 ...

  3. Nginx 常用配置方式说明

    原文内容来自于LZ(楼主)的印象笔记,如出现排版异常或图片丢失等问题,可查看当前链接:https://app.yinxiang.com/shard/s17/nl/19391737/7619763f-1 ...

  4. 云服务器配置 docker java mysql mongodb redis nginx 环境

    磁盘挂载 fdisk -l #查看磁盘列表 mkfs.ext4 /dev/vdb #格式化磁盘 mount /dev/vdb /data #挂载磁盘在/data echo '/dev/vdb /dat ...

  5. JVM CPU Profiler技术原理及源码深度解析

    研发人员在遇到线上报警或需要优化系统性能时,常常需要分析程序运行行为和性能瓶颈.Profiling技术是一种在应用运行时收集程序相关信息的动态分析手段,常用的JVM Profiler可以从多个方面对程 ...

  6. 手写SpringMVC

    环境描述 idea java 8 1. POM文件 <?xml version="1.0" encoding="UTF-8"?> <proje ...

  7. Support URL

    如您有任何疑问或者建议,请通过以下方式与我们取得联系,我们会尽快响应您的反馈: 邮箱:eighteyes_cn@163.com

  8. layui2.5 开关在confirm确认了之后在关/开

    <!--默认选中--> <div class="layui-form-item layui-form"> <div class="layui ...

  9. python基础之字符串讲解(下)

    7.swapspace 这个命令是让大小写翻转 s = 'qwerQ' s3 = s.swapcase() print(s3) 8.title 每个隔开(特殊字符或者数字)的单词首字母大写 s = ' ...

  10. 二分查找(Java)

    题目: 编写程序,完成以下功能: (1)输入5个整数到数组中; (2)使用冒泡法对5个数按从小到大排序,输出排序后的数组; (3)输入一个整数X,在数组中用二分法查找X,找到输出X在数组中的下标,找不 ...