SpringBoot解决mysql 连接8小时问题

SpringBoot解决mysql 连接8小时问题

问题: 服务连接mysql数据库,8小时没有数据库的操作时候,数据库会主动断开连接释放资源

解决办法总共4种方法

MySQL 5版本之前可以通过在URL后面加入autoReconnect=true

application.properties文件中加入:

yaml 复制代码
spring.datasource.test-on-borrow=true #(即在获取Connection对象时检测其可用性),不过这样会影响性能,但是这个配置是最有效的。
spring.datasource.test-while-idle=true
spring.datasource.time-between-eviction-runs-millis= 3600000

** 数据库配置调整:**

如果你有权限访问 MySQL 服务器的配置,你也可以调整 MySQL 的连接超时时间。修改 wait_timeoutinteractive_timeout 参数,将它们设置为一个更大的值,以延长连接的存活时间。

请注意,修改 MySQL 服务器的配置可能需要谨慎考虑,因为这会影响到所有连接

my.ini 文件中修改此参数

ini 复制代码
[mysqld]
wait_timeout=31536000
interactive_timeout=31536000

定时任务发送查询:

如果你没有使用连接池,你可以创建一个定时任务,在一定时间间隔内发送一个查询来保持连接活跃。这可以使用 Spring 的 @Scheduled 注解来实现

java 复制代码
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class KeepAliveTask {
    private final JdbcTemplate jdbcTemplate;

    public KeepAliveTask(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    @Scheduled(fixedRate = 300000) // 5 minutes
    public void keepConnectionAlive() {
        jdbcTemplate.queryForObject("SELECT 1", Integer.class);
    }
}
相关推荐
henujolly16 分钟前
go学习day two
后端
AI袋鼠帝28 分钟前
腾讯这只小程序Agent🦀,帮我找到了最强日程、文件、知识管理姿势
后端
努力的小郑37 分钟前
突发!Claude Code 51万行源码全网裸奔:一场史诗级“开源”事故,国内大厂笑麻了
前端·后端·ai编程
qq_283720051 小时前
MySQL技巧(九): Binlog 完整格式解析(ROW 模式,默认)
mysql·binlog·数据恢复
皮皮林5511 小时前
用 SpringBoot + Tess4j 优雅实现图像文字识别,真香!
spring boot
HashTang1 小时前
Claude Code 源码中 REPL.tsx 深度解析:一个 5005 行 React 组件的架构启示
前端·后端·ai编程
thatway19891 小时前
ARM TFM-1介绍及代码下载运行适配
后端
Java面试题总结2 小时前
MySQL篇 索引失效
数据库·mysql
千寻girling2 小时前
不知道 Java 全栈 + AI 编程有没有搞头 ?
前端·人工智能·后端
last demo2 小时前
mysql
运维·数据库·mysql·oracle