mysql数据库连接等待时间修改

问题描述:数据库长时间未连接,再次连接的时候已经连接不上了,出错提示如下:

org.hibernate.exception.JDBCConnectionException: Error calling Driver#connect

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

初步判断是程序的数据库连接池已经断开,需要重新连接数据库,此时重新启动服务器(如tomcat)即可。

-------------------------------------------------------------------------------------------------------------

however,若长时间没访问,依然还存在上述问题。

1、登录mysql数据库,查询数据库连接等待时间:show global variables like '%timeout';


不难发现,interactive_timeout、wait_timeout这两个参数都是28800秒,即8小时。interactive_timeout是服务器关闭交互式连接前数据库等待的时间(如在mysql命令输入界面操作数据库),wait_timeout是服务器关闭非交互式连接前等待的时间(如程序通过hibernate连接数据库)。

2、为了保持这两个数据的同步,同时修改这两个参数。

set global wait_time=86400;


3、设置之后发现不起作用,可能是因为版本(笔者用的是mysql5.7)问题,现在直接去修改my.cnf配置文件。


在[mysqld]后面加上两行:

wait_timeout=864000 
interactive_timeout=864000

4、最后重启mysql,完工。

systemctl restart mysql;  或者  service mysqld restart;

至此,修改完成。

-------------------------------------------------------------

by the way,解决这个问题有其他方法,如设置程序定时访问连接池,可编写shell脚本定时触发连接池等等。

如有问题,欢迎指正交流,谢谢。





  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
使用AWS云平台的MySQL数据库连接时,可以按照以下步骤进行: 1. 登录AWS控制台并打开RDS(Relational Database Service)控制台。 2. 在RDS控制台中,选择“实例”选项卡,并点击“创建实例”按钮。 3. 在创建实例页面的“引擎选项”部分,选择MySQL作为数据库引擎。 4. 根据需求,选择相应的实例规格和存储容量。 5. 在“设置”部分,为实例指定一个唯一的标识符和master用户名和密码。这些凭证将用于连接到MySQL数据库。 6. 配置网络和安全组,确保设置可以允许通过所需的端口进行连接。 7. 可选地,可以在“可选配置”部分更改其他设置,如备份保留期限、监控配置和数据库参数。 8. 点击“创建数据库”。等待一段时间,直到实例状态变成“可用”。 9. 连接到MySQL数据库的最常用方法是使用命令行工具或MySQL客户端。在命令行或MySQL客户端中输入以下命令,确保替换相应的主机名、端口、数据库名和凭证: ``` mysql -h <hostname> -P <port> -u <username> -p ``` 其中,`<hostname>`是MySQL实例的终端节点地址,`<port>`是数据库实例的端口,`<username>`和`<password>`是之前在步骤五中设置的凭证。 10. 进入MySQL之后,就可以通过执行SQL语句来管理和查询数据库。 以上是连接到AWS上部署的MySQL数据库的一般步骤。可以根据实际需求和使用的工具进行适当的调整。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值