天天看點

Redis配置導入Redis依賴配置redis服務編寫redis配置類

Rrdis配置

  • 導入Redis依賴
  • 配置redis服務
  • 編寫redis配置類

導入Redis依賴

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
           

配置redis服務

appliction.yml

配置redis服務(根據實際情況修改資料),代碼如下

spring:
  redis:
    database: 0           # Redis伺服器資料庫
    host: 127.0.0.1       # Redis伺服器位址
    port: 6379            # Redis伺服器連接配接端口
    timeout: 6000ms       # 連接配接逾時時間(毫秒)
    jedis:
      pool:
        max-active: 200   # 連接配接池最大連接配接數(使用負值表示沒有限制)
        max-wait: -1      # 連接配接池最大阻塞等待時間(使用負值表示沒有限制)
        max-idle: 10      # 連接配接池中的最大空閑連接配接
        min-idle: 0       # 連接配接池中的最小空閑連接配接
           

編寫redis配置類

RedisConfig.java

代碼如下:

@Configuration
public class RedisConfig {

    @Bean
    @SuppressWarnings("all")
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        // 我們為了自己開發友善,一般直接使用 <String, Object>
        RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();
        template.setConnectionFactory(factory);
        // Json序列化配置
        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);
        // String 的序列化
        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
        // key采用String的序列化方式
        template.setKeySerializer(stringRedisSerializer);
        // hash的key也采用String的序列化方式
        template.setHashKeySerializer(stringRedisSerializer);
        // value序列化方式采用jackson
        template.setValueSerializer(jackson2JsonRedisSerializer);
        // hash的value序列化方式采用jackson
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        template.afterPropertiesSet();
        return template;
    }
}