wait_timeout 修改
时间: 2023-09-20 16:10:44 浏览: 400
wait_timeout是MySQL数据库系统中的一个参数,它定义了一个客户端与MySQL服务器的连接在没有活动(没有执行SQL语句)的情况下保持的最长时间。当wait_timeout的值比较小时,连接在一段时间后会自动关闭;当wait_timeout的值比较长时,连接则可以保持更长的时间。
根据引用的描述,只修改wait_timeout是无效的,因为在MySQL中,如果同时存在interactive_timeout和wait_timeout这两个参数,系统会以interactive_timeout的值为准。也就是说,不管wait_timeout的值是多少,当查询show variables like '%timeout%';时,显示的两个值都是一样的,并且都是interactive_timeout的值。
因此,如果想要修改wait_timeout的值,需要同时修改interactive_timeout的值,因为修改interactive_timeout的值会影响到wait_timeout的值。修改interactive_timeout可以达到修改wait_timeout的效果。
相关问题
mysql参数 lock_wait_timeout 和 innodb_lock_wait_timeout 的关系,举例说明
`lock_wait_timeout` 和 `innodb_lock_wait_timeout` 都是 MySQL 中用来控制锁等待时间的参数,它们之间有一些关系。
首先,`innodb_lock_wait_timeout` 参数是 InnoDB 引擎的全局参数,它用来控制事务在等待锁时的最长时间,单位是秒。如果一个事务在等待锁的时间超过了该参数设定的时间,那么 InnoDB 引擎就会自动结束该事务并回滚所有修改操作。
而 `lock_wait_timeout` 参数是会话级别的参数,它用来控制当前会话在等待锁时的最长时间,单位也是秒。如果一个事务在等待锁的时间超过了该参数设定的时间,那么 MySQL 就会自动结束该事务并回滚所有修改操作。
需要注意的是,如果 `lock_wait_timeout` 参数的值大于 `innodb_lock_wait_timeout` 参数的值,那么 `innodb_lock_wait_timeout` 参数的值会被覆盖,即事务最长只会等待 `innodb_lock_wait_timeout` 参数设定的时间。
下面举个例子来说明它们之间的关系:
假设有两个事务 A 和 B,它们都需要访问一张名为 `account` 的表,并且事务 A 先于事务 B 开始执行。在事务 A 中,我们执行以下语句:
```sql
begin;
select * from account where id = 1 for update;
-- do some modifications
commit;
```
在事务 B 中,我们执行以下语句:
```sql
begin;
select * from account where id = 1 for update;
```
由于事务 A 在执行期间一直持有 `id=1` 的行的排它锁,因此事务 B 会一直等待,直到事务 A 释放锁为止。
假设 `lock_wait_timeout` 参数被设置为 10 秒,而 `innodb_lock_wait_timeout` 参数被设置为 5 秒。
当事务 B 等待时间超过 5 秒时,InnoDB 引擎会自动检测到这个超时,并自动结束事务 B,回滚事务中的所有修改操作,以避免无限等待锁的情况。
而如果事务 B 等待时间超过 10 秒,MySQL 会自动结束事务 B,并回滚事务中的所有修改操作。
application.yml配置mysql连接 参数:wait_timeout 和wait_timeout
wait_timeout和interactive_timeout是MySQL服务器的系统变量,用于设置一个客户端连接在没有活动时等待服务器关闭连接的时间。这两个变量的默认值都是28800秒(8小时),可以通过修改MySQL配置文件或在连接时设置来更改它们的值。
在application.yml中配置MySQL连接时,可以通过下面的方式设置wait_timeout和interactive_timeout参数:
```
spring:
datasource:
url: jdbc:mysql://localhost:3306/mydatabase?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true&useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&failOverReadOnly=false&maxReconnects=10&connectTimeout=3000&socketTimeout=3000
username: root
password: root
driver-class-name: com.mysql.cj.jdbc.Driver
hikari:
connection-timeout: 3000
validation-timeout: 5000
idle-timeout: 600000
max-lifetime: 1800000
maximum-pool-size: 5
minimum-idle: 1
pool-name: SpringBootJPAHikariCP
tomcat:
max-wait: 10000
max-active: 10
max-idle: 5
min-idle: 2
```
在上面的配置中,可以看到HikariCP和Tomcat连接池都有自己的一些超时配置参数,比如connection-timeout、validation-timeout、idle-timeout、max-lifetime等。这些参数可以根据具体情况进行调整和设置。
另外,在MySQL连接的URL中也可以设置一些超时相关的参数,比如connectTimeout和socketTimeout等。这些参数的含义和作用可以参考MySQL官方文档。
阅读全文