mysql 参数max_connect_errors研究

1.在server端设置max_connect_errors=3,超过3次连接错误就block

mysql> set global max_connect_errors=3;

Query OK, 0 rows affected (0.00 sec)

mysql> show variables like 'max_connect_errors';

+--------------------+-------+

| Variable_name | Value |

+--------------------+-------+

| max_connect_errors | 3 |

+--------------------+-------+

1 row in set (0.00 sec)

2.在客户端10.153.56.25连接server,不输入密码四次,第五次依旧连接上了

mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root'@'10.153.56.25' (using password: NO) \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root'@'10.153.56.25' (using password: NO) \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root'@'10.153.56.25' (using password: NO) \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root'@'10.153.56.25' (using password: NO) \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \\g. Your MySQL connection id is 17 Server version: 5.7.26-log MySQL Community Server (GPL) Copyright (c) 2000, 2023, Oracle and/or its affiliates. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\\h' for help. Type '\\c' to clear the current input statement. mysql\> 3.在server端看到10.153.56.25 HOST_VALIDATED: YES , SUM_CONNECT_ERRORS: 0 , COUNT_HOST_BLOCKED_ERRORS: 0 COUNT_AUTHENTICATION_ERRORS: 4 说明密码错误并不数据连接错误 mysql\> select \* from performance_schema.host_cache\\G \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 1. row \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* IP: 10.153.56.25 HOST: NULL HOST_VALIDATED: YES SUM_CONNECT_ERRORS: 0 COUNT_HOST_BLOCKED_ERRORS: 0 COUNT_NAMEINFO_TRANSIENT_ERRORS: 0 COUNT_NAMEINFO_PERMANENT_ERRORS: 1 COUNT_FORMAT_ERRORS: 0 COUNT_ADDRINFO_TRANSIENT_ERRORS: 0 COUNT_ADDRINFO_PERMANENT_ERRORS: 0 COUNT_FCRDNS_ERRORS: 0 COUNT_HOST_ACL_ERRORS: 0 COUNT_NO_AUTH_PLUGIN_ERRORS: 0 COUNT_AUTH_PLUGIN_ERRORS: 0 COUNT_HANDSHAKE_ERRORS: 0 COUNT_PROXY_USER_ERRORS: 0 COUNT_PROXY_USER_ACL_ERRORS: 0 COUNT_AUTHENTICATION_ERRORS: 4 COUNT_SSL_ERRORS: 0 COUNT_MAX_USER_CONNECTIONS_ERRORS: 0 COUNT_MAX_USER_CONNECTIONS_PER_HOUR_ERRORS: 0 COUNT_DEFAULT_DATABASE_ERRORS: 0 COUNT_INIT_CONNECT_ERRORS: 0 COUNT_LOCAL_ERRORS: 0 COUNT_UNKNOWN_ERRORS: 0 FIRST_SEEN: 2025-02-13 14:26:57 LAST_SEEN: 2025-02-13 14:27:10 FIRST_ERROR_SEEN: 2025-02-13 14:26:57 LAST_ERROR_SEEN: 2025-02-13 14:27:02 1 row in set (0.00 sec) 4.通过telnet 10.153.35.2 3306命令,超过3次后第四次后就报错: Host '10.153.56.25' is blocked because of many connection errors; 正常的mysql -h 10.153.35.2 -u root -p输入密码也被 block了 \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ telnet 10.153.35.2 3306 Trying 10.153.35.2... Connected to 10.153.35.2. Escape character is '\^\]'. N 5.7.26-logM:Nu -A%a-9c2Ubmysql_native_password !#08S01Got packets out of orderConnection closed by foreign host. \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ telnet 10.153.35.2 3306 Trying 10.153.35.2... Connected to 10.153.35.2. Escape character is '\^\]'. N 5.7.26-logS8IQA-CNOG\\+\|mSCmysql_native_password !#08S01Got packets out of orderConnection closed by foreign host. \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ telnet 10.153.35.2 3306 Trying 10.153.35.2... Connected to 10.153.35.2. Escape character is '\^\]'. N 5.7.26-logWd7\[G- -6% "mysql_native_password !#08S01Got packets out of orderConnection closed by foreign host. \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ telnet 10.153.35.2 3306 Trying 10.153.35.2... Connected to 10.153.35.2. Escape character is '\^\]'. jHost '10.153.56.25' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts'Connection closed by foreign host. \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ telnet 10.153.35.2 3306 Trying 10.153.35.2... Connected to 10.153.35.2. Escape character is '\^\]'. jHost '10.153.56.25' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts'Connection closed by foreign host. \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: ERROR 1129 (HY000): Host '10.153.56.25' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts' 5.server端可以看到 SUM_CONNECT_ERRORS: 3 COUNT_HOST_BLOCKED_ERRORS: 3 mysql\> select \* from performance_schema.host_cache\\G \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 1. row \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* IP: 10.153.56.25 HOST: NULL HOST_VALIDATED: YES SUM_CONNECT_ERRORS: 3 COUNT_HOST_BLOCKED_ERRORS: 3 COUNT_NAMEINFO_TRANSIENT_ERRORS: 0 COUNT_NAMEINFO_PERMANENT_ERRORS: 1 COUNT_FORMAT_ERRORS: 0 COUNT_ADDRINFO_TRANSIENT_ERRORS: 0 COUNT_ADDRINFO_PERMANENT_ERRORS: 0 COUNT_FCRDNS_ERRORS: 0 COUNT_HOST_ACL_ERRORS: 0 COUNT_NO_AUTH_PLUGIN_ERRORS: 0 COUNT_AUTH_PLUGIN_ERRORS: 0 COUNT_HANDSHAKE_ERRORS: 3 COUNT_PROXY_USER_ERRORS: 0 COUNT_PROXY_USER_ACL_ERRORS: 0 COUNT_AUTHENTICATION_ERRORS: 4 COUNT_SSL_ERRORS: 0 COUNT_MAX_USER_CONNECTIONS_ERRORS: 0 COUNT_MAX_USER_CONNECTIONS_PER_HOUR_ERRORS: 0 COUNT_DEFAULT_DATABASE_ERRORS: 0 COUNT_INIT_CONNECT_ERRORS: 0 COUNT_LOCAL_ERRORS: 0 COUNT_UNKNOWN_ERRORS: 0 FIRST_SEEN: 2025-02-13 14:26:57 LAST_SEEN: 2025-02-13 14:33:15 FIRST_ERROR_SEEN: 2025-02-13 14:26:57 LAST_ERROR_SEEN: 2025-02-13 14:33:15 1 row in set (0.00 sec) 6.解决办法就是在server端执行flush hosts; mysql\> flush hosts; Query OK, 0 rows affected (0.00 sec) mysql\> select \* from performance_schema.host_cache\\G Empty set (0.00 sec) 可以看到10.153.56.25这个client又可以连接了 \[mysql@t3-tksbscms-tkcms-db-mysql01-ma01 bin\]$ mysql -h 10.153.35.2 -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \\g. Your MySQL connection id is 24 Server version: 5.7.26-log MySQL Community Server (GPL) Copyright (c) 2000, 2023, Oracle and/or its affiliates. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\\h' for help. Type '\\c' to clear the current input statement. mysql\>

相关推荐
sz-lcw3 小时前
MySQL知识笔记
笔记·mysql·adb
安东尼肉店7 小时前
Android compose屏幕适配终极解决方案
android
2501_916007477 小时前
HTTPS 抓包乱码怎么办?原因剖析、排查步骤与实战工具对策(HTTPS 抓包乱码、gzipbrotli、TLS 解密、iOS 抓包)
android·ios·小程序·https·uni-app·iphone·webview
Java-xy²8 小时前
AlmaLinux release 9.6服务器离线安装MySQL8.0.27详细步骤
运维·服务器·adb
feiyangqingyun8 小时前
基于Qt和FFmpeg的安卓监控模拟器/手机摄像头模拟成onvif和28181设备
android·qt·ffmpeg
用户20187928316712 小时前
ANR之RenderThread不可中断睡眠state=D
android
煤球王子12 小时前
简单学:Android14中的Bluetooth—PBAP下载
android
小趴菜822712 小时前
安卓接入Max广告源
android
齊家治國平天下12 小时前
Android 14 系统 ANR (Application Not Responding) 深度分析与解决指南
android·anr
ZHANG13HAO12 小时前
Android 13.0 Framework 实现应用通知使用权默认开启的技术指南
android