SpringBoot配置Redis多数据源,或同一数据源切换database

在编程中,经常需要处理多Redis数据源或动态切换Database的情况。文章介绍了如何通过配置多个数据源来解决线程安全的动态切换问题,具体方法包括创建新的redisTemplate,修改JedisConnectionFactory的连接信息,并提供了配置文件和代码示例,适用于Redis和MongoDB的多数据源配置。

        在编码过程中经常会遇到需要配置多个redis数据源,或者在同一数据源下切换database的场景。

        今天遇到了需要动态切换database的业务需求,找了几个方法,虽然能切换,但是存在线程安全问题。最终我选择了配置多数据源来切换database。也就是重新生成一个 redisTemplate,通过修改JedisConnectionFactory连接信息的方法。这种方法通用与MongoDB的多数据源配置,也是通过配置bean工厂实现。且是线程安全的。

 1.配置文件如下

# redis配置
  redis:
    # Redis数据库索引
    database: 0
    # Redis服务器地址
    host:  
    # Redis服务器连接端口
    port:  
    # Redis服务器连接密码(默认为空)
    password:  
#redis数据源2
  redis2:
    database: 2
    host:  
    port:  
    password:  

2.redis配置类

@Configuration
public class Redis2Configs {
    @Value("${spring.redis2.database}")
    private int database;
    @Value("${spring.redis2.host}")
    private String host;
    @Value("${spring.redis2.password}")
    private String password;
    @Value("${spring.redis2.port}")
    private int port;


    @Bean(name={"redisTemplate2"})//容器注入名称
    public RedisTemplate<String, Object> redisTemplate() {
        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redis2ConnectionFactory());
        redisTemplate.setKeySerializer(keySerializer());
        redisTemplate.setHashKeySerializer(keySerializer());
        redisTemplate.setValueSerializer(valueSerializer());
        redisTemplate.setHashValueSerializer(valueSerializer());
        return redisTemplate;
    }

    private RedisSerializer<String> keySerializer() {
        return new StringRedisSerializer();
    }

    private RedisSerializer<Object> valueSerializer() {
        return new GenericFastJsonRedisSerializer();
    }

    private JedisConnectionFactory redis2ConnectionFactory() {
        RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration();
        redisStandaloneConfiguration.setDatabase(database);
        redisStandaloneConfiguration.setHostName(host);
        redisStandaloneConfiguration.setPort(port);
        redisStandaloneConfiguration.setPassword(RedisPassword.of(password));
        JedisClientConfiguration clientConfig = JedisClientConfiguration.builder()
                .build();
        JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory(redisStandaloneConfiguration,clientConfig);
        jedisConnectionFactory.afterPropertiesSet();
        return jedisConnectionFactory;
    }

PS:为了简便我没有配置连接池,需要的可以添加配置信息

3.注入需要的数据源进行使用

    @Autowired
    private RedisTemplate redisTemplate;//默认配置

    @Resource(name = "redisTemplate2")
    private RedisTemplate redisTemplate2;
Boolean hasKey = redisTemplate2.hasKey("key");

Set keys = redisTemplate.opsForHash().keys("key");

                                 需要MongoDB多数据源配置方法的可以评论或私俺

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值