Redis 分布式缓存实现(一)

1. 什么是缓存(Cache)

  定义:就是计算机内存中的一段数据;

2. 内存中数据特点

  a. 读写快    b. 断电立即丢失

3. 缓存解决了什么问题?

  a. 提高网站吞吐量,提高网站运行效率;

  b. 核心解决问题:缓存的存在是用来减轻数据库访问压力;

4. 既然缓存能提高效率,那项目中所有数据加入缓存岂不是更好?

  注意:使用缓存时一定是数据库中数据极少发生修改,更多用于查询这种情况 例如:省份  城市  县  村

5. 本地缓存和分布式缓存的区别

  本地缓存:存储在当前应用服务器内存中的数据称之为本地缓存(local cache)

  分布式缓存:存储在当前应用服务器内存之外的数据称之为分布式缓存(distribute cache)

  集群:将同一种服务的多个节点放在一起,共同对系统提供服务的过程称之为集群(cluster)

  分布式:有多个不同服务集群共同对系统提供服务的这个系统称之为分布式系统(distribute system)

6. 利用 MyBatis 自身本地缓存结合 Redis 实现分布式缓存

  a. MyBatis 中应用级缓存(二级缓存)SqlSessionFactory 级别缓存,所有会话共享同一个 namespace

  b. 如何开启(二级缓存)

    在对应模块的Mapper.xml文件中开启二级缓存,例如:UserMapper.xml

    <cache/>  ---- 本地缓存 

  c. 查看 Cache 标签缓存实现

    结论:MyBatis底层默认使用的是:org.apache.ibatis.cache.impl.PerpetualCache 实现【底层就是一个 Map 数据结构存储】

  d. 自定义 RedisCache 实现,替换默认的 PerpetualCache

    (1)通过 MyBatis 默认 Cache 源码得知,可以只用自定义 Cache 接口的实现类 implements Cache 接口,并对里面的方法进行实现

      public class RedisCache implements Cache { }

    (2)在指定 Mapper 对应的 namespace 中开启二级缓存

      <cache type="com.study.cache.RedisCache"/>

Redis 分布式缓存实现(二)

1. 缓存在项目中应用

  a. 如果项目中表查询之间没有任何关联查询时,使用现在的这种缓存方式没有任何问题,比如:只是使用单表查询;

  b. 现有缓存方式在表连接查询过程中一定存在问题;比如:Depart 部门中有 多个 User 用户,Depart { List<User> users; }

2. 在 MyBatis 的缓存中如何要解决关联关系时更新缓存信息的问题【可参考文档:MyBatis 一级缓存和二级缓存     MyBatis 缓存 Cache

  <cache-ref  /> 用来将多个有关联关系查询缓存放在一起处理;

  在 UserMapper.xml 文件中加入以下内容:

  <cache-ref namespace="com.study.mapper.DepartMapper"/>

(1)关联关系缓存处理【用来将两个关联关系查询的结果缓存放在一起处理】
(2)存在关联关系的多个模块中,只要有一个模块更新,就应该把有关联的模块缓存都清空,否则会出现脏数据情况;
(3)此时不能使用<cache type=""/> 【只适合单模块的缓存】 要使用 <cache-ref namespace=""> 标签; <cache-ref namespace=""/> 当前模块的缓存去引用其他模块的缓存【用户模块的查询缓存放入部门模块的查询缓存中】
由于用户和部门关联,共享缓存,首先两模块的查询缓存放在一起 DepartMapper 下,无论用户或者部门做增删改,都会将 departMapper 下的缓存清空,进而关联的用户缓存也一并清空;

Redis 分布式缓存实现(三)

1. 缓存优化策略

  a. 对放入 Redis 中 Key 进行优化:Key 的长度不能太长;

  b. 尽可能将 Key 设计简洁一些:

    算法:MD5处理 加密

    特点:(1)一切文件字符字符串等经过MD5加密处理后,都会生成32位16进制字符串;(2)不同内容文件经过MD5进行加密,加密结果一定不一致;

         (3)相同内容文件多次经过MD5加密生成的结果始终一致;

  推荐:在 Redis 整合 SpringBoot 过程中建议将 Key 进行 MD5 加密优化处理;

2. 面试相关概念

  a. 什么是缓存穿透 击穿

    定义:客户端查询了一个数据库中没有的数据记录,导致缓存在这种情况下无法使用,称之为缓存穿透  缓存击穿

      MyBatis 中 Cache 解决了缓存穿透问题:将数据库中没有查询到的结果也进行缓存

  b. 什么是缓存雪崩

    定义:在系统运行的某一时刻,突然系统中缓存全部失效,恰好在这一时刻涌来大量客户的请求,导致所有模块缓存无法使用,大量请求涌向数据库导致极端情况,数据库阻塞获取挂起;

      缓存存储时:业务系统非常大,模块多,业务数据不同,不同模块在放入缓存时,都会设置一个缓存超时时间;

    解决方案:1. 缓存永久存储(不推荐) 2. 针对于不同业务数据一定要设置不同超时时间,避免同一时刻 或者 一极短时间内大量缓存失效。

目前只展示相关概念,代码实现没有展示出来,有问题大家一块讨论哈!

Redis实现分布式缓存的更多相关文章

  1. 在AspNetCore 中 使用Redis实现分布式缓存

    AspNetCore 使用Redis实现分布式缓存 上一篇讲到了,Core的内置缓存:IMemoryCache,以及缓存的基础概念.本篇会进行一些概念上的补充. 本篇我们记录的内容是怎么在Core中使 ...

  2. 【转载】在AspNetCore 中 使用Redis实现分布式缓存

    原文地址:https://www.cnblogs.com/szlblog/p/9045209.html AspNetCore 使用Redis实现分布式缓存 上一篇讲到了,Core的内置缓存:IMemo ...

  3. ASP.NET Core 使用 Redis 实现分布式缓存:Docker、IDistributedCache、StackExchangeRedis

    ASP.NET Core 使用 Redis 实现分布式缓存:Docker.IDistributedCache.StackExchangeRedis 前提:一台 Linux 服务器.已安装 Docker ...

  4. WEB 应用缓存解析以及使用 Redis 实现分布式缓存

    什么是缓存? 缓存就是数据交换的缓冲区,用于临时存储数据(使用频繁的数据).当用户请求数据时,首先在缓存中寻找,如果找到了则直接返回.如果找不到,则去数据库中查找.缓存的本质就是用空间换时间,牺牲数据 ...

  5. Redis-基本概念、java操作redis、springboot整合redis,分布式缓存,分布式session管理等

    NoSQL的引言 Redis数据库相关指令 Redis持久化相关机制 SpringBoot操作Redis Redis分布式缓存实现 Resis中主从复制架构和哨兵机制 Redis集群搭建 Redis实 ...

  6. C# Redis Server分布式缓存编程 --网络转载

    这篇文章我将介绍如果用最简洁的方式配置Redis Server, 以及如何使用C#和它交互编程 一. 背景介绍 Redis是最快的key-value分布式缓存之一 缺点: 没有本地数据缓冲, 目前还没 ...

  7. redis+keeplived分布式缓存

    redis(三)redis+Keepalived主从热备秒级切换 博客分类: 分布式缓存Redis redis高可用Keepalived  一 简介 安装使用centos 5.10 Master 19 ...

  8. springboot+mybatis+redis实现分布式缓存

    大家都知道springboot项目都是微服务部署,A服务和B服务分开部署,那么它们如何更新或者获取共有模块的缓存数据,或者给A服务做分布式集群负载,如何确保A服务的所有集群都能同步公共模块的缓存数据, ...

  9. ASP.NET结合Redis实现分布式缓存

    最近一个项目ASP.NET+MySQL 有的网页打开初始化的查询需要10秒甚至更久,用户体验极差,而且并发量变大的时候网站容易崩溃 后来想了两种解决方案都不是太满意 1.数据库里建一张缓存表,后台作业 ...

随机推荐

  1. go 继承

    package main import "fmt" type Animal struct { Color string } // 继承动物结构体 type Dog struct { ...

  2. PHP转Go系列:数组与切片 转

    数组的定义# 用过PHP的同学应该很清楚,无论多么复杂的数据格式都可以用数组来表达,什么类型的数据都可以往里塞,它是工作必备的一部分,使用很简单,易用程度简直变态. Copy $array = [1, ...

  3. 【API管理 APIM】APIM集成内部VNet时,常遇见的关于自定义DNS服务问题。

    问题描述 Azure 的APIM集成虚拟网络有两种方式,外部VNET, 内部VNET. 外部VNET,要求低,可以通过APIM访问VNET中的VM等资源,不需要配置自定义DNS服务器,这种方式下,AP ...

  4. 56.Qt-滚动字幕之无间隙滚动(原创)

    1.描述 最近要实现一个滚动条字幕,但是搜到的系列文章都是利用定时器QTimer,在固定的时间截取文本并显示,这样滚动的时候其实是断断续续的,因为实际上是一个个字符位移实现的,不过实现方便. 所以只有 ...

  5. 【Azure Developer】使用.Net Core解析JSON的笔记

    在C#中解析JSON的一些历史代码记录,分别记录针对各种情况的解析方式. DLL的引用 using Newtonsoft.Json; using Newtonsoft.Json.Linq; 需要使用的 ...

  6. docker容器学习资料

    现在说起docker容器,你应该不会太陌生了吧?如果你是真的不懂或者是太久没有用到已经忘记的差不多了,那么你需要这一波的干货了,这波的干货刚刚好可以满足你的需要! 话不多说,直接上干货

  7. pyqt5为控件设置提示信息

    # 显示控件提示消息 import sys from PyQt5.QtWidgets import QHBoxLayout,QMainWindow,QApplication,QToolTip,QPus ...

  8. Java网关服务-AIO(三)

    Java网关服务-AIO(三) 概述 前两节中,我们已经获取了body的总长度,剩下的就是读出body,处理请求 ChannelServerHandler ChannelServerHandler即从 ...

  9. axb_2019_heap-format_string + off-by-one

    axb_2019_heap 简单题,格式化字符串泄漏栈地址 算上rsp,格式化字符串参数是栈顺序+6-1 edit有off by one 构造unlink chunk0 chunk1 chunk2 构 ...

  10. c语言之指针特性

    0x01.指针的声明 char x; char* x; short y; short* y; int z; int* z; float f; float* f; double d; double* d ...