如果你没有修改过MySQL的配置,缺省情况下,wait_timeout的初始值是28800。

wait_timeout过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放,拖累系统性能,不过也不能把这个指设置的过小,否则你可 能会遭遇到“MySQL has gone away”之类的问题,通常来说,我觉得把wait_timeout设置为10是个不错的选择,但某些情况下可能也会出问题,比如说有一个CRON脚本, 其中两次SQL查询的间隔时间大于10秒的话,那么这个设置就有问题了(当然,这也不是不能解决的问题,你可以在程序里时不时mysql_ping一下, 以便服务器知道你还活着,重新计算wait_timeout时间):

# vi /etc/my.cnf

[mysqld]
wait_timeout=10

# /etc/init.d/mysql restart

不过这个方法太生硬了,线上服务重启无论如何都应该尽可能避免,看看如何在MySQL命令行里通过SET来设置:

mysql> set global wait_timeout=10;

mysql> show global variables like 'wait_timeout';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| wait_timeout               | 10    |
+----------------------------+-------+

这里一个容易把人搞蒙的地方是如果查询时使用的是show variables的话,会发现设置好像并没有生效,这是因为单纯使用show variables的话就等同于使用的是show session variables,查询的是会话变量,只有使用show global variables,查询的才是全局变量。

网络上很多人都抱怨说他们set global之后使用show variables查询没有发现改变,原因就在于混淆了会话变量和全局变量,如果仅仅想修改会话变量的话,可以使用类似set wait_timeout=10;或者set session wait_timeout=10;这样的语法。

另一个值得注意的是会话变量wait_timeout初始化的问题,这一点在手册里已经明确指出了,我就直接拷贝了:

On thread startup, the session wait_timeout value is initialized from the global wait_timeout value or from the global interactive_timeout value, depending on the type of client (as defined by the CLIENT_INTERACTIVE connect option to mysql_real_connect()).

MySQL大拿Jeremy Zawodny曾在他的文章Fixing Poor MySQL Default Configuration Values里面列出了几个很恶心的MySQL缺省设置,不过没包含wait_timeout,但我觉得它也应该算一个,每次新装MySQL后最好都记得修改它。

摘自:http://www.cnblogs.com/jiunadianshi/articles/2388871.html

最新文章

  1. PHP AJAX JSONP实现跨域请求使用实例
  2. ABP入门系列(3)——领域层创建实体
  3. session跟cookies区别
  4. [OrangePi] Installation on SD Card
  5. C++:主要几种排序算法及其复杂度
  6. 路径问题以及cookie详解
  7. ImageView一例
  8. 浅说CPU并行计算与GPU并行计算
  9. Java对象序列化/反序列化的注意事项
  10. C语言的基本概念
  11. 40个比较重要的Android面试题
  12. 如何在Eclipse中彻底修改一个项目名称
  13. DashBoard创建各种表(二)
  14. The JRE_HOME environment variable is not defined correctly This environment
  15. Git——简说.git目录【五】
  16. C#winform 窗体缩放自适应
  17. gcc dynamic load library
  18. 9.8Django书单列表3.0
  19. opencv3寻找最小包围矩形在图像中的应用-滚动条
  20. 安装Qt5.9

热门文章

  1. LeetCode 【235. Lowest Common Ancestor of a Binary Search Tree】
  2. git相关
  3. Durid(二): 数据集及存储
  4. wordpress google字体和gravatar头像不显示问题处理
  5. ruby的加密方法整理(des rsa加密 加签)
  6. SQLLite 学习笔记
  7. UVA 11082 矩阵解压(网络流建模)
  8. Bellman算法
  9. Xamarin.Froms项目中包含的文件
  10. Flex中设置Camera的视频清晰质量的最佳配合