标签:养成 成功 mysql配置 内容 地方 习惯 完全 问题 timeout
? 最近遇到了一个奇怪的MySql数据库问题,好几次前一天晚上历史数据还正常存储,第二天早上来了看实时数据存储还正常,历史数据不存储了。找了好久也没找到问题。后来仔细想了想,历史数据设置了变化才存储,是不是数据一直不变,就一直没有往数据库写数据,导致MySql的连接太久不用自动断开了。然后就百度了一下,Mysql空闲连接有效时长,一看都说是8个小时就自动断开了。嗯,有点感觉了,应该就是这个原因。
根据查到的资料查看MySql 有两个参数,可以设定空闲连接的有效时长,分别是interactive_timeout
和wait_timeout
,可以在mysql配置文件中设置。根据这一点,可以来进行排查了。
show variables like ‘%timeout%‘;
命令查询以上两个参数的值,一查都是28800(单位是秒,刚好8小时)。interactive_timeout
和wait_timeout
都为100,这样连接100秒不使用就自动关闭了。show status like ‘Threads%‘
命令来查看当前的连接数,查询结果中Threads_connected
即为当前连接数。mysql_query
的返回值,所以数据存储失败的时候没有产生日志。mysql_query
的返回值并产生日志,使每次数据库操作结果都有记录。注意:mysql c/c++ API mysql_query
返回 0为操作成功,非0为操作失败。? 这个问题完全是由于代码写的不严谨造成的,如果代码写的严谨,该校验的地方都加上校验,就算出现问题也能快速定位。吃一堑,长一智以后需要多注意,养成良好的代码习惯。还有就是需要找时间系统的学习一下数据库方面的内容,项目锻炼是能够快速学习一些内容,但是都是用到哪部分学哪部分,不系统。还是需要自己多花时间系统的学。
标签:养成 成功 mysql配置 内容 地方 习惯 完全 问题 timeout
原文地址:https://www.cnblogs.com/ay-a/p/10520425.html