如果你没有修改过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后最好都记得修改它。
设置MySQL里的wait_timeout
-
react native开发遇到的问题二
集成react-nativ-webview,出现这样的错误"RNCWebView" was not found in the UIManager
-
/lib64/libstdc++.so.6: version `CXXABI_1.3.9' not found
canvas在centos上安装失败的解决办法
-
react native 集成高德地图 tagged-pointers 后退闪退
记录一次react native集成高德地图闪退的问题,一个小问题解决废了 老鼻子劲了,解决方案添加android:allowNativeHeapPointerTagging="false"
-
ios "AMapMarker" was not found in the UIManager
ios手动添加 pod 'react-native-amap3d', path: '../node_modules/react-native-amap3d'解决问题
-
window如何正确安装node-cavnas不报错
每次安装node-canvas都报错,安装不成功,这次记录下来
-
一篇文章学会使用vue3+Eslint+Prettier进行代码格式化和错误检测
Eslint编写代码过程中检测代码,主动检测代码问题,git提交中检测大妈问题
-
nuxt3+vite+vue3如何使用eslint和prettier
使用nuxt3 vite vue3技术,搭建项目全过程,里面用到很多知识点和开源工具。
-
强制杀死nginx进程简单粗暴
nginx: [error] open() "/run/nginx.pid" failed (2: No such file or directory),最简单的办法,杀死nginx进程,重启
-
android 如何查看包被那个包依赖
迅速查看Gradle 查看包的依赖关系,解决冲突,或者找到不必要的包依赖
-
vue用jspdf 把html转成pdf教程并解决乱码问题
最终我发现这个乱码问题不好解决,得改许多东西,如果网页不是自己的,最好不要使用这种方案,网页是自己的得严格要求网页格式