我正在调整我的项目MYSQL数据库,因为有很多人建议我减少
wait_timeout
,但是我不清楚,这个会话变量是否排除查询执行时间,还是包括它?我将其设置为5秒钟,考虑到我有时可能会执行3-5秒钟的查询(是的,速度很慢,它们很少,但它们仍然存在),因此mysql连接至少有1 PHP脚本在MYSQL关闭脚本之前需要-2秒。 在MySQL文档中,没有关于如何开始计算超时以及是否包括执行时间的明确解释。也许您的经验可能会有所帮助。谢谢。
答案 0 :(得分:1)
wait_timeout
session variable是否排除查询执行时间?
是的,它不包括查询时间。
您使用php连接池吗?如果这样,那么5秒就是非常短的wait_time
。延长时间。 60秒可能很好。为什么?连接池的全部目的是保持一些从php到MySQL的空闲连接打开,因此php可以处理来自用户的请求,而无需打开连接。
这是它的工作方式。
wait_timeout
倒计时。wait_timeout
的倒计时,并开始max_execution_time
的倒计时。max_execution_time
的倒计时并重新开始wait_timeout
的倒计时。根据需要重复执行6和7。wait_time
现在正在该连接处于池中时对该连接进行递减计数。wait_time
过期,则php从连接池中将其删除。如果第9步经常发生,那么第5步也必须频繁发生,并且php对请求的响应速度会变慢。您可以通过增加wait_timeout
来减少第9步的发生。
(注意:这是简化的:还规定了连接池中的最大连接数。)
MySQL也有一个interactive_timeout
variable。就像wait_timeout
,但用于通过mysql
命令行程序进行的交互式会话。
当网络用户发出请求然后在完成之前放弃请求时会发生什么?例如,用户可能停止等待报告并转到另一个页面。在某些情况下,主机语言处理器会检测到用户连接的关闭,终止MySQL查询,然后将连接返回到池中。在其他情况下,查询将完成或达到max_execution_timeout
障碍。然后,连接将返回到池中。在所有情况下,wait_timeout
倒数仅在连接打开时处于活动状态,但没有在其上活动的查询。
答案 1 :(得分:0)
MySQL服务器超时的发生可能有多种原因,但最常见的情况是通过封闭的连接向MySQL发送命令时。 MySQL服务器可能由于 idle-timeout (空闲超时)而关闭了连接;但是,在大多数情况下,这是由应用程序错误,网络超时问题(在防火墙,路由器等上)或MySQL服务器重新启动引起的。
从documentation可以明显看出,它不包括查询执行时间。它基本上是两次活动之间允许的最大空闲时间。如果超过该限制,服务器将自动关闭连接。
服务器等待活动的秒数 非交互式连接,然后再关闭它。
来自https://www.digitalocean.com/community/questions/how-to-set-no-timeout-to-mysql:
答案 2 :(得分:0)
根据参考手册,
服务器在关闭连接之前等待连接变为活动状态的时间(秒)。
从根本上讲,您可以容忍某人保留您的资源而无所事事的秒数?在决定采取哪种行动之前,您的“思考时间”可能经常超过5秒。保持自由。对于Web应用程序,某些过程需要5秒钟以上的时间才能运行查询,并且导致它们在5秒钟时终止。默认值为28800秒,这是不合理的。 60秒可能是一个合理的时间,可以预期将完成任何基于Web的过程。如果您的应用程序也在传统的工作环境中使用,那么15分钟的休息时间也不是不合理的。保持开放态度,避免出现“不良反馈”。