Par*_*een 6 java spring spring-data-redis spring-boot
我有以下用于获取 RedisTemplate 的代码片段。
@Bean
public JedisConnectionFactory getJedisConnectionFactory() {
RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration();
redisStandaloneConfiguration.setHostName(host);
if (!StringUtils.isEmpty(password)) {
redisStandaloneConfiguration.setPassword(RedisPassword.of(password));
}
redisStandaloneConfiguration.setPort(port);
return new JedisConnectionFactory(redisStandaloneConfiguration, getJedisClientConfiguration());
}
@Bean
public RedisTemplate redisTemplate() {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
redisTemplate.setConnectionFactory(getJedisConnectionFactory());
redisTemplate.setKeySerializer(new StringRedisSerializer());
return redisTemplate;
Run Code Online (Sandbox Code Playgroud)
}
我的问题是 sprint-boot 如何理解连接池,因为我没有在工厂中提供有关连接池的任何信息。我的应用程序属性文件具有以下属性。
redis.host=<redis-host>
redis.port=<port>
redis.password=<password>
redi.jedis.pool.max.total=16
redi.jedis.pool.max.idle=8
redi.jedis.pool.min.idle=4
Run Code Online (Sandbox Code Playgroud)
当您JedisClientConfiguration使用构建器创建时
JedisClientConfigurationBuilder builder = JedisClientConfiguration .builder()
Run Code Online (Sandbox Code Playgroud)
这将在内部调用默认构造函数,JedisClientConfiguration其看起来像这样。
private DefaultJedisClientConfigurationBuilder() {
this.poolConfig = new JedisPoolConfig();
// other configs
}
Run Code Online (Sandbox Code Playgroud)
JedisPoolConfig进一步扩展GenericObjectPoolConfig,其默认值如下。(如果不手动覆盖,这将是默认值)
maxTotal = 8;
maxIdle = 8;
minIdle = 0;
Run Code Online (Sandbox Code Playgroud)
在您的情况下,当您使用 覆盖配置时GenericObjectPoolConfig,它将从那里选择值。
GenericObjectPoolConfig.setMaxTotal(maxConnection);
GenericObjectPoolConfig.setMaxIdle(maxConnectionIdle);
GenericObjectPoolConfig.setMinIdle(minConnectionIdle);
Run Code Online (Sandbox Code Playgroud)
当您指定usePooling()和时poolConfig(genericObjectPoolConfig),您的应用程序将使用这些配置进行连接池。
我希望这有帮助。
| 归档时间: |
|
| 查看次数: |
11993 次 |
| 最近记录: |