在用官方语言进行解释这个东西之前,我先说说我对缓存的理解,缓存就是当我们在进行与数据库多次交互的时候,为了方便我们的使用,将我们在数据库里面查询到的东西存放在一个地方,当我们,再次进行使用的时候可以减少我们对于数据库的操作,提高效率,
一、JSR107
这里有一张图示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yrtlZwhC-1581770692107)(http://39.102.36.205:8090/upload/2020/2/image-b3a517e510a54c098743b4a12c90ec89.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FQBLgSkR-1581770692110)(http://39.102.36.205:8090/upload/2020/2/image-9381229182494d0ea1b77e4d8bc947b6.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zU5AXHyV-1581770692111)(http://39.102.36.205:8090/upload/2020/2/image-ff11732d786e41ed9ed667b0e9fce73d.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yblLafew-1581770692112)(http://39.102.36.205:8090/upload/2020/2/image-a56ea0f690f24f108224571bb96c87f1.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DA9dUNa1-1581770692112)(http://39.102.36.205:8090/upload/2020/2/image-b41c7eb6071946bbb9e036f3336e0304.png)]
1、引入spring-boot-starter-cache模块
2、@EnableCaching开启缓存
3、使用缓存注解
4、切换为其他缓存
**
* 一、搭建基本环境
* 1、导入数据库文件 创建出department和employee表
* 2、创建javaBean封装数据
* 3、整合MyBatis操作数据库
* 1.配置数据源信息
* 2.使用注解版的MyBatis;
* 1)、@MapperScan指定需要扫描的mapper接口所在的包
* 二、快速体验缓存
* 步骤:
* 1、开启基于注解的缓存 @EnableCaching
* 2、标注缓存注解即可
* @Cacheable
* @CacheEvict
* @CachePut
* 默认使用的是ConcurrentMapCacheManager==ConcurrentMapCache;将数据保存在 ConcurrentMap<Object, Object>中
* 开发中使用缓存中间件;redis、memcached、ehcache;
* 三、整合redis作为缓存
* Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。
* 1、安装redis:使用docker;
* 2、引入redis的starter
* 3、配置redis
* 4、测试缓存
* 原理:CacheManager===Cache 缓存组件来实际给缓存中存取数据
* 1)、引入redis的starter,容器中保存的是 RedisCacheManager;
* 2)、RedisCacheManager 帮我们创建 RedisCache 来作为缓存组件;RedisCache通过操作redis缓存数据的
* 3)、默认保存数据 k-v 都是Object;利用序列化保存;如何保存为json
* 1、引入了redis的starter,cacheManager变为 RedisCacheManager;
* 2、默认创建的 RedisCacheManager 操作redis的时候使用的是 RedisTemplate<Object, Object>
* 3、RedisTemplate<Object, Object> 是 默认使用jdk的序列化机制
* 4)、自定义CacheManager;
*
*/
spring.redis.host=118.24.44.169
/**
* Redis常见的五大数据类型
* String(字符串)、List(列表)、Set(集合)、Hash(散列)、ZSet(有序集合)
* stringRedisTemplate.opsForValue()[String(字符串)]
* stringRedisTemplate.opsForList()[List(列表)]
* stringRedisTemplate.opsForSet()[Set(集合)]
* stringRedisTemplate.opsForHash()[Hash(散列)]
* stringRedisTemplate.opsForZSet()[ZSet(有序集合)]
*/
//序列化器的作用将对象保存在redis中的时候通过json字符串的形式进行展示。
//操作员工的
@Bean
public RedisTemplate<Object, Employee> empRedisTemplate(
RedisConnectionFactory redisConnectionFactory)
throws UnknownHostException {
RedisTemplate<Object, Employee> template = new RedisTemplate<Object, Employee>();
//序列化器
template.setConnectionFactory(redisConnectionFactory);
Jackson2JsonRedisSerializer<Employee> ser = new Jackson2JsonRedisSerializer<Employee>(Employee.class);
template.setDefaultSerializer(ser);
return template;
}
//CacheManagerCustomizers可以来定制缓存的一些规则
//自定义员工的缓存模拟器,将上个方法当成参数放进里面,进行自动注入
@Primary //将某个缓存管理器作为默认的
@Bean
public RedisCacheManager employeeCacheManager(RedisTemplate<Object, Employee> empRedisTemplate){
RedisCacheManager cacheManager = new RedisCacheManager(empRedisTemplate);
//key多了一个前缀
//使用前缀,默认会将CacheName作为key的前缀
cacheManager.setUsePrefix(true);
return cacheManager;
}
顺便说一下我的个人博客地址:
原文:https://www.cnblogs.com/cainiaoxiaoxie/p/12313821.html