zoukankan      html  css  js  c++  java
  • Spring Boot与缓存

    ---恢复内容开始---

    JSR-107、Spring缓存抽象、整合Redis

    一、JSR107 Java Caching定义了5个核心接口,分别是CachingProvider, CacheManager, Cache, Entry 和 Expiry(到期)。

    • CachingProvider定义了创建、配置、获取、管理和控制多个CacheManager。一个应用可 以在运行期访问多个CachingProvider。
    
    • CacheManager定义了创建、配置、获取、管理和控制多个唯一命名的Cache,这些Cache 存在于CacheManager的上下文中。一个CacheManager仅被一个CachingProvider所拥有。
    
    • Cache是一个类似Map的数据结构并临时存储以Key为索引的值。一个Cache仅被一个 CacheManager所拥有。
    
    • Entry是一个存储在Cache中的key-value对。
    
    • Expiry 每一个存储在Cache中的条目有一个定义的有效期。一旦超过这个时间,条目为过期 的状态。一旦过期,条目将不可访问、更新和删除。缓存有效期可以通过ExpiryPolicy设置。
    

     

               

    图(1)关系图

    二、Spring缓存抽象

    Spring从3.1开始定义了org.springframework.cache.Cache 和org.springframework.cache.CacheManager接口来统一不同的缓存技术; 并支持使用JCache(JSR-107)注解简化我们开发;

    • Cache接口为缓存的组件规范定义,包含缓存的各种操作集合;
    • Cache接口下Spring提供了各种xxxCache的实现;如RedisCache,EhCacheCache ,
    ConcurrentMapCache等;
    • 每次调用需要缓存功能的方法时,Spring会检查检查指定参数的指定的目标方法是否
    已经被调用过;如果有就直接从缓存中获取方法调用后的结果,如果没有就调用方法
    并缓存结果后返回给用户。下次调用直接从缓存中获取。
    • 使用Spring缓存抽象时我们需要关注以下两点;
    1、确定方法需要被缓存以及他们的缓存策略
    2、从缓存中读取之前缓存存储的数据
    

      

    图2

     三、几个重要概念&缓存注解

     四、缓存使用

    • 1、引入spring-boot-starter-cache模块
    • 2、@EnableCaching开启缓存
    • 3、使用缓存注解
    • 4、切换为其他缓存
    

    五、整合redis实现缓存

    1. 引入spring-boot-starter-data-redis
    2. application.yml配置redis连接地址
    3. 使用RestTemplate操作redis
    1. redisTemplate.opsForValue();//操作字符串
    2. redisTemplate.opsForHash();//操作hash
    3. redisTemplate.opsForList();//操作list
    4. redisTemplate.opsForSet();//操作set
    5. redisTemplate.opsForZSet();//操作有序set
    4. 配置缓存、CacheManagerCustomizers
    5. 测试使用缓存、切换缓存、 CompositeCacheManager

     

     

     运行原理:

    1、自动配置类:CacheAutoConfiguration

    2、缓存的配置类

    3、默认生效的配置类:

    SimpleCacheConfiguration

    4、给容器注册一个:

    cacheManager:ConcurrentMapCacheManager

    5、创建ConcurrentMapCache类型的缓存组件:它的数据将保存在ConcurrentMap中

     

     

    运行流程:

     

     开发中使用的开发中间件:redis、memcache、ehcache

    整合rredis作为缓存:

    Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。

    1.安装redis,使用Docker

    docker pull registry.docker-cn.com/library/redis

    docker run -d -p 6379:6379 --name myredis registry.docker-cn.com/library/redis

    2.引入redis的starter

    3.配置redis的主机

    @RunWith(SpringRunner.class)
    @SpringBootTest
    public class Springboot01CacheApplicationTests {
    
        @Autowired
        StringRedisTemplate stringRedisTemplate;
        @Autowired
        RedisTemplate redisTemplate;
    
        @Autowired
        EmployeeMapper employeeMapper;
    
        /**
         * Redis 常见的5大数据类型
         * String 字符串 、List列表、set集合、Hash散列、Zset有序集合
         *  stringRedisTemplate.opsForValue()[String 字符串]
         *  stringRedisTemplate.opsForList()[List列表]
         *  stringRedisTemplate.opsForSet()[set集合]
         *  stringRedisTemplate.opsForHash()[Hash散列]
         *  stringRedisTemplate.opsForZSet()[Zset有序集合]
         *
         */
        @Test
        public void test01() {
            // 给redis中保存数据
            // stringRedisTemplate.opsForValue().append("msg","helloworld");
           //String msg = stringRedisTemplate.opsForValue().get("msg");
          //  System.out.println(msg);
        }
        // 测试保存对象
        @Test
        public void test02() {
            Employee empById = employeeMapper.getEmpById(1);
            // 如果保存对象,使用jdk序列化机制,序列化后的数据保存到redis中
            // redisTemplate.opsForValue().set("emp-01",empById);
            // 1、将数据以json的方式进行保存
            // (1)将自己对象转化为json
            //  (2) redisTemplate默认的序列化规则,改变默认的序列化规则。
        }
        @Test
        public void contextLoads() {
        }
    
    }

     redis 对象键值对-----not ok!

  • 相关阅读:
    RESTful日#2:使用Unity容器和引导程序在Web api中使用依赖注入实现控制反转
    RESTful日#2:使用Unity容器和引导程序在Web api中使用依赖注入实现控制反转
    带有可选选项的输入文本框(组合框)
    在组合框中嵌入一个DataGridView
    ItemData在。net
    实现一个所有者绘制的组合框
    模板化的“请等待”按钮和模板控件介绍
    使用AvalonEdit (WPF文本编辑器)
    办公风格的扁平组合箱
    【windows】telnet 和一些dos命令
  • 原文地址:https://www.cnblogs.com/limingxian537423/p/10625059.html
Copyright © 2011-2022 走看看