MySQL 连接控制(Connection Control)

news2024/9/22 19:29:16

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攻击)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1536678.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SQL Server 文件组详解

数据文件组 SQL Server 数据库最常用的存储文件是数据文件和日志文件。 数据文件用于存储数据,由一个主要数据文件(.mdf)和若干个次要数据文件(.ndf)构成;日志文件用于存储事物日志,由.ldf文件…

Simcenter试验仿真技术交流会圆满成功

庭田科技携手西门子工业软件于2024年3月15日在山东职业学院成功举办Simcenter试验及仿真技术交流会。会议邀请到众多技术专家及各行业同仁参与。本次会议以西门子最新试验设备变化为主要方向,通过设备及软件的更新介绍、技术及产品的应用分享,全面搭建起…

怎么批量删除文件名中的括号?

怎么批量删除文件名中的括号?在日常的文件管理中,我们经常会遇到需要批量删除文件名中的括号的情况。这些括号可能是多余的字符,或者干扰了文件名的整体清晰度和统一性。针对这一问题,有许多方法可以轻松实现批量删除文件名中的括…

Linux 文件系统:C语言接口、系统接口

目录 一、文件接口 二、感性理解Linux系统下“一切皆文件” 三、C语言文件接口 1、fopen 2、当前路径 3、fwrite、fprintf、fputs 4、fgets 模拟实现cat命令 5、fscanf 五、系统接口 1、open系统调用 2、write系统调用 例:O_WRONLY 例:O_WR…

webpack5零基础入门-12搭建开发服务器

1.目的 每次写完代码都需要手动输入指令才能编译代码,太麻烦了,我们希望一切自动化 2.安装相关包 npm install --save-dev webpack-dev-server 3.添加配置 在webpack.config.js中添加devServer相关配置 /**开发服务器 */devServer: {host: localhos…

K3镜头擦拭纸工厂的神奇运用

在一个忙碌而充满活力的工厂里,每一天都是一场不同寻常的冒险。工厂的名字叫做“清洁之家”,它是一家专门生产清洁用品的工厂,为世界各地的人们提供着优质的清洁产品。 在这家工厂里,有一支拥有超能力的清洁团队,他们…

ABAP笔记:定义指针,动态指针分配:ASSIGN COMPONENT <N> OF STRUCTURE <结构> TO <指针>.

参考大佬文章学习,总结了下没有提到的点:SAP ABAP指针的6种用法。_abap 指针-CSDN博客 定义指针:其实指针这玩意,就是类似你给个地方,把东西临时放进去,然后指针就是这个东西的替身了,写代码的…

几种常见的IO模型学习

IO模型 IO模型(输入输出模型)是计算机科学中用于描述程序如何处理输入、产生输出以及与外部系统交互的一种概念模型。在操作系统和网络编程中,IO模型尤其重要,因为它们决定了程序如何与文件、网络套接字和其他资源进行通信。以下…

腾讯云COS - 前端上传文件到 COS 跨域问题

问题描述 原因分析 因为我本地的地址是:http://localhost:9528 而发送请求时的地址是:http://132-1307119153.cos.ap-beijing.myqcloud.com/tu.jpg 域名不同,自然而然就出现了跨域的问题! 解决方案 先点击对象存储 - 安全设置…

JUC-1M/75±5°超小型密封温度继电器 体积小、重量轻、控温精度高 JOSEF约瑟

JUC系列温度继电器 JUC-1M型超小型密封温度继电器 JUC-2M型超小型密封温度继电器 继电器JUC-027M/2531H-III-G温度继电器 JUC-1M 10C常开温度继电器 JUC-1M 105C温度继电器 用途 小型温控开关系接触感应式密封温度继电器,具有体积小、重量轻、控温精度高等特点&…

Ruby选择结构实战

文章目录 一、Ruby选择结构实战概述二、Ruby选择结构实战案例(一)闰年判断1、编写程序,实现功能2、程序的解释说明3、运行程序,查看结果 (二)求解一元二次方程1、编写程序,实现功能2、程序的解释…

多级页表查询

说明一下这个三级页表的查询,会需要上面的L2,L1,L0 如果在二级页表level就是2,PGSHIFT是12,那么就是往左移129*2位置,在&9bit就得到L2,其他以此类推 也表查询,首先有跟页表的地址pagetable,…

TCP协议——三次握手和四次挥手

文章目录 1. 示意图2. 三次握手3. 四次挥手4. 三次和四次问题4.1 为什么三次握手4.2 为什么四次挥手 5. 状态变化实验5.1 三次握手实验5.2 四次挥手实验 1. 示意图 Tips: 不管是握手还是挥手,发送的都是完整的TCP报头,这不过这些标记位被设置…

【惠友精术】腰椎间盘突出急性发作“要人命”!微创手术除病痛

腰椎间盘突出 急性发作真的很突然 很多患者都有相同的感受 腰腿疼痛难忍 突然就无法动弹 这两天医院来了一位腰椎间盘突出急性发作的阿姨,到院时由家人搀扶着,疼得根本直不起腰,不停吸冷气,情况十分严重。 “医生&#xff0c…

需求:JSON数据显示null值或者不显示null值

使用hutool的工具类 import cn.hutool.json.JSON; import cn.hutool.json.JSONConfig; import cn.hutool.json.JSONUtil;public class Main {public static void main(String[] args) {String sss "{\"1\":\"a\",\"2\":null}";// 不…

vue项目突然报错 error Insert `⏎·········` prettier/prettier

vs设置了保存时自动格式化代码,突然就报错: 解决方法,在.eslintrc.js最后添加一行:prettier/prettier: off, 然后重新运行

C++之constexpr和常量表达式

常量表达式 常量表达式(const expression)是指值不会改变并且在编译过程就能得到计算结果的表达式。 显然,字面值属于常量表达式,用常量表达式初始化的const对象也是常量表达式。 后面将会提到,C语言中有几种情况下是要用到常量表达式的。…

黑马现有java课程框架及其功能梳理

目录 高并发相关提高通信效率Netty作用:哪些框架使用它: ChannelChannelHandler 和 ChannelPipelineEventLoop 和 EventLoopGroup**涉及的名词解释:**NIOSocketNginx 高并发相关 主要用来解决IO密集型程序(大量文件读写&#xff…

AI+ 发展展望

引言 随着人工智能技术的不断进步,"AI"已经成为一个热门话题,它代表着人工智能与其他行业的深度融合。"AI"不仅仅是技术的进步,更是一场影响深远的社会变革。在这篇文章中,回望历史我们将探索历史经验&#…

高德地图——轨迹回放和电子围栏

功能点 地图的初始化显示电子围栏(先初始化在调接口显示电子围栏)显示定位显示轨迹轨迹回放 (回放速度无法控制是因为高德地图的版本问题,不要设置版本,使用默认的即可生效)获取当前城市及天气情况设置地图…