当前位置: 首页 > article >正文

MySQL 数据库安全配置最佳实践

文章目录

  • MySQL 数据库安全配置最佳实践
  • 账户与权限管理
    • 账户最小化原则
    • 权限最小化配置
    • 密码策略强化
  • 认证与访问控制
    • 禁用匿名账户
    • 启用安全认证
  • 网络安全防护
    • 访问源限制
    • 禁用远程root访问
    • 启用SSL加密
  • 日志审计与监控
    • 全量审计配置
    • 二进制日志管理
  • 服务端安全加固
    • 关键参数配置
    • 文件权限控制
  • 灾备与应急响应
    • 定期备份策略
    • 安全事件响应
  • 实施注意事项
  • 总结


MySQL 数据库安全配置最佳实践

在数据库管理中,保障数据库的安全性是至关重要的。MySQL 作为常见的关系型数据库管理系统,合理的安全配置能够有效预防安全漏洞和非法访问,确保数据的完整性、机密性和可用性。本文将深入探讨 MySQL 安全配置的最佳实践,包括账户配置要求、日志配置要求及其他关键配置项,并提供具体的操作步骤、回退操作及风险提示。


账户与权限管理

账户最小化原则

安全要求:禁止共享账户,按角色创建独立账户
检查方法

SELECT user, host FROM mysql.user 
WHERE user NOT IN ('mysql.sys','mysql.session','mysql.infoschema');

操作步骤

-- 创建应用账户(MySQL 5.7+)
CREATE USER 'testuser'@'192.168.1.%' IDENTIFIED BY 'TEst@123!';
GRANT SELECT, INSERT ON app_db.* TO 'testuser'@'192.168.1.%';-- 创建只读监控账户
CREATE USER 'monitor'@'192.168.1.1' IDENTIFIED WITH caching_sha2_password BY 'TEst@123!';
GRANT SELECT, PROCESS, REPLICATION CLIENT ON *.* TO 'monitor'@'192.168.1.1';

回退方案

SHOW GRANTS FOR 'testuser'@'192.168.1.%';  -- 记录原权限
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'testuser'@'192.168.1.%';
DROP USER IF EXISTS 'testuser'@'192.168.1.%';

风险提示:删除账户前需确认相关应用已下线,避免服务中断


权限最小化配置

安全要求:遵循最小权限原则
检查工具

mysql> SHOW GRANTS FOR CURRENT_USER();  -- 查看当前用户权限
mysql> SELECT * FROM information_schema.user_privileges;  -- 全量权限审计

高危权限清单

  • FILE:允许文件系统访问
  • SUPER:绕过权限限制
  • PROCESS:查看所有会话
  • RELOAD:刷新权限/日志
  • SHUTDOWN:关闭数据库

权限回收示例

REVOKE DROP, ALTER, CREATE USER ON *.* FROM 'testuser'@'%';

密码策略强化

企业级密码策略

-- 全局密码策略(MySQL 8.0+)
SET GLOBAL validate_password.policy = STRONG;
SET GLOBAL validate_password.length = 12;
SET GLOBAL validate_password.mixed_case_count = 2;
SET GLOBAL validate_password.number_count = 2;
SET GLOBAL validate_password.special_char_count = 1;

具体含义如下:

  1. SET GLOBAL validate_password.policy = STRONG;
  • 作用: 设置密码复杂度要求的策略为 STRONG(强)
  • 解释:validate_password.policy 中,常见的值有:
    • LOW:只要求密码长度大于等于 8 个字符。
    • MEDIUM:要求密码不仅具有足够的长度,还要求包括字母、数字及特殊字符。
    • STRONG:要求密码长度和复杂度更高,通常需要包括大写字母、小写字母、数字和特殊字符。
  1. SET GLOBAL validate_password.length = 12;
  • 作用: 设置密码的最小长度为 12 个字符
  • 解释: 这个设置规定了所有用户密码必须至少包含 12 个字符。较长的密码比短密码更难以被破解。
  1. SET GLOBAL validate_password.mixed_case_count = 2;
  • 作用: 设置密码中 大写字母和小写字母 的最小个数为 2
  • 解释: 这意味着密码中必须至少包含 2 个大写字母和 2 个小写字母,这样可以提高密码的复杂度。
  1. SET GLOBAL validate_password.number_count = 2;
  • 作用: 设置密码中 数字 的最小个数为 2
  • 解释: 这要求密码至少包含 2 个数字,数字的加入可以增加密码的复杂性。
  1. SET GLOBAL validate_password.special_char_count = 1;
  • 作用: 设置密码中 特殊字符(如 @#$% 等)的最小个数为 1
  • 解释: 这个设置要求密码至少包含一个特殊字符,增加密码的强度,使其不容易被猜测。

密码生命周期管理

ALTER USER 'admin'@'localhost' 
PASSWORD EXPIRE INTERVAL 90 DAY
FAILED_LOGIN_ATTEMPTS 5 
PASSWORD_LOCK_TIME 1;

认证与访问控制

禁用匿名账户

检查与处理

SELECT user, host FROM mysql.user WHERE user = '';
-- 清理匿名账户
DROP USER IF EXISTS ''@'localhost';

启用安全认证

# my.cnf配置
[mysqld]
default_authentication_plugin=caching_sha2_password  # MySQL 8默认
secure_auth = ON

网络安全防护

访问源限制

企业级方案

-- 仅允许指定IP段访问
CREATE USER 'admintest'@'10.20.30.%' IDENTIFIED BY 'AAASSS!@#2323';
GRANT ALL ON *.* TO 'admintest'@'10.20.30.%';

禁用远程root访问

DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1');

启用SSL加密

SHOW VARIABLES LIKE '%ssl%';  -- 验证证书状态
ALTER USER 'remote_user'@'%' REQUIRE SSL;

日志审计与监控

全量审计配置

# my.cnf配置
[mysqld]
log_error = /var/log/mysql/error.log
general_log = 1
general_log_file = /var/log/mysql/general.log
slow_query_log = 1
log_queries_not_using_indexes = 1

二进制日志管理

SET GLOBAL expire_logs_days = 7;  -- 保留7天
SET GLOBAL binlog_format = ROW;  -- 行级复制

服务端安全加固

关键参数配置

[mysqld]
local_infile = OFF
skip_symbolic_links = ON
skip_name_resolve = ON
secure_file_priv = /var/lib/mysql-files

文件权限控制

chmod 750 /var/lib/mysql
chown -R mysql:mysql /var/lib/mysql

灾备与应急响应

定期备份策略

# 物理备份工具
mysqlbackup --user=backup --password=TT@@EE33$$ --backup-dir=/backups backup-and-apply-log

安全事件响应

  • 建立账号变更审批流程
  • 配置实时入侵检测系统(IDS)
  • 制定数据库脱敏规范

实施注意事项

  1. 变更窗口:在业务低峰期执行配置变更
  2. 配置备份:修改前备份my.cnf文件
  3. 灰度验证:先在测试环境验证配置变更
  4. 监控回滚:变更后观察数据库性能指标
  5. 文档同步:更新运维手册和CMDB记录

总结

通过实施本指南中的安全配置,可有效构建MySQL数据库的多层防御体系。建议每季度进行安全审计,配合漏洞扫描和渗透测试,持续提升数据库安全水位。对于云环境下的托管数据库(如RDS),需结合云平台的安全能力进行综合防护。

相关文章:

MySQL 数据库安全配置最佳实践

文章目录 MySQL 数据库安全配置最佳实践账户与权限管理账户最小化原则权限最小化配置密码策略强化 认证与访问控制禁用匿名账户启用安全认证 网络安全防护访问源限制禁用远程root访问启用SSL加密 日志审计与监控全量审计配置二进制日志管理 服务端安全加固关键参数配置文件权限…...

小红书自动评论

现在越来越多的人做起来小红书,为了保证自己的粉丝和数据好看,需要定期养号。 那么养号除了发视频外,还需要积极在社区互动,比如点赞、评论等等,为了节省时间,我做了一个自动化评论工具。 先看效果 那这个是…...

OpenCV图像认知(一)

OpenCV: 是由Intel公司俄罗斯团队发起并参与和维护的一个计算机视觉处理开源软件库,支持与计算机视觉和机器学习相关的众多算法 OpenCV-Python: OpenCV-Python是一个Python绑定库,旨在解决计算机视觉问题。 Python是一种由Gui…...

自学微信小程序的第六天

DAY6 1、使用录音API首先需要通过wx.getRecorderManager()方法获取到一个RecorderManager实例,该实例是一个全局唯一的录音管理器,用于实现录音功能。 表32:RecorderManager实例的常用方法 方法名称 说明 start() 开始录音 pause() 暂停录音 resume() 继续录音 stop() 停止…...

C++动态与静态转换区别详解

文章目录 前言一、 类型检查的时机二、安全性三、适用场景四、代码示例对比总结 前言 在 C 中,dynamic_cast 和 static_cast 是两种不同的类型转换操作符,主要区别体现在类型检查的时机、安全性和适用场景上。以下是它们的核心区别: 一、 类…...

Qt6.8编译项目找不到文件——6.8.2\msvc2022_64\include\QtWidgets\QMainWindow does not exist.

问题:Error: dependent ‘…\Qt6.8.2\6.8.2\msvc2022_64\include\QtWidgets\QMainWindow’ does not exist. jom: D:\Temp\untitled1\build\Makefile [release] Error 2 20:20:43: 进程"D:\ProgramFiles\Develop\Qt6.8.2\Tools\QtCreator\bin\jom\jom.exe"…...

AI工具导航平台功能模块之混合分类器功能说明文档

AI工具导航平台功能模块之混合分类器功能说明文档 这是我最近正在开发的AI工具信息平台的部门功能模块混合分类器的说明文档,我的AI工具信息平台基于streamlit架构,整理出来与大家分享。 该程序的混合分类器采用规则引擎与深度学习模型协同工作的架构&…...

【时序预测】在线学习:算法选择(从线性模型到深度学习解析)

——如何为动态时序预测匹配最佳增量学习策略? 引言:在线学习的核心价值与挑战 在动态时序预测场景中(如实时交通预测、能源消耗监控),数据以流式(Streaming)形式持续生成,且潜在的…...

某个设备的RJ45网口接头为何不可连接任何POE设备

某个设备的RJ45网口接头不可连接任何POE设备 1.POE设备是什么? POE设备是指支持通过以太网线传输电力和数据的设备,即“Power over Ethernet”(PoE)技术的设备。这种技术允许网络设备在传输数据的同时,通过标准的RJ4…...

发展中的脑机接口:SSVEP特征提取技术

一、简介 脑机接口(BCI)是先进的系统,能够通过分析大脑信号与外部设备之间建立通信,帮助有障碍的人与环境互动。BCI通过分析大脑信号,提供了一种非侵入式、高效的方式,让人们与外部设备进行交流。BCI技术越…...

绕过密码卸载360终端安全管理系统

一不小心在电脑上安装了360终端安全管理系统,就会发现没有密码,就无法退出无法卸载360,很容易成为一个心病,360终端安全管理系统,没有密码,进程无法退出,软件无法卸载,前不久听同事说…...

Java数据结构第十五期:走进二叉树的奇妙世界(四)

专栏:Java数据结构秘籍 个人主页:手握风云 目录 一、二叉树OJ练习题(续) 1.1. 二叉树的层序遍历 1.2. 二叉树的最近公共祖先 1.3. 从前序与中序遍历序列构造二叉树 1.4. 从中序与后序遍历序列构造二叉树 1.5. 根据二叉树创建…...

Transformer 代码剖析9 - 解码器模块Decoder (pytorch实现)

一、模块架构全景图 1.1 核心功能定位 Transformer解码器是序列生成任务的核心组件,负责根据编码器输出和已生成序列预测下一个目标符号。其独特的三级注意力机制架构使其在机器翻译、文本生成等任务中表现出色。下面是解码器在Transformer架构中的定位示意图&…...

JAVA八股—计算机网络(自用)

JAVA八股—计算机网络(自用) 2.7 1.介绍一下TCP/IP模型和OSI模型的区别 OSI模型是国际标准化组织(ISO)制定的一个用于计算机或通信系统间互联的标准体系,将计算机网络通信划分为七个不同的层级,每个层级都负责特定的功能。每个…...

unity和unity hub关系

unity和unity hub关系 Unity和Unity Hub是紧密相关但功能不同的两个软件,以下是它们的关系说明: Unity 定义:是一款专业的实时3D开发平台,广泛用于创建各种类型的3D和2D互动内容,如视频游戏、建筑可视化、汽车设计展示、虚拟现实(VR)和增强现实(AR)应用等。功能:提供…...

Linux的OOM机制

Linux 的 OOM(Out of Memory)机制是操作系统在内存耗尽时采取的一种保护措施。当系统内存不足,无法继续分配给进程时,Linux 内核会触发 OOM 杀手(OOM Killer),选择并终止某些进程,以…...

Typora的Github主题美化

[!note] Typora的Github主题进行一些自己喜欢的修改,主要包括:字体、代码块、表格样式 美化前: 美化后: 一、字体更换 之前便看上了「中文网字计划」的「朱雀仿宋」字体,于是一直想更换字体,奈何自己拖延症…...

Cursor配置MCP Server

一、什么是MCP MCP(Model Context Protocol)是由 Anthropic( Claude 的那个公司) 推出的开放标准协议,它为开发者提供了一个强大的工具,能够在数据源和 AI 驱动工具之间建立安全的双向连接。 举个好理解…...

定时器之输入捕获

输入捕获的作用 工作机制​ 输入捕获通过检测外部信号边沿(上升沿/下降沿)触发计数器(CNT)值锁存到捕获寄存器(CCRx),结合两次捕获值的差值计算信号时间参数。 ​脉冲宽度测量&#x…...

Uniapp开发微信小程序插件的一些心得

一、uniapp 开发微信小程序框架搭建 1. 通过 vue-cli 创建 uni-ap // nodejs使用18以上的版本 nvm use 18.14.1 // 安装vue-cli npm install -g vue/cli4 // 选择默认模版 vue create -p dcloudio/uni-preset-vue plugindemo // 运行 uniapp2wxpack-cli npx uniapp2wxpack --…...

0005__PyTorch 教程

PyTorch 教程 | 菜鸟教程 离线包:torch-1.13.1cpu-cp39-cp39-win_amd64.whl https://download.pytorch.org/whl/torch_stable.html...

Pikachu

一、网站搭建 同样的,先下载安装好phpstudy 然后启动Apache和Mysql 然后下载pikachu,解压到phpstudy文件夹下的www文件 然后用vscode打开pikachu中www文件夹下inc中的config.inc.php 将账户和密码改为和phpstudy中的一致(默认都是root&…...

CentOS7 使用 YUM 安装时报错:Cannot find a valid baseurl for repo: base/7/x86_64的解决方法

CentOS7 使用 YUM 安装时报错:Cannot find a valid baseurl for repo: base/7/x86_64的解决方法 报错代码解决方法 报错代码 输入命令yum update -y时报错Cannot find a valid baseurl for repo: base/7/x86_64 解决方法 有 wget 工具 更换YUM源 mv /etc/yum.…...

ChatGPT与DeepSeek:AI语言模型的巅峰对决

目录 引言 一、ChatGPT 与 DeepSeek 简介 (一)ChatGPT (二)DeepSeek 二、技术原理剖析 (一)ChatGPT 技术原理 (二)DeepSeek 技术原理 (三)技术原理对比…...

Linux----网络通信

一、IP地址详解 (一)核心概念 概念说明IP地址网络设备的唯一逻辑标识符,相当于网络世界的"门牌号"主机任何接入网络的终端设备(计算机/手机/服务器等)核心作用① 设备标识 ② 路由寻址 ③ 数据传输 &…...

Android逆向:一文掌握 Frida 详细使用

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 1. Frida 简介2. Frida 的工作原理3. 安装 Frida3.1 安装 Frida 工具3.2 安装 Frida Server4. Frida 的基本使用4.1 连接到目标设备4.2 附加到目标进程4.3 编写 Frida 脚本5. Frida 的高级用法5.1 Hook Java 方法5.2 修…...

AI军备竞赛2025:GPT-4.5的“情商革命”、文心4.5的开源突围与Trae的代码革命

AI军备竞赛2025:GPT-4.5的“情商革命”、文心4.5的开源突围与Trae的代码革命 ——一场重塑人类认知边界的技术战争 一、OpenAI的“感性觉醒”:GPT-4.5的颠覆与争议 1.1 从“冷面学霸”到“温柔导师”:AI的情商跃迁 当用户输入“朋友放鸽子&…...

5G网络切片辨析(eMBB,mMTC,uRLLC)

URLLC有三大应用场景,分别是eMBB(增强型移动宽带)、uRLLC(高可靠低延时通信)和mMTC(海量机器通信)。 增强型移动宽带(eMBB):需要关注峰值速率,容…...

【MySQL篇】数据类型

目录 前言: 1,数据类型的分类 ​编辑 2 ,数值类型 2.1 tinyint类型 2.2 bit类型 2.3 小数类型 2.3.1 float类型 2.3.2 decimal类型 3,字符串类型 3.1 char 3.2 varchar 3.3 char与varchar的比较 3.4日期和时间类型 3.5 …...

DockerでOracle Database 23ai FreeをセットアップしMAX_STRING_SIZEを拡張する手順

DockerでOracle Database 23c FreeをセットアップしMAX_STRING_SIZEを拡張する手順 はじめに環境準備ディレクトリ作成Dockerコンテナ起動 データベース設定変更コンテナ内でSQL*Plus起動PDB操作と文字列サイズ拡張設定検証 管理者ユーザー作成注意事項まとめ はじめに Oracle…...