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
,以及結合自定義配置的方式。你可以根據具體需求選擇合適的方式來實現多數據源的支持。