spring boot mysql 8小时连接超时

2024-09-05 23:08

本文主要是介绍spring boot mysql 8小时连接超时,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用springboot 线程池连接MySQL时,mysql数据库wait_timeout 为8个小时,所以程序第二天发现报错,在url配置了 autoReconnect=true 也不行,正确配置以下

 

 

#验证连接的有效性spring.datasource.test-while-idle=true#获取连接时候验证,会影响性能
spring.datasource.test-on-borrow=truespring.datasource.validation-query=SELECT 1 FROM DUAL#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.time-between-eviction-runs-millis=300000#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.min-evictable-idle-time-millis=1800000

 

 

 

 

 

 

================  

SpringBoot配置属性之DataSource  

https://segmentfault.com/a/1190000004316491

datasource

  • spring.dao.exceptiontranslation.enabled是否开启PersistenceExceptionTranslationPostProcessor,默认为true

  • spring.datasource.abandon-when-percentage-full设定超时被废弃的连接占到多少比例时要被关闭或上报

  • spring.datasource.allow-pool-suspension使用Hikari pool时,是否允许连接池暂停,默认为: false

  • spring.datasource.alternate-username-allowed是否允许替代的用户名.

  • spring.datasource.auto-commit指定updates是否自动提交.

  • spring.datasource.catalog指定默认的catalog.

  • spring.datasource.commit-on-return设置当连接被归还时,是否要提交所有还未完成的事务

  • spring.datasource.connection-init-sql指定连接被创建,再被添加到连接池之前执行的sql.

  • spring.datasource.connection-init-sqls使用DBCP connection pool时,指定初始化时要执行的sql

  • spring.datasource.connection-properties.[key]在使用DBCP connection pool时指定要配置的属性

  • spring.datasource.connection-test-query指定校验连接合法性执行的sql语句

  • spring.datasource.connection-timeout指定连接的超时时间,毫秒单位.

  • spring.datasource.continue-on-error在初始化数据库时,遇到错误是否继续,默认false

  • spring.datasource.data指定Data (DML)脚本

  • spring.datasource.data-source-class-name指定数据源的全限定名.

  • spring.datasource.data-source-jndi指定jndi的地址

  • spring.datasource.data-source-properties.[key]使用Hikari connection pool时,指定要设置的属性

  • spring.datasource.db-properties使用Tomcat connection pool,指定要设置的属性

  • spring.datasource.default-auto-commit是否自动提交.

  • spring.datasource.default-catalog指定连接默认的catalog.

  • spring.datasource.default-read-only是否设置默认连接只读.

  • spring.datasource.default-transaction-isolation指定连接的事务的默认隔离级别.

  • spring.datasource.driver-class-name指定driver的类名,默认从jdbc url中自动探测.

  • spring.datasource.fair-queue是否采用FIFO返回连接.

  • spring.datasource.health-check-properties.[key]使用Hikari connection pool时,在心跳检查时传递的属性

  • spring.datasource.idle-timeout指定连接多久没被使用时,被设置为空闲,默认为10ms

  • spring.datasource.ignore-exception-on-pre-load当初始化连接池时,是否忽略异常.

  • spring.datasource.init-sql当连接创建时,执行的sql

  • spring.datasource.initial-size指定启动连接池时,初始建立的连接数量

  • spring.datasource.initialization-fail-fast当创建连接池时,没法创建指定最小连接数量是否抛异常

  • spring.datasource.initialize指定初始化数据源,是否用data.sql来初始化,默认: true

  • spring.datasource.isolate-internal-queries指定内部查询是否要被隔离,默认为false

  • spring.datasource.jdbc-interceptors使用Tomcat connection pool时,指定jdbc拦截器,分号分隔

  • spring.datasource.jdbc-url指定JDBC URL.

  • spring.datasource.jmx-enabled是否开启JMX,默认为: false

  • spring.datasource.jndi-name指定jndi的名称.

  • spring.datasource.leak-detection-threshold使用Hikari connection pool时,多少毫秒检测一次连接泄露.

  • spring.datasource.log-abandoned使用DBCP connection pool,是否追踪废弃statement或连接,默认为: false

  • spring.datasource.log-validation-errors当使用Tomcat connection pool是否打印校验错误.

  • spring.datasource.login-timeout指定连接数据库的超时时间.

  • spring.datasource.max-active指定连接池中最大的活跃连接数.

  • spring.datasource.max-age指定连接池中连接的最大年龄

  • spring.datasource.max-idle指定连接池最大的空闲连接数量.

  • spring.datasource.max-lifetime指定连接池中连接的最大生存时间,毫秒单位.

  • spring.datasource.max-open-prepared-statements指定最大的打开的prepared statements数量.

  • spring.datasource.max-wait指定连接池等待连接返回的最大等待时间,毫秒单位.

  • spring.datasource.maximum-pool-size指定连接池最大的连接数,包括使用中的和空闲的连接.

  • spring.datasource.min-evictable-idle-time-millis指定一个空闲连接最少空闲多久后可被清除.

  • spring.datasource.min-idle指定必须保持连接的最小值(For DBCP and Tomcat connection pools)

  • spring.datasource.minimum-idle指定连接维护的最小空闲连接数,当使用HikariCP时指定.

  • spring.datasource.name指定数据源名.

  • spring.datasource.num-tests-per-eviction-run指定运行每个idle object evictor线程时的对象数量

  • spring.datasource.password指定数据库密码.

  • spring.datasource.platform指定schema要使用的Platform(schema-${platform}.sql),默认为: all

  • spring.datasource.pool-name指定连接池名字.

  • spring.datasource.pool-prepared-statements指定是否池化statements.

  • spring.datasource.propagate-interrupt-state在等待连接时,如果线程被中断,是否传播中断状态.

  • spring.datasource.read-only当使用Hikari connection pool时,是否标记数据源只读

  • spring.datasource.register-mbeans指定Hikari connection pool是否注册JMX MBeans.

  • spring.datasource.remove-abandoned指定当连接超过废弃超时时间时,是否立刻删除该连接.

  • spring.datasource.remove-abandoned-timeout指定连接应该被废弃的时间.

  • spring.datasource.rollback-on-return在归还连接时,是否回滚等待中的事务.

  • spring.datasource.schema指定Schema (DDL)脚本.

  • spring.datasource.separator指定初始化脚本的语句分隔符,默认: ;

  • spring.datasource.sql-script-encoding指定SQL scripts编码.

  • spring.datasource.suspect-timeout指定打印废弃连接前的超时时间.

  • spring.datasource.test-on-borrow当从连接池借用连接时,是否测试该连接.

  • spring.datasource.test-on-connect创建时,是否测试连接

  • spring.datasource.test-on-return在连接归还到连接池时是否测试该连接.

  • spring.datasource.test-while-idle当连接空闲时,是否执行连接测试.

  • spring.datasource.time-between-eviction-runs-millis指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔

  • spring.datasource.transaction-isolation指定事务隔离级别,使用Hikari connection pool时指定

  • spring.datasource.url指定JDBC URL.

  • spring.datasource.use-disposable-connection-facade是否对连接进行包装,防止连接关闭之后被使用.

  • spring.datasource.use-equals比较方法名时是否使用String.equals()替换==.

  • spring.datasource.use-lock是否对连接操作加锁

  • spring.datasource.username指定数据库名.

  • spring.datasource.validation-interval指定多少ms执行一次连接校验.

  • spring.datasource.validation-query指定获取连接时连接校验的sql查询语句.

  • spring.datasource.validation-query-timeout指定连接校验查询的超时时间.

  • spring.datasource.validation-timeout设定连接校验的超时时间,当使用Hikari connection pool时指定

  • spring.datasource.validator-class-name用来测试查询的validator全限定名.

  • spring.datasource.xa.data-source-class-name指定数据源的全限定名.

  • spring.datasource.xa.properties指定传递给XA data source的属性

JPA

  • spring.jpa.database指定目标数据库.

  • spring.jpa.database-platform指定目标数据库的类型.

  • spring.jpa.generate-ddl是否在启动时初始化schema,默认为false

  • spring.jpa.hibernate.ddl-auto指定DDL mode (none, validate, update, create, create-drop). 当使用内嵌数据库时,默认是create-drop,否则为none.

  • spring.jpa.hibernate.naming-strategy指定命名策略.

  • spring.jpa.open-in-view是否注册OpenEntityManagerInViewInterceptor,绑定JPA EntityManager到请求线程中,默认为: true

  • spring.jpa.properties添加额外的属性到JPA provider.

  • spring.jpa.show-sql是否开启sql的log,默认为: false

jooq

  • spring.jooq.sql-dialect指定JOOQ使用的SQLDialect,比如POSTGRES.

h2

  • spring.h2.console.enabled是否开启控制台,默认为false

  • spring.h2.console.path指定控制台路径,默认为: /h2-console

JTA

  • spring.jta.allow-multiple-lrc是否允许 multiple LRC,默认为: false

  • spring.jta.asynchronous2-pc指定两阶段提交是否可以异步,默认为: false

  • spring.jta.background-recovery-interval指定多少分钟跑一次recovery process,默认为: 1

  • spring.jta.background-recovery-interval-seconds指定多久跑一次recovery process,默认: 60

  • spring.jta.current-node-only-recovery是否过滤掉其他非本JVM的recovery,默认为: true

  • spring.jta.debug-zero-resource-transaction是否追踪没有使用指定资源的事务,默认为: false

  • spring.jta.default-transaction-timeout设定默认的事务超时时间,默认为60

  • spring.jta.disable-jmx是否禁用jmx,默认为false

  • spring.jta.enabled是否开启JTA support,默认为: true

  • spring.jta.exception-analyzer设置指定的异常分析类

  • spring.jta.filter-log-status使用Bitronix Transaction Manager时,是否写mandatory logs,开启的话,可以节省磁盘空间,但是调试会复杂写,默认为false

  • spring.jta.force-batching-enabled使用Bitronix Transaction Manager时,是否批量写磁盘,默认为true.

  • spring.jta.forced-write-enabled使用Bitronix Transaction Manager时,是否强制写日志到磁盘,默认为true

  • spring.jta.graceful-shutdown-interval当使用Bitronix Transaction Manager,指定shutdown时等待事务结束的时间,超过则中断,默认为60

  • spring.jta.jndi-transaction-synchronization-registry-name当使用Bitronix Transaction Manager时,在JNDI下得事务同步registry,默认为: java:comp/TransactionSynchronizationRegistry

  • spring.jta.jndi-user-transaction-name指定在JNDI使用Bitronix Transaction Manager的名称,默认:java:comp/UserTransaction

  • spring.jta.journal当使用Bitronix Transaction Manager,指定The journal是否disk还是null还是一个类的全限定名,默认disk

  • spring.jta.log-dirTransaction logs directory.

  • spring.jta.log-part1-filename指定The journal fragment文件1的名字,默认: btm1.tlog

  • spring.jta.log-part2-filename指定The journal fragment文件2的名字,默认: btm2.tlog

  • spring.jta.max-log-size-in-mb指定journal fragments大小的最大值. 默认: 2M

  • spring.jta.resource-configuration-filename指定Bitronix Transaction Manager配置文件名.

  • spring.jta.server-id指定Bitronix Transaction Manager实例的id.

  • spring.jta.skip-corrupted-logs是否忽略corrupted log files文件,默认为false.

  • spring.jta.transaction-manager-id指定Transaction manager的唯一标识.

  • spring.jta.warn-about-zero-resource-transaction当使用Bitronix Transaction Manager时,是否对没有使用指定资源的事务进行警告,默认为: true

这篇关于spring boot mysql 8小时连接超时的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140325

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.