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>

相关推荐
通玄9 小时前
Jetpack Compose 入门系列(六):Navigation 3 页面导航
android
rocpp11 小时前
Android 多语言切换实战:从 Context 到 Android 13 应用语言适配
android·kotlin
释然小师弟12 小时前
Android开发十年:反思与回顾
android·后端·嵌入式
黄林晴14 小时前
用了这么久 Koin Scope,原来一直都用错了?
android·kotlin
爱勇宝1 天前
我做了一个只用来搜歌词的小 App
android·前端·后端
众少成多积小致巨1 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
Coffeeee2 天前
如何使用Glide和Coil加载WebP动图
android·kotlin·glide
Kapaseker2 天前
5 分钟搞懂 Kotlin DSL
android·kotlin
恋猫de小郭2 天前
AI Agent 开发究竟是啥?如何用 AI 开发 Agent ?深入浅出给你一套概念
android·前端·ai编程
黄林晴2 天前
Android 17 正式发布!target 37 一大批旧代码直接不能用了
android