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


本文关键字:最大连接数、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 的握手失败。

easy connect无法连接到服务端_故障分析 | 一次因为超过最大连接数的登陆限制相关推荐

  1. c++ ftp服务端_重磅干货||五万字长文总结:C/C++ 知识(下篇)

    结识更多同行,共同讨论"嵌入式"技术.欢迎添加社区客服微信,备注发送"电源+公司名(学校)+职位(专业)"拉您入群. 回顾上篇:五万字长文总结:C/C++ 知识 ...

  2. 学习如何使用电脑客户端和ESP8266客户端来连接MQTT服务端以及订阅主题发送主题操作

    MQTT原理与应用 学习如何使用电脑客户端和ESP8266客户端来连接MQTT服务端 本文章学习借鉴于太极创客团队,以表感谢.官网[http://www.taichi-maker.com/] 文章目录 ...

  3. 1.3 连接MQTT服务端

    MQTT客户端之间要想实现通讯,必须要通过MQTT服务端.因此MQTT客户端无论是发布消息还是订阅消息,首先都要连接MQTT服务端.下面我们看一下MQTT客户端连接服务端的详细过程. MQTT客户端连 ...

  4. Java中使用Jedis连接Redis服务端时提示:JedisConnectionException: Failed connecting

    场景 Centos中Redis的下载编译与安装(超详细): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103967334 Re ...

  5. springboot socket服务端_从零开始学SpringBoot之Spring Boot WebSocket:编码分析

    前言: 在上一篇文章中讲到了WebSocket的原理,这节中我们先简单的编码分析下,这样有助于在之后的实战编码. 说明: (1)编码中使用的Spring Boot版本是:1.5.8: (2) 使用We ...

  6. Easy Connect无法连接的情况,当前IE代理启用了自动配置脚本,不允许使用CS客户端登录

    这是王秀秀的第16篇博客 Easy Connect无法连接的情况,当前IE代理启用了自动配置脚本,不允许使用CS客户端登录 由于最近需要访问校园网,所以需要使用easy connect 进行连接.可是 ...

  7. oracle11g服务器端下载,安装_oracle11G_客户端_服务端_链接_oracle

    在开始之前呢,有一些注细节需要注意,oracle11G_客户端_和_服务端, 分为两种   一种是  开发者使用    一种是  BDA  自己使用(同时也需要根据自己 PC 的系统来做_win7_与 ...

  8. Easy Connect 无法连接服务器,请检查网络是否可用

    问题描述:Easy Connect 无法连接服务器,请检查网络是否可用.且尝试在IE浏览器中原址打不开. 解决办法:没有直接访问原址,而是在biying窗口复制网址,打开对应链接,输入账号,显示链接成 ...

  9. java实现mqtt服务端_基于Swoole使用MQTT协议连接阿里云物联网平台设备实现消息订阅

    阿里云物联网平台为设备提供安全可靠的连接通信能力,支撑设备数据采集上云,我们这里认为阿里云物联网平台是 MQTT 服务端,那么我们自己的设备作为客户端,应该如何实现消息订阅? 阿里云没有提供 PHP ...

最新文章

  1. JavaScript封装一个注册函数解决兼容问题
  2. java qq登陆api_java方式接入QQ登录
  3. CES新观察:智能应用全面开花 “陆海空”新品值得关注
  4. Android应用插件式开发解决方法[转]
  5. 机器学习模型 知乎_机器学习中有哪些模型?
  6. jeecg团队招新人(5人)
  7. 2021快手美妆行业数据营销报告
  8. 20190724算法题存档
  9. MySQL一个语句查出各种整形占用字节数及最大最小值
  10. 单片机原理及应用 C51编程 proteus仿真
  11. Python+vue设计并实现了宾馆酒店客房管理系统django flask
  12. QTimer::singleShot
  13. 合天网安实验室-sql注入实验一
  14. android短信uri,Android开发,URI 如:发短信,发彩信,调用通讯录等
  15. 惠群计算机科技,电脑报专访:探索新视角,再造多元化的宏碁
  16. 1.1.Perl环境安装-Windows下环境安装
  17. 杭州保俶塔实验机器人_资讯 | 智慧与挑战!2017年西湖区中小学生科技节智能机器人比赛成绩出炉啦...
  18. jsp无图片时显示默认图片解决方案
  19. PHP 获取本月与上个月的第一天和最后一天
  20. EXT4分区工具MiniTool Partition Wizard Home Edition

热门文章

  1. bootstrap中日历组件只显示年月
  2. 一道面试题:用多线程求1000以内的素数有多少个?并给出消耗时间
  3. 2016-Fiddler
  4. linux使用mount命令挂载、umount命令取消挂载
  5. [转载] OpenCV-Python 图像处理(二):图像的读取、显示与保存
  6. [转载] Python str方法
  7. 机器学习-数据科学库-day6
  8. Critical Warning: Synopsys Design Constraints File file notfound: 'CMTT.sdc'. A Synopsys Design Cons
  9. ffmpeg下载rtmp flv
  10. java异常处理和自定义异常利用try和catch让程序继续下去(回来自己再写个例子试运行下)...