当前位置: 首页 > news >正文

springboot配置redis lettuce连接池,以及连接池参数解释

文章目录

  • 前置
  • 基本配置
  • 参数解释

前置

  • java
  • springboot
  • redis
  • lettuce 连接池

有很多连接池,比如 jedis,lettuce,redission,springboot 默认使用 lettuce 连接池

lettuce 连接池的特点是:一个 lettuce 连接可以被多个线程复用,不需要频繁创建连接,其实是通过 Netty 实现了异步非阻塞,单连接即可支持高并发

虽然多个线程可以共享一个 lettuce 的一个连接,但是 redis 它本身是串行执行命令的

默认情况下(shareNativeConnection = true),Lettuce 的连接池(如 GenericObjectPool)实际上 不会生效,因为所有线程都共用一个连接

如果你希望启用连接池(例如为每个线程分配独立连接),需要显式设置 shareNativeConnection = false,此时连接池参数(如 max-active、max-idle)才会起作用

如果默认按照 shareNativeConnection = true,Lettuce 会始终使用一个物理连接,所有线程共享这个连接,不会生成第二个新的连接,连接池参数不生效,官方推荐默认值,因为已经适合了大多数场景,单个连接即可满足高并发需求,避免资源浪费

基本配置

依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

application.yml

spring:redis:host: localhost  # Redis 服务器地址port: 6379       # Redis 服务器端口,默认是 6379password:        # Redis 密码(如果没有密码,可以省略)database: 0      # 使用的数据库索引,默认是 0timeout: 2000    # 连接超时时间(毫秒)lettuce:pool:max-active: 8      # 连接池最大连接数max-idle: 8        # 连接池最大空闲连接数min-idle: 0        # 连接池最小空闲连接数max-wait: -1ms     # 连接池最大阻塞等待时间(-1 表示无限制)

参数解释

参数说明默认值推荐值
活跃连接和空闲连接:
spring.redis.lettuce.pool.max-active最大活跃连接数(包括正在使用和空闲的连接)8根据 CPU 核心数调整,通常为 CPU * 2 + 2
spring.redis.lettuce.pool.max-idle最大空闲连接数(避免频繁创建连接)8CPU * 2
spring.redis.lettuce.pool.min-idle最小空闲连接数(保持一定数量的空闲连接)00 或 1(低负载场景)
spring.redis.lettuce.pool.time-between-eviction-runs空闲连接回收线程的运行间隔(单位:毫秒),清理的是超过 max-idle 或空闲时间过长的空闲连接,根据 min-evictable-idle-time,关闭长时间未使用的空闲连接,但连接数不低于 min-idle1000~60000(根据负载调整)
spring.redis.lettuce.pool.min-evictable-idle-time最小驱逐空闲时间未显式配置时默认为 300 秒300秒
连接等待与超时:
spring.redis.lettuce.pool.max-wait获取连接的最大等待时间(单位:毫秒,负值表示无限等待)-15000~60000(避免线程长时间阻塞)
spring.redis.lettuce.shutdown-timeout关闭连接池的超时时间(单位:毫秒)1001000~5000(确保连接正常关闭)

相关文章:

  • 从逻辑学视角严谨证明数据加密的数学方法与实践
  • 【Ubuntu】如何在一个脚本文件中跑三个python文件?以及端口被占的解决方法
  • 企业级云原生爬虫架构与智能优化
  • ArcGIS Pro 3.4 二次开发 - 地理数据库
  • PostgreSQL 数据库备份与恢复
  • 从源码编译支持ffmpeg(H264编码)的opencv(创建mp4视频报错:H264 is not supported with codec id 28)
  • Oracle 基础知识作业的使用
  • Linux-线程同步于互斥
  • Docker Volumes 还原指南
  • 超详细openBmc Virtual Media 功能及实现流程(1)
  • 使用Rancher在CentOS 环境上部署和管理多Kubernetes集群
  • nginx配置跨域请求,后台不用配置啦,完美
  • VMware虚拟机突然无法ssh连接
  • 消除爆红 [vue/no-unused-vars] ‘row‘ is defined but never used.eslint-plugin-vue
  • 【NGINX】-11 nginx 平滑升级
  • 如何使用patch-package给npm包打补丁
  • halcon 连接相机
  • 扫描电镜:打开微观世界的“超维相机“
  • 晶圆隐裂检测提高半导体行业效率
  • LNCS-2009《Adaptive Sampling for $k$-Means Clustering》
  • 如何做优秀的视频网站设计/网站制作详细流程
  • 中国空间站纪念币/电商具体是做什么的
  • 跨境出口电商网站/seo分析seo诊断
  • 不同性质网站/宁波seo网络推广产品服务
  • 我的网站在百度搜不到/谷歌官网下载
  • 怎么做钓鱼网站盗取qq/今日头条热搜