博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SpringCache学习实践
阅读量:5896 次
发布时间:2019-06-19

本文共 5451 字,大约阅读时间需要 18 分钟。

1. SpringCache学习实践

1.1. 引用

org.springframework.boot
spring-boot-starter-cache

1.2. 启用方式

1.2.1. 添加一种cacheManager的bean

  1. 若注解了@EnableCaching,则spring可自动发现并配置cacheManager,只要有一种可用于缓存提供的即可,详情见文献[1]。常用的有Ehcache、redis等实现
@Configuration    @EnableCaching    public class CacheConfiguration {        @Bean        public CacheManager cacheManager() {            SimpleCacheManager cacheManager = new SimpleCacheManager();            cacheManager.setCaches(Collections.singletonList(new ConcurrentMapCache("models")));            return cacheManager;        }    }

1.3. 使用方式

  1. 三个主要的注解 Cacheable (最常用的注解,用于标注需要缓存方法)、CacheEvict(用于仅清除缓存)、CachePut(用于仅存放缓存)
  2. 先定义一个测试POJO: TestModel。 含有name和address两个字符串变量。
class TestModel {       String name;       String address;       // 省略getter和setter   }

1.3.1. Cacheable

@Cacheable(value = "models", key = "#testModel.name", condition = "#testModel.address !=  '' ")public TestModel getFromMem(TestModel testModel) throws InterruptedException {    TimeUnit.SECONDS.sleep(1);    testModel.setName(testModel.getName().toUpperCase());    return testModel;}
  1. 例子里的注解@Cacheable中存在有以下几个元素
    • value (也可使用 cacheNames) : 可看做命名空间,表示存到哪个缓存里了。
    • key : 表示命名空间下缓存唯一key,使用Spring Expression Language(简称SpEL,详见参考文献[5])生成。
    • condition : 表示在哪种情况下才缓存结果(对应的还有unless,哪种情况不缓存),同样使用SpEL
  2. 当第一次使用
{name: 'XiaoMing', address: 'ChengDu'}

调用getFromMem时,会等待一秒钟,然后返回

{name: 'XIAOMING', address: 'ChengDu'}

再次使用name为’XiaoMing’的对象作为参数调用getFromMem时,会立即返回上一个结果,无论参数中的address是什么。

但是如果第一次调用时,address为空字符串,第二次调用仍然需要等待一秒钟,这就是condition的作用。

1.3.2. CacheEvict

@CacheEvict(value = "models", allEntries = true)@Scheduled(fixedDelay = 10000)public void deleteFromRedis() {}@CacheEvict(value = "models", key = "#name")public void deleteFromRedis(String name) {}
  1. 例子里的注解 @CacheEvict 中存在有以下几个元素
    • value (也可使用 cacheNames) : 同Cacheable注解,可看做命名空间。表示删除哪个命名空间中的缓存
    • allEntries: 标记是否删除命名空间下所有缓存,默认为false
    • key: 同Cacheable注解,代表需要删除的命名空间下唯一的缓存key
  2. 例子中第一段,与 @Scheduled 注解同时使用,每十秒删除命名空间name下所有的缓存
  3. 第二段,调用此方法后删除命名空间models下, key == 参数 的缓存
    同样含有unless与condition

1.3.3. CachePut

@CachePut(value = "models", key = "#name")public TestModel saveModel(String name, String address) {    return new TestModel(name, address);}
  1. 例子里的注解 @CachePut 中存在有以下几个元素
    • value: 同上
    • key: 同上
    • condition(unless): 同上
  2. 比如可用于后台保存配置时及时刷新缓存。

1.4. Redis作为缓存配置

1.4.1. 引用

  1. 再加依赖
org.springframework.boot
spring-boot-starter-data-redis
  1. 然后在配置中添加RedisConnectionFactory用于获取redis链接
@Value("${spring.redis.host}")    private String redisHost;    @Value("${spring.redis.port}")    private int redisPort;    @Value("${spring.redis.timeout}")    private int redisTimeout;    @Value("${spring.redis.password}")    private String redisAuth;    @Value("${spring.redis.database}")    private int redisDb;    @Value("${spring.redis.pool.max-active}")    private int maxActive;    @Value("${spring.redis.pool.max-wait}")    private int maxWait;    @Value("${spring.redis.pool.max-idle}")    private int maxIdle;    @Value("${spring.redis.pool.min-idle}")    private int minIdle;    @Bean    public RedisConnectionFactory redisConnectionFactory() {        JedisPoolConfig poolConfig = new JedisPoolConfig();        poolConfig.setMaxTotal(maxActive);        poolConfig.setMaxIdle(maxIdle);        poolConfig.setMaxWaitMillis(maxWait);        poolConfig.setMinIdle(minIdle);        poolConfig.setTestOnBorrow(true);        poolConfig.setTestOnReturn(false);        poolConfig.setTestWhileIdle(true);        JedisClientConfiguration clientConfig = JedisClientConfiguration.builder()                .usePooling().poolConfig(poolConfig).and().readTimeout(Duration.ofMillis(redisTimeout)).build();        // 单点redis        RedisStandaloneConfiguration redisConfig = new RedisStandaloneConfiguration();        // 哨兵redis        // RedisSentinelConfiguration redisConfig = new RedisSentinelConfiguration();        // 集群redis        // RedisClusterConfiguration redisConfig = new RedisClusterConfiguration();        redisConfig.setHostName(redisHost);        redisConfig.setPassword(RedisPassword.of(redisAuth));        redisConfig.setPort(redisPort);        redisConfig.setDatabase(redisDb);        return new JedisConnectionFactory(redisConfig,clientConfig);    }    @Bean    public RedisTemplate
redisTemplate() { RedisTemplate
redisTemplate = new RedisTemplate<>(); Jackson2JsonRedisSerializer
serializer = jackson2JsonRedisSerializer(); redisTemplate.setConnectionFactory(redisConnectionFactory()); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(serializer); redisTemplate.setHashKeySerializer(new StringRedisSerializer()); redisTemplate.setHashValueSerializer(serializer); return redisTemplate; } @Bean public Jackson2JsonRedisSerializer jackson2JsonRedisSerializer() { final Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class); final ObjectMapper objectMapper = Jackson2ObjectMapperBuilder .json().build(); objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL); jackson2JsonRedisSerializer.setObjectMapper(objectMapper); return jackson2JsonRedisSerializer; }

转载于:https://www.cnblogs.com/sky-chen/p/10256157.html

你可能感兴趣的文章
将HTML特殊转义为实体字符的两种实现方式
查看>>
System.Func<>与System.Action<>
查看>>
asp.net开源CMS推荐
查看>>
csharp skype send message in winform
查看>>
MMORPG 游戏服务器端设计--转载
查看>>
SILK 的 Tilt的意思
查看>>
Html学习笔记3
查看>>
HDFS dfsclient写文件过程 源码分析
查看>>
部署P2P升级的脚本
查看>>
ubuntu下安装libxml2
查看>>
nginx_lua_waf安装测试
查看>>
WinForm窗体缩放动画
查看>>
JQuery入门(2)
查看>>
linux文件描述符
查看>>
C++ const 详解
查看>>
传值引用和调用引用的区别
查看>>
Hive简介
查看>>
hyper-v 无线网连接
查看>>
Python3.7.1学习(六)RabbitMQ在Windows环境下的安装
查看>>
Windows下memcached的安装配置
查看>>