MySQL 连接控制(Connection Control)

本文介绍了如何在MySQL中安装并配置连接控制插件,以防止DDoS攻击和暴力破解。通过设置阈值和延迟,插件能监控并限制连续失败连接,确保数据库安全。
摘要由CSDN通过智能技术生成

MySQL连接控制是一个安全插件,当客户端出现指定次数的连接失败时(密码错误),之后的每次连接请求的响应都会逐渐增加延迟,此插件可以帮助数据库抵御类似DDOS攻击或暴力破解密码。

一、安装连接控制插件

连接控制插件connection_control.so默认安装在插件目录,你可以通过select @@plugin_dir查找该目录在文件系统上的路径:

select @@plugin_dir;

在这里插入图片描述

需要安装的插件分为2个部分:

  • connection_cotrol,负责检查连接连接次数,并在检测到超过指定失败次数时增加下一次响应延时。
  • connection_control_failed_login_attempts,在information_schema下新增connection_control_failed_login_attempts表记录详细的连接失败的用户及尝试次数信息。

执行下列命令安装连接控制插件:

install plugin connection_control soname 'connection_control.so';
install plugin connection_control_failed_login_attempts soname 'connection_control.so';

在这里插入图片描述

通过show plugins检查插件是否安装成功,status为ACTIVE说明成功:

show plugins;

在这里插入图片描述

为了重启后可以自动加载插件,建议将下面配置放到my.cnf的[mysqld]模块中:

[mysqld]
plugin-load-add=connection_control.so

在这里插入图片描述

二、连接控制参数配置

插件安装完成后,我们可以通过如下参数进行连接控制:

  • connection_control_failed_connections_threshold,控制增加相应延迟前的最大失败次数。
  • connection_control_min_connection_delay,最小增加响应延迟,单位是毫秒。
  • connection_control_max_connection_delay,最大增加响应延迟,单位是毫秒。

下面SQL设置增加延迟前最多可以失败3次,最小增加延迟为1000毫秒(随着失败次数变多,延迟会逐渐变大):

set global connection_control_failed_connections_threshold=3;
set global connection_control_min_connection_delay=1000;

在这里插入图片描述

这里同样建议将配置写到my.cnf文件中:

[mysqld]
plugin-load-add=connection_control.so
connection_control_failed_connections_threshold=3
connection_control_min_connection_delay=1000

在这里插入图片描述

三、效果测试

完成上面的配置后,我们尝试用错误的密码去不停连接数据库,这里循环10次。通过测试发现第4次开始,数据库响应的时间开始出现延迟,并且随着尝试次数变多,延迟越来越大:

for i in `seq 1 10`
do
  time mysql -uroot -p123 2>&1 >/dev/null | grep real
done

在这里插入图片描述

状态变量connection_control_delay_generated记录数据库为失败尝试增加相应延迟的次数,上面的示例中,从第4次开始,所有连接尝试都加了延迟,因此变量值是7:

show global status like 'connection_control_delay_generated';

在这里插入图片描述

从information_schema.connection_control_failed_login_attempts可以查询到连接失败的用户及次数信息,这里显示root用户有10次尝试登陆失败了:

select * from information_schema.connection_control_failed_login_attempts;

在这里插入图片描述

如果要重置失败尝试次数,只需要再次给变量connection_control_failed_connections_threashold赋值即可,状态变量connection_control_delay_generated值也会归零:

set global connection_control_failed_connections_threshold=3;
show global status like 'connection_control_delay_generated';

在这里插入图片描述

以上就是连接控制插件的配置及使用,其可以有效防止数据库密码被暴力破解或者高频连接请求导致数据库资源被大量消耗(类DDOS攻击)。

  • 24
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值