Redis 客户端 Lettuce 命令超时与套接字超时

标签 redis timeout spring-data-redis lettuce

我们已经定义了 Lettuce 客户端连接工厂,以便能够连接到定义自定义套接字和命令超时的 Redis:

@Bean
LettuceConnectionFactory lettuceConnectionFactory() {

   final SocketOptions socketOptions = SocketOptions.builder().connectTimeout(socketTimeout).build();
   final ClientOptions clientOptions =
           ClientOptions.builder().socketOptions(socketOptions).build();

   LettuceClientConfiguration clientConfig = LettuceClientConfiguration.builder()
           .commandTimeout(redisCommandTimeout)
           .clientOptions(clientOptions).build();
   RedisStandaloneConfiguration serverConfig = new RedisStandaloneConfiguration(redisHost,
           redisPort);

   final LettuceConnectionFactory lettuceConnectionFactory = new LettuceConnectionFactory(serverConfig,
           clientConfig);
   lettuceConnectionFactory.setValidateConnection(true);
   return new LettuceConnectionFactory(serverConfig, clientConfig);
}

enter image description here

Lettuce 文档定义默认值:

  • 默认套接字超时为 10 秒
  • 默认命令超时为 60 秒

如果 Redis 服务关闭,应用程序必须在 300 毫秒内收到超时。哪个值必须定义为最大值?

Github 示例项目: https://github.com/cristianprofile/spring-data-redis-lettuce

最佳答案

在套接字选项中指定连接超时。这是允许 Redis 客户端 (Lettuce) 尝试与 Redis 服务器建立 TCP/IP 连接的最长时间。该值应该相对较小(例如最多 1 分钟)。

如果客户端无法在 1 分钟内与服务器建立连接,我想可以肯定地说服务器不可用(服务器已关闭,地址/端口错误,防火墙等网络安全禁止连接等)。

命令超时完全不同。建立连接后,客户端可以向服务器发送命令。它期望服务器响应这些命令。超时配置客户端等待服务器命令响应的时间。

我认为可以将此超时设置为更大的值(例如几分钟),以防客户端命令向服务器发送大量数据并且传输和存储这么多数据需要时间。

关于Redis 客户端 Lettuce 命令超时与套接字超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51836375/

相关文章:

java - Spring Session 和 Redis 混合 session

php - 我无法使用 php 连接到 redis

asp.net - asp.net 应用程序继续运行时浏览器超时

java - Curator 与 Zookeeper 服务发现连接被强制关闭

spring - 为什么 Spring @Cacheable 不将带注释的方法的结果类型传递给它的反序列化器?

spring-data - 无法获得Redis的连接Spring数据Redis的模板

ruby-on-rails - Controller 中的查询缓存

redis - 对 Redis 及其工作方式感到困惑

sql-server - 如何在脚本内设置 SQL Server 脚本的超时?

Spring Data Redis 不会将日期保留为空值