栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

springboot 集成 Redis调试

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

springboot 集成 Redis调试

在Spring Boot中,默认集成Spring Data Redis,Spring Data Redis针对Redis提供了非常方便的操作模版RedisTemplate,并且可以进行连接池自动管理。
先导入依赖



    org.springframework.boot
    spring-boot-starter-data-redis



    org.apache.commons
    commons-pool2




    com.fasterxml.jackson.core
    jackson-databind


    com.fasterxml.jackson.datatype
    jackson-datatype-jsr310

写配置文件application.yml

spring: 
  redis:
    host: 192.168.47.130
    port: 6379
    database: 0
    password: #默认为空
    timeout: 3000ms #最大等待时间,超时则抛出异常,否则请求一直等待
    lettuce:
      pool:
        max-active: 20  #最大连接数,负值表示没有限制,默认8
        max-wait: -1    #最大阻塞等待时间,负值表示没限制,默认-1
        max-idle: 8     #最大空闲连接,默认8
        min-idle: 0     #最小空闲连接,默认0

虚拟机启动redis

#先查看进程
ps -ef|grep redis
#如果没启动,则先将redis起来,进入redis的bin目录下
bin/redis-server redis.conf
#启动后可以选择性开启client(如未配置后台启动可以开启新的会话框)
./redis-cli
#查看一下key的情况
keys *

在windows中开启redis desktop manager查看连接情况
连不上可以先ping一下,ping不通就是网络设置问题了,ping通连不上,建议杀死进程,重启redis。

以上就绪后,我们可以在项目中创建测试类(如下是查询数据库,存一个dict对象)

@SpringBootTest
@RunWith(SpringRunner.class)
public class RedisTemplateTests {
    @Resource
    private RedisTemplate redisTemplate;
    @Resource
    private DictMapper dictMapper;
    @Test
    public void saveDict(){
        Dict dict = dictMapper.selectById(1);
        //向数据库中存储string类型的键值对, 过期时间5分钟
        redisTemplate.opsForValue().set("dict", dict, 5, TimeUnit.MINUTES);
    }
}

@Configuration
public class RedisConfig {

写config配置类,配置Redis序列化方案

    @Bean
    public RedisTemplate redisTemplate(LettuceConnectionFactory redisConnectionFactory) {

        RedisTemplate redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);

        //首先解决key的序列化方式
        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
        redisTemplate.setKeySerializer(stringRedisSerializer);

        //解决value的序列化方式
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class);

        //序列化时将类的数据类型存入json,以便反序列化的时候转换成正确的类型
        ObjectMapper objectMapper = new ObjectMapper();
        //objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        objectMapper.activateDefaultTyping(LaissezFaireSubTypevalidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);

        // 解决jackson2无法反序列化LocalDateTime的问题
        objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
        objectMapper.registerModule(new JavaTimeModule());

        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);


        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        return redisTemplate;
    }
}
 

最后进test写入测试取值

@Test
public void getDict(){
    Dict dict = (Dict)redisTemplate.opsForValue().get("dict");
    System.out.println(dict);
}

接下来编写实现类,具体代码就不写了,写一下逻辑
1.redisTemplate.opsForValue().get()查询出是否存在数据,如果不为null,直接取值
2.catch (Exception e),有可能出现redis失效的情况,我们选择继续执行不抛出异常log.error()
3.如果不存在则从数据库取值
4.redisTemplate.opsForValue().set()将数据存入redis后,return返回结果

以上就是一套完整的redis缓存调试及编写业务过程

转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号