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);
    }
}
相关推荐
疯狂的程序猴7 分钟前
深入理解 iPhone 文件管理,从沙盒结构到开发调试的多工具协同实践
后端
一只游鱼15 分钟前
我的第一个微服务项目cy-fang1.0
java·后端·spring cloud
JavaGuide16 分钟前
对标MinIO!全新一代分布式文件系统诞生!
数据库·后端
缘来是庄18 分钟前
invalid comparison
java·spring boot·mybatis
喵个咪19 分钟前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:基于 Ent 从零实现新服务
后端·go·orm
atwednesday25 分钟前
分布式事务及实现方案
后端
文心快码BaiduComate27 分钟前
Comate Spec模式实测:让AI编程更精准可靠
前端·后端·前端框架
哈哈哈笑什么32 分钟前
3 次生产系统崩溃复盘:Java 后端从踩坑到封神的排查优化之路
java·后端·性能优化
ServBay33 分钟前
MongoDB 的文档模型与 CRUD 实战
数据库·后端·mongodb
哈哈哈笑什么37 分钟前
Sleuth+Zipkin 与 OpenSearch 结合是企业级分布式高并发系统的“王炸组合”
分布式·后端·spring cloud