Spring Boot 支持多种方式来实现 Redis 的多数据源配置。以下是一些常见的方法:
RedisConnectionFactory
你可以为每个数据源配置一个单独的 RedisConnectionFactory
。Spring Boot 提供了灵活的配置方式来定义这些连接工厂。
spring:
redis:
client:
lettuce:
pool:
max-active: 10
max-idle: 5
min-idle: 2
jedis:
pool:
max-active: 10
max-idle: 5
min-idle: 2
# 数据源1
spring.redis.client.lettuce-source1.host=localhost
spring.redis.client.lettuce-source1.port=6379
spring.redis.client.lettuce-source1.database=0
# 数据源2
spring.redis.client.jedis-source2.host=localhost
spring.redis.client.jedis-source2.port=6380
spring.redis.client.jedis-source2.database=1
RedisStandaloneConfiguration
和 RedisTemplate
你可以为每个数据源配置一个 RedisStandaloneConfiguration
和一个 RedisTemplate
。
spring:
redis:
client:
lettuce:
pool:
max-active: 10
max-idle: 5
min-idle: 2
jedis:
pool:
max-active: 10
max-idle: 5
min-idle: 2
# 数据源1
spring.redis.client.lettuce-source1.host=localhost
spring.redis.client.lettuce-source1.port=6379
spring.redis.client.lettuce-source1.database=0
# 数据源2
spring.redis.client.jedis-source2.host=localhost
spring.redis.client.jedis-source2.port=6380
spring.redis.client.jedis-source2.database=1
RedisClusterConfiguration
和 RedisTemplate
如果你使用的是 Redis 集群,可以使用 RedisClusterConfiguration
和 RedisTemplate
。
spring:
redis:
cluster:
nodes:
- localhost:7000
- localhost:7001
- localhost:7002
- localhost:7003
- localhost:7004
- localhost:7005
RedisSentinelConfiguration
和 RedisTemplate
如果你使用的是 Redis 哨兵模式,可以使用 RedisSentinelConfiguration
和 RedisTemplate
。
spring:
redis:
sentinel:
master: mymaster
nodes:
- localhost:26379
- localhost:26380
- localhost:26381
RedisConnectionFactory
和 RedisTemplate
结合自定义配置你可以结合自定义的 RedisConnectionFactory
和 RedisTemplate
来实现更复杂的配置。
@Configuration
public class RedisConfig {
@Bean
public RedisConnectionFactory redisConnectionFactory1() {
RedisStandaloneConfiguration config = new RedisStandaloneConfiguration();
config.setHostName("localhost");
config.setPort(6379);
config.setDatabase(0);
return new LettuceConnectionFactory(config);
}
@Bean
public RedisConnectionFactory redisConnectionFactory2() {
RedisStandaloneConfiguration config = new RedisStandaloneConfiguration();
config.setHostName("localhost");
config.setPort(6380);
config.setDatabase(1);
return new LettuceConnectionFactory(config);
}
@Bean
public RedisTemplate<String, Object> redisTemplate1() {
RedisTemplate<String, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory1());
return template;
}
@Bean
public RedisTemplate<String, Object> redisTemplate2() {
RedisTemplate<String, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory2());
return template;
}
}
Spring Boot 提供了多种方式来配置 Redis 的多数据源,包括使用多个 RedisConnectionFactory
、RedisStandaloneConfiguration
和 RedisTemplate
、RedisClusterConfiguration
和 RedisTemplate
、RedisSentinelConfiguration
和 RedisTemplate
,以及结合自定义配置的方式。你可以根据具体需求选择合适的方式来实现多数据源的支持。