常见相关问题

Redis 有哪些功能?数据缓存功能

分布式锁的功能

支持数据持久化

支持事务

支持消息队列

Redis 为什么是单线程的?

因为 cpu 不是 Redis 的瓶颈,Redis 的瓶颈最有可能是机器内存或者网络带宽。既然单线程容易实现,而且 cpu 又不会成为瓶颈,那就顺理成章地采用单线程的方案了。 关于 Redis 的性能,官方网站也有,普通笔记本轻松处理每秒几十万的请求。 而且单线程并不代表就慢 nginx 和 nodejs 也都是高性能单线程的代表。

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

Redis 支持的数据类型:string(字符串)、list(列表)、hash(字典)、set(集合)、zset(有序集合)。

Redis 支持的 Java 客户端都有哪些?

支持的 Java 客户端有 Redisson、jedis、lettuce 等。

jedis 和 Redisson 有哪些区别?

jedis:提供了比较全面的 Redis 命令的支持。 Redisson:实现了分布式和可扩展的 Java 数据结构,与 jedis 相比 Redisson 的功能相对简单,不支持排序、事务、管道、分区等 Redis 特性。

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

合理设置缓存的过期时间。 新增、更改、删除数据库操作时同步更新 Redis,可以使用事物机制来保证数据的一致性。

Redis 持久化有几种方式?

Redis 的持久化有两种方式,或者说有两种策略: RDB(Redis Database):指定的时间间隔能对你的数据进行快照存储。 AOF(Append Only File):每一个收到的写命令都通过write函数追加到文件中。

缓存穿透、缓存击穿、缓存雪崩解决方案?缓存穿透:指查询一个一定不存在的数据,如果从存储层查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到DB去查询,可能导致DB挂掉。 解决方案:1.查询返回的数据为空,仍把这个空结果进行缓存,但过期时间会比较短;

2.布隆过滤器:将所有可能存在的数据哈希到一个足够大的bitmap中,一个一定不存在的数据会被这个bitmap拦截掉,从而避免了对DB的查询。

缓存击穿:对于设置了过期时间的key,缓存在某个时间点过期的时候,恰好这时间点对这个Key有大量的并发请求过来,这些请求发现缓存过期一般都会从后端DB加载数据并回设到缓存,这个时候大并发的请求可能会瞬间把DB压垮。 解决方案:1.使用互斥锁:当缓存失效时,不立即去load db,先使用如Redis的setnx去设置一个互斥锁,当操作成功返回时再进行load db的操作并回设缓存,否则重试get缓存的方法。

2.永远不过期:物理不过期,但逻辑过期(后台异步线程去刷新)。

缓存雪崩:设置缓存时采用了相同的过期时间,导致缓存在某一时刻同时失效,请求全部转发到DB,DB瞬时压力过重雪崩。与缓存击穿的区别:雪崩是很多key,击穿是某一个key缓存。 解决方案:将缓存失效时间分散开,比如可以在原有的失效时间基础上增加一个随机值,比如1-5分钟随机,这样每一个缓存的过期时间的重复率就会降低,就很难引发集体失效的事件。

加互斥锁或者使用队列,只允许一个线程去查询数据库

缓存定时预先更新,避免同时失效

加随机值,使key在不同时间失效

缓存永不过期

Java中的Redis的思维导图_Redis思维导图相关推荐

  1. c#获取对象的唯一标识_在 Java 中利用 redis 实现分布式全局唯一标识服务

    作者: 杨高超 juejin.im/post/5a4984265188252b145b643e 获取全局唯一标识的方法介绍 在一个IT系统中,获取一个对象的唯一标识符是一个普遍的需求.在以前的单体应用 ...

  2. 在java中使用redis

    在java中使用redis很简单,只需要添加jedist.jar,通过它的api就可以了.而且,api和redis的语法几乎完全相同.以下简单的测试: 参考:http://www.runoob.com ...

  3. 在 Java 中利用 redis 实现 LBS 服务

    前言 LBS(基于位置的服务) 服务是现在移动互联网中比较常用的功能.例如外卖服务中常用的我附近的店铺的功能,通常是以用户当前的位置坐标为基础,查询一定距离范围类的店铺,按照距离远近进行倒序排序. 自 ...

  4. java 结合redis队列_在 Java 中使用 redis 的消息队列服务

    前言 关于 redis 我们前面已经讨论过了缓存.分布式锁.分布式唯一标识.LBS服务的用法,这里我们来谈谈利用 redis 来实现一个消息服务. 典型的消息服务是一个生产者和消费者模式的服务.一般是 ...

  5. java lbs_在 Java 中利用 redis 实现 LBS 服务

    前言 LBS(基于位置的服务) 服务是现在移动互联网中比较常用的功能.例如外卖服务中常用的我附近的店铺的功能,通常是以用户当前的位置坐标为基础,查询一定距离范围类的店铺,按照距离远近进行倒序排序. 自 ...

  6. Java中函数及递归的使用(附思维导图)——java面试知识点

    引言 我相信能点到这里来的童鞋们对计算机编程中的函数肯定已经有或多或少的认知,首先我们需要知道的是:计算机编程语言中的"函数"和它隔壁领域--数学中的同名同姓的亲戚"函数 ...

  7. Redis笔记(六):Java中使用Redis

    Java程序使用Redis 添加依赖包 Maven依赖方式 <dependency><groupId>redis.clients</groupId><arti ...

  8. Java中使用Redis Hash的3种方法

    前言:    不用说Map是Java中最流行的数结构.Redis提供了一个与Java的Map结构非常相似的数据结构,它吸引了许多Java开发者的兴趣.已经有越来越多的Java库与Redis进行对话,其 ...

  9. java 调用 spring,java中使用redis和spring中调用redis

    1.需要的jar包,配置的pom.xml文件 redis.clients jedis 2.7.2 2.java调用 /** * @文件名称: JedisTest.java * @描述: TODO * ...

最新文章

  1. 初步了解Linux proc文件系统
  2. sql server日期时间函数
  3. 路由选项卡_M32全面培训第四讲——路由配置
  4. android studio编译时提示error please select android sdk
  5. Linux下samba服务的错误处理
  6. 【华为云技术分享】鲲鹏开发套件:让应用软件迁移调优So Easy
  7. python实现刷博器(适用于新浪、搜狐)
  8. 使用Node.JS,如何将JSON文件读入(服务器)内存?
  9. ApiCloud数据Url请求
  10. Axure第11享:Axure汉化方法?
  11. 爱立信面试前的GitHub项目如何上传
  12. UC浏览器去广告、联网、升级(支持新版8.1)
  13. 从RTS游戏看游戏开发
  14. 莱昂哈德·欧拉生平及其成就简介
  15. 过去式和现在完成时区别
  16. Linux设备模型分析之bus(基于3.10.1内核)
  17. layui使用表格数据,json嵌套数据解决
  18. 详解动态规划01背包问题--JavaScript实现
  19. MT-InSAR原理和发展_刘计洪
  20. python无人驾驶_无人驾驶技术入门(四):无人车传感器 IMU 深入剖析

热门文章

  1. php vue联动查询,使用vue.js实现联动效果的示例代码
  2. java 拉丁文 unicode_“java语言使用的是Unicode编码”是指的jvm?.java文件?
  3. 非负矩阵之Perron-Frobenius定理
  4. spss非线性回归分析步骤_SPSS与简单线性回归分析
  5. php网站标签加小图标,在htmltitle/title标签添加图标,网页title左边显示网页的logo图标...
  6. 二次优化大招(由泰勒公式推出最值条件)
  7. 程序员应该多逛的几个技术网站
  8. JavaScript | JSON基本格式
  9. FreeRTOS--API函数
  10. 机电传动控制大作业 第一阶段