0

0

mysql如何防止开发人员越权操作_mysql权限规范建议

P粉602998670

P粉602998670

发布时间:2026-02-04 08:07:02

|

787人浏览过

|

来源于php中文网

原创

MySQL权限最小化落地需按角色分组、库/表粒度授权、禁用FILE/SUPER/GRANT OPTION等越权红线权限,应用与开发账号必须分离,定期用SQL检查并回收残留权限。

mysql如何防止开发人员越权操作_mysql权限规范建议

MySQL 权限最小化原则怎么落地

直接给 rootDBA 权限给开发人员,等于把数据库的钥匙塞进所有人手里。真正可行的做法是:按角色分组、按库/表粒度授权、禁用高危权限。比如开发只读账号不应有 DROPCREATEALTERGRANT OPTION,连 SELECT 也建议限制到具体库(如 app_production),而非用 *

  • CREATE USER 'dev_ro'@'192.168.10.%' IDENTIFIED BY 'pwd123';
  • GRANT SELECT ON app_production.* TO 'dev_ro'@'192.168.10.%';
  • REVOKE DROP, ALTER, CREATE, GRANT OPTION ON *.* FROM 'dev_ro'@'192.168.10.%';
  • 执行 FLUSH PRIVILEGES; 生效(MySQL 8.0+ 在部分场景下可省略,但显式调用更稳妥)

哪些权限属于“越权红线”必须禁用

开发日常只需 SELECT、有限 INSERT/UPDATE(如测试环境)、SHOW VIEW;其余基本都该禁。特别注意:

  • FILE:允许读写服务器文件系统,极易导致配置泄露(如读取 /etc/passwd 或 MySQL 的 my.cnf
  • SUPER:可 kill 线程、修改全局变量、绕过只读模式,等同于降级为 root
  • PROCESS:能看到所有 SQL(含敏感参数),违反最小披露原则
  • REPLICATION CLIENTREPLICATION SLAVE:除非明确参与主从调试,否则不应开放
  • GRANT OPTION:一旦开启,该账号可自行扩大权限,彻底破坏管控链条

如何快速检查现有账号是否越权

别靠人工翻文档,用 SQL 直接查。登录高权限账号后运行:

SELECT 
  u.User, u.Host,
  GROUP_CONCAT(DISTINCT p.Privilege SEPARATOR ', ') AS Privileges
FROM mysql.user u
JOIN mysql.role_edges r ON u.User = r.Granted_role AND u.Host = r.Granted_host
JOIN mysql.role_edges r2 ON r.Granted_role = r2.Granted_role
JOIN mysql.role_edges r3 ON r2.Granted_role = r3.Granted_role
JOIN (
  SELECT User, Host, 
         CASE WHEN Select_priv = 'Y' THEN 'SELECT' END AS Privilege FROM mysql.user
  UNION ALL
  SELECT User, Host, CASE WHEN Insert_priv = 'Y' THEN 'INSERT' END FROM mysql.user
  UNION ALL
  SELECT User, Host, CASE WHEN File_priv = 'Y' THEN 'FILE' END FROM mysql.user
  UNION ALL
  SELECT User, Host, CASE WHEN Super_priv = 'Y' THEN 'SUPER' END FROM mysql.user
  UNION ALL
  SELECT User, Host, CASE WHEN Grant_priv = 'Y' THEN 'GRANT OPTION' END FROM mysql.user
) p ON u.User = p.User AND u.Host = p.Host
WHERE u.User NOT IN ('root', 'mysql.sys', 'mysql.session')
GROUP BY u.User, u.Host
HAVING Privileges LIKE '%FILE%' OR Privileges LIKE '%SUPER%' OR Privileges LIKE '%GRANT OPTION%';

结果为空才表示暂无明显越权账号。注意:MySQL 8.0+ 权限模型已改用 mysql.role_edgesmysql.role_routines,上述查询需适配——但核心逻辑不变:查 mysql.user 表中 File_privSuper_privGrant_priv 字段是否为 'Y' 即可快速定位。

Presentations.AI
Presentations.AI

AI驱动创建令人惊叹的演示文稿

下载

应用连接池里的账号要不要和开发账号分开

要,而且必须分开。开发账号用于本地调试、SQL 审核、故障排查;应用账号只供线上服务使用,权限进一步收窄(例如只允许 SELECT + 指定几张表的 INSERT)。两者共用一个账号,意味着任何一次代码注入、日志打印、IDE 连接泄露,都会直接暴露生产操作能力。

  • 应用账号命名建议带前缀,如 app_api_rwapp_report_ro,避免与人名或临时账号混淆
  • 密码必须独立管理,禁止硬编码在代码或 .env 中;应通过密钥管理服务(如 HashiCorp Vault、阿里云 KMS)动态获取
  • 应用账号默认启用 max_connections=5 类似限制,防止误触发连接风暴
  • 上线前用 SHOW GRANTS FOR 'app_api_rw'@'%'; 复核,确认没有意外继承的权限

实际中最容易被忽略的是权限回收动作——删掉离职人员账号不等于清除其创建的视图、存储过程或代理用户。只要没显式 DROP PROCEDUREREVOKE 掉对应对象权限,残留风险就一直存在。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

813

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

330

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

351

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1366

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

365

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

943

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

427

2024.04.29

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.1万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 821人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号