故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]作者:王翔飞 爱可生研发团队测试成员,负责数据库管理平台的测试工作。 本文来源:原创投稿 *爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。 本文关键字:最大连接数、TC…

故障分析 | 一次因为超过最大连接数的登陆限制

作者:王翔飞 爱可生研发团队测试成员,负责数据库管理平台的测试工作。 本文来源:原创投稿 *爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。


本文关键字:最大连接数、TCP协议、MySQL协议、参数配置

现象

在测试某功能时,将 mysql 的最大连接数设置为 120,使用 sysbench 并发 200 插入数据,

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

上述错误是预期内的结果,因为 sysbench 的 200 个并发超过了 mysql 实例最大连接数;

随后,修改 sysbench 并发数为 100(小于最大连接数),再次插入数据,失败报错,并发数已经小于最大连接数了,为什么还报错,报错信息如下:

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

使用用户 test 单独登录实例,和上面报一样的错误:

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

之前正常的可以登录的用户 test,现在无法登录了。

原因和解决方法

起初,并不了解是什么原因造成的登录失败。查询官网文档了解到,是用户的错误的连接数超过了设置的最大值,这个最大值参数是 max_connect_errors。

解决方法很简单:执行 flush hosts

官网解释:https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_max_connect_errors

分析

对于这个参数 max_connect_errors 之前并不了解,查阅网上文档提到,使用错误密码多次登录并不能模拟失败连接。尝试将此参数修改为 2,然后使用错误密码登录 2 次,后续再登录依然成功。看来使用错误密码确实不能模拟失败连接。

查阅官网文档了解到,在 Performance Schema 库表 host_cache 里会保存客户端的连接信息,其中字段 SUM_CONNECT_ERRORS 就是记录连接的错误次数,一旦 SUM_CONNECT_ERRORS 的值达到 max_connect_errors 设定的值,来自此客户端的连接就会被阻止。SUM_CONNECT_ERRORS 的官网描述:The number of connection errors that are deemed “blocking” (assessed against the max_connect_errors system variable). Only protocol handshake errors are counted, and only for hosts that passed validation (HOST_VALIDATED = YES).

可以看到这里指的是协议握手错误的次数。

官网链接: https://dev.mysql.com/doc/refman/5.7/en/host-cache-table.html

下面使用 telnet 来模拟协议的握手错误次数:

配置最大错误连接错误数为 2,查看库表 Performance Schema.host_cache 的 SUM_CONNECT_ERRORS

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

这里 SUM_CONNECT_ERRORS 初始值为 0;

注:另一个参数 count_authentication_errors 是尝试错误密码登录的次数(这里的 2 就是之前尝试错误密码登录的次数)。

在客户端主机上使用 telnet 尝试 2 次端口探测,

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

再次查看该主机的 SUM_CONNECT_ERRORS 变成了 2。

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

此时问题复现,客户端登录实例被拒绝,因为错误连接次数达到了最大值 2。

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

回到本文最开始的问题,sysbench 并发 200 超过最大连接数 max_connections=120 时,

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

由于 max_connect_errors 的缺省值是 100,sysbench 并发 200 造成了 109 个错误连接,这就超过了错误连接的最大值,所以后续连接就报错了。

另外,为什么错误连接数 SUM_CONNECT_ERRORS 是 109,是因为此环境实例已经存在来自其他客户端的 11 个正常连接(通过 show processlist 可见),那么只剩下 120-11=109 个可用连接,sysbench 的 200 个并发,只接受了 109 个然后就协议握手失败,所以造成了 109 个错误连接。

延伸

官网提到错误连接指的是协议的握手失败次数,并未明确说明是哪个协议,是 TCP/IP 还是应用层的 MySQL 协议?

对于 TCP/IP 通信,首先是 TCP 协议的三次握手,因为客户端已经成功收到了服务端返回的报错:error 1040: Too many connections,TCP 握手已经成功完成了,所以这里的协议应该指的是 MySQL 的握手协议。

这里可以通过抓包来验证:

故障分析 | 一次因为超过最大连接数的登陆限制[亲测有效]

上述前三个包是完整的 TCP 握手协议包,已经完成了 TCP 的握手协议,后面 MySQL 协议服务端发送完 HandShake 信息之后双方就关闭了连接,客户端并未继续发送登录认证包,造成 MySQL 的协议握手失败。所以这里指的是 MySQL 的协议握手失败次数。

针对上面利用 telnet 来模拟协议握手失败的例子,由于 telnet 只是发送了 TCP 的握手包,并不会发送 MySQL 登录认证包,服务器端等待 10 秒(mysql 的 connect_timeout=10)就关闭了连接,所以才造成 MySQL 的握手失败。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/7431.html

(0)
上一篇 2023-03-20 14:00
下一篇 2023-03-20

相关推荐

  • 以mat文件用什么打开

    以mat文件用什么打开在科学研究和数据分析的领域中,MATLAB是非常常用的工具之一。MATLAB可以生成的数据文件格式广泛,其中.mat文件是其中的一种常用格式。MATLAB生成的mat文件是二进制文件,包含了由该程序生成的数据结构和变量。然而,.mat文件是由MATLAB特定的二进制格式编写的,不是所有软件都能够正确解释它们,因此需要特定的工具来读取这种文件格式。

    2024-09-21
    16
  • Python注释的使用与规范

    Python注释的使用与规范Python作为目前最流行的编程语言之一,在各个领域都有广泛的应用。然而,当Python代码量越来越大,难以一下子理解代码的含义时,注释便显得尤为重要。注释不仅方便其他开发者了解代码逻辑,也可以帮助自己快速回忆代码的意图。在本文中,我们将讨论Python注释的使用与规范。

    2024-04-17
    79
  • Python中的List Index功能详解

    Python中的List Index功能详解List(列表)是Python中的基本数据类型之一,它表示有序、可变、可重复的元素集合。每个元素在列表中都有唯一的索引,可以通过索引来访问、修改和删除列表中的元素。而List Index功能就是用来操作这些索引的。

    2023-12-28
    124
  • Python实现的平方根函数

    Python实现的平方根函数平方根是数学中一个非常重要的概念,它在科学计算和工业应用中都有广泛的应用。在Python中,实现平方根函数非常方便。本文将介绍如何使用Python实现平方根函数,并从多个方面展开阐述。

    2023-12-10
    112
  • 大数据Hadoop之——任务调度器Oozie(Oozie环境部署)「终于解决」

    大数据Hadoop之——任务调度器Oozie(Oozie环境部署)「终于解决」一、概述 Oozie是一个基于工作流引擎的开源框架,依赖于MapReduce来实现,是一个管理 Apache Hadoop 作业的工作流调度系统。是由Cloudera公司贡献给Apache的,它能够提

    2023-05-18
    151
  • Bug: 删除中间某条记录后/删除最后一条记录再添加 ,auto-increment的自动增长不连续「终于解决」

    Bug: 删除中间某条记录后/删除最后一条记录再添加 ,auto-increment的自动增长不连续「终于解决」问题描述: 现在我删除最后一条记录: 再加上一条新记录: 发现,记录的id不是4而是5. 问题解释: 这是因为作为主键而不得有重复的id值,就算是删掉了,因为设置了auto_increment,为了保

    2023-02-17
    151
  • 什么是Druid_USART指的是

    什么是Druid_USART指的是一、Druid是什么 Druid 单词来源于西方古罗马的神话人物,中文常常翻译成德鲁伊。 玩过魔兽世界,暗黑破坏神,Dota,炉石传说,Dota自走棋的朋友,对这个词一定不陌生。 本文中所介绍的Dru

    2023-01-25
    152
  • mysql必知必会-创建高级联结[通俗易懂]

    mysql必知必会-创建高级联结[通俗易懂]使用表别名 使用别名引用被检索的表列 别名除了用于列名和计算字段外,SQL还允许给表名起别名。这样做 有两个主要理由: + 缩短SQL语句; + 允许在单条 SELECT 语句中多次使用相同的表。 可

    2023-01-25
    142

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注