深入浅析MySQL中的警告日志中止连接

  介绍

这期内容当中小编将会给大家带来有关深入浅析MySQL中的警告日志中止连接,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

<强>前言:

有时候,连接MySQL的会话经常会异常退出,错误日志里会看到“有一个错误阅读交流packets"类型的告警。本篇文章我们一起来讨论下该错误可能的原因以及如何来规避。

<强> 1。状态变量Aborted_clients和Aborted_connects

首先我们来了解下Aborted_clients和Aborted_connects这两个状态变量的含义,当出现会话异常退出时,这两个状态值会有变化。根据官方文档描述,总结如下:

深入浅析MySQL中的警告日志中止连接

造成Aborted_connects状态变量增加的可能原因:

    <李>客户端试图访问数据库,但没有数据库的权限。李 <>李客户端使用了错误的密码。李 <>李连接包不包含正确的信息。 <李>获取一个连接包需要的时间超过connect_timeout秒。

深入浅析MySQL中的警告日志中止连接

造成Aborted_clients状态变量增加的可能原因:

    <李>程序退出前,客户机程序没有调用mysql_close()。 <李>客户端睡眠时间超过了wait_timeout或interactive_timeout参数的秒数。李 <>李客户端程序在数据传输过程中突然终止。

简单来说即:数据库会话未能正常连接到数据库,会造成Aborted_connects变量增加。数据库会话已正常连接到数据库但未能正常退出,会造成Aborted_clients变量增加。

<强> 2。有一个错误阅读通信数据包原因分析

哪种情况会导致错误日志中出现“中止连接xxxx db: & # 39; db # 39;用户:& # 39;dbuser& # 39;主持人:& # 39;主机名# 39;(有一个错误阅读通信数据包)”类似告警呢?下面我们根据上面可能的原因来做下具体测试。每次测试要注意状态变量Aborted_clients和Aborted_connects的变化及错误日志记录。

    <李>测试一:错误密码,错误用户李
1。测试前查看状态变量值mysql>显示全球状态像& # 39;中止% & # 39;;+ - - - - - - - - - - - - - - - - - - - - - - - - - + + | Variable_name | | +价值- - - - - - - - - - - - - - - - - - - - - - - - - + + | Aborted_clients | 0 | | Aborted_connects | 0 | + - - - - - - - - - - - - - - - - - - - - - - - - - + +   2.测试过程# mysql -uroot -pwrongpassmysql:[警告]使用一个密码> 1。测试前查看状态变量值mysql>显示全球状态像& # 39;中止% & # 39;;+ - - - - - - - - - - - - - - - - - - - - - - - - - + + | Variable_name | | +价值- - - - - - - - - - - - - - - - - - - - - - - - - + + | Aborted_clients | 0 | | Aborted_connects | 2 | + - - - - - - - - - - - - - - - - - - - - - - - - - + +   2 .手动杀会话测试mysql>显示processlist; +——+——+ + - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - -用户主机| | + | | Id db | | | | |命令时间状态信息+——+ + - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | + | 9根|查询localhost零| | | 0 | |开始显示processlist | | | 10根| localhost零睡眠7 | | | | |零| +——+ + - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + 2行组(0.00秒)mysql>杀死10;查询好,0行影响(0.00秒)   3 .查看状态变化及错误日志mysql>显示全球状态像& # 39;中止% & # 39;;+ - - - - - - - - - - - - - - - - - - - - - - - - - + + | Variable_name | | +价值- - - - - - - - - - - - - - - - - - - - - - - - - + + | Aborted_clients | 1 | | Aborted_connects | 2 | + - - - - - - - - - - - - - - - - - - - - - - - - - + +   结果:Aborted_clients有增加错误日志无记录,类似的,睡眠时间超时后Aborted_clients有增加错误日志中有流产的连接相关记录。

会话异常退出一般会造成中止连接告警,即我们可以通过Aborted_clients状态变量的变化来反映出是否存在异常会话,那么出现“有一个错误阅读通信数据包”类似告警的原因就很明了了,查询相关资料,总结出造成中止连接告警的可能原因如下:

    <李>会话链接未正常关闭,程序没有调用mysql_close()。 <李>睡眠时间超过wait_timeout或interactive_timeout参数的秒数。李 <>李查询数据包大小超过max_allowed_packet数值,造成链接中断。 <李>其他网络或者硬件层面的问题。

    深入浅析MySQL中的警告日志中止连接