首页 > 其他分享 >第十一天

第十一天

时间:2022-11-17 23:13:25浏览次数:33  
标签:第十一天 om 缓存 Redis factory jackson2JsonRedisSerializer new

Redis 的回顾

在一个网站中,那一部分的访问量是最大的?一般都是首页面的访问量是最大的!解决方案:对首页的数据进行缓存,通过Redis来进行缓存处理

1.Redis的介绍:

Redis的特点:
0,基于Key和Value的方式来进行实现的
1,读取的速度块,Redis读取的速度是110000次/s,写的速度是81000次/s;
2,原子 。Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
3,支持多种数据结构:string(字符串);list(列表);hash(哈希),set(集合);zset(有序集合)
4,持久化,集群部署 ,通过内存进行存储,也可以存到硬盘里面!
5,支持过期时间(也就是Redis中的数据 超过多长时间之后就失效了!),支持事务,消息订阅
6,Redis一般存储什么样的数据:
经常进性查询,不经常修改的数据放到redis作为缓存或者不是特别重要的数据!
比如钱财的数据就不适合做缓存!
Redis 的集群比较重要

2.Redis在项目中的集成:

1.添加Redist的相关依赖:在common模块添加依赖
由于redis缓存是公共应用,所以我们把依赖与配置添加到了common模块下面,在common模块pom.xml下添加以下依赖

点击查看代码
	 <!-- redis -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <!-- spring2.X集成redis所需common-pool2-->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <version>2.6.0</version>
        </dependency>

2.创建Redis缓存配置类,配置插件

点击查看代码
@EnableCaching //开启缓存
@Configuration  //配置类
public class RedisConfig extends CachingConfigurerSupport { //两个插件
    /**
     * RedisTemplate :redis 模板 ,也就是spring-boot-starter-data-redis依赖中的 相关模板
     * @param factory
     * @return
     */
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        template.setConnectionFactory(factory);
        //key序列化方式
        template.setKeySerializer(redisSerializer);
        //value序列化
        template.setValueSerializer(jackson2JsonRedisSerializer);
        //value hashmap序列化
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        return template;
    }

    /**
     * 针对缓存的管理
     * @param factory
     * @return
     */
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        //解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        // 配置序列化(解决乱码的问题),过期时间600秒
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(600)) //设置数据的过期时间,超过就取不出来了
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();
        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
        return cacheManager;
    }
}

3. 在查询所有banner的方法的上面添加缓存注解@Cacheable
@Cacheable(key= "'selectIndexList'",value = "banner")

image
4.启动Redis服务

image

最后重新启动服务器就可以了!

标签:第十一天,om,缓存,Redis,factory,jackson2JsonRedisSerializer,new
From: https://www.cnblogs.com/gz-xiaofan/p/16901084.html

相关文章