[英]Spring data Redis Cluster Lettuce Connection Settings
我们将 spring 数据 redis 与生菜一起使用,生菜使用单连接,但在 web 应用程序中,根据我的假设,最好使用连接池。 下面是 java 配置的代码
@Configuration
@ComponentScan(basePackages = { "com.test.*" })
public class AppConfig {
@Bean
public LettuceConnectionFactory getLettuceConnectionFactory() {
List<String> clusterNodes = Arrays.asList("redis-cluster----0001-001.redis-cluster---.usw2.cache.amazonaws.com:6379", "redis-cluster----0001-002.redis-cluster---.usw2.cache.amazonaws.com:6379");
final LettuceConnectionFactory lettuceConnectionFactory = new LettuceConnectionFactory(new RedisClusterConfiguration(clusterNodes));
lettuceConnectionFactory.setTimeout(10000);
lettuceConnectionFactory.setUseSsl(true);
lettuceConnectionFactory.setVerifyPeer(false);
lettuceConnectionFactory.setStartTls(false);
lettuceConnectionFactory.afterPropertiesSet();
return lettuceConnectionFactory;
}
@Bean
public RedisTemplate<String, Object> redisTemplate() {
final RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
redisTemplate.setConnectionFactory(getLettuceConnectionFactory());
return redisTemplate;
}
}
由于我们使用 Spring 数据 redis 1.8.23 和 Lettuce 4.5.0.final,我们不能使用 LettucePoolingClientConfiguration。
为 AWS Elastic Cache 使用 DefaultLettucePool 是否是好的选择,使用 setShareNativeConnection 设置为 false 的缺点是什么。
拥有连接池的任何其他更好的选择。
将 DefaultLettucePool 用于 AWS Elastic Cache 是否是一个不错的选择
从功能的角度来看,它工作得很好,唯一的问题是它已被弃用,因此使用它会产生技术债务。
使用 setShareNativeConnection 设置为 false 的缺点是什么
它将增加应用程序的网络 I/O,因为每个操作都会打开和关闭一个套接字。 将其保持为 true 可确保多个 LettuceConnection 对象可以重用本机连接。
作为替代方案,尝试使用Jedis作为您的引擎,而不是 Lettuce。 使用这个库我有一些很棒的表现,它也支持连接池。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.