0

0

mysql备份用户需要哪些权限_mysql最小授权方案

P粉602998670

P粉602998670

发布时间:2026-01-26 11:02:38

|

274人浏览过

|

来源于php中文网

原创

备份用户最小权限为SELECT、LOCK TABLES、SHOW VIEW、TRIGGER,RELOAD为全局可选权限;严禁授予PROCESS或SUPER;跨库需显式授权业务库,禁授系统库;须验证权限生效。

mysql备份用户需要哪些权限_mysql最小授权方案

备份用户只需要 SELECT + LOCK TABLES + RELOAD(非必需但推荐)

MySQL 备份用户(如用 mysqldump 做逻辑备份)**不需任何写权限,也不该有**。最小可行权限组合是:SELECT(读数据)、LOCK TABLES(保证一致性快照)、SHOW VIEW(若库中有视图)、TRIGGER(若表带触发器且需导出定义)。RELOAD 权限仅在启用 --single-transaction 时非必须,但加了更稳妥——它允许执行 FLUSH TABLES WITH READ LOCK 回退方案。

  • SELECT:必须,读取所有待备份表的数据
  • LOCK TABLES:必须,mysqldump 默认会尝试加表级读锁;没这权限会报错 Access denied; you need (at least one of) the LOCK TABLES privilege(s) for this operation
  • SHOW VIEW:必须,否则视图会被跳过或报错 Access denied for view ...
  • TRIGGER:建议加上,否则 mysqldump --triggers(默认开启)会失败
  • RELOAD:非强制但强烈建议,让 mysqldump 在无法用事务快照时能降级使用全局只读锁
CREATE USER 'bkp_user'@'localhost' IDENTIFIED BY 'strong_pass_2025';
GRANT SELECT, LOCK TABLES, SHOW VIEW, TRIGGER ON myapp_db.* TO 'bkp_user'@'localhost';
GRANT RELOAD ON *.* TO 'bkp_user'@'localhost';  -- 注意:RELOAD 是全局权限,必须写 *.*
FLUSH PRIVILEGES;

别给 backup 用户 PROCESS 或 SUPER 权限

有些文档误写“加 PROCESS 才能看线程”,其实 mysqldump 完全不需要它;而 SUPER 更是高危权限,一旦泄露可执行 KILL、修改系统变量、甚至绕过认证。真实错误现象包括:

  • 给了 PROCESS 后,mysqldump 确实不报错,但这是过度授权——它只是恰好没被拒绝,不是真需要
  • 给了 SUPER,用户能执行 SET GLOBAL read_only=OFF,瞬间让只读备份账号获得写能力
  • 某些云数据库(如阿里云 RDS、腾讯云 CDB)直接禁用 SUPERPROCESS,强行加会导致 GRANT 报错

跨库备份?按需授权,绝不写 *.*

如果备份脚本要 dump 多个库(比如 myapp_dblog_db),常见错误是直接授 SELECT ON *.* —— 这违反最小权限,且可能意外暴露系统库(如 mysqlinformation_schema)。

Sheet+
Sheet+

Excel和GoogleSheets表格AI处理工具

下载
  • 正确做法:显式列出每个业务库,分别授权
    GRANT SELECT, LOCK TABLES, SHOW VIEW, TRIGGER ON myapp_db.* TO 'bkp_user'@'localhost';
    GRANT SELECT, LOCK TABLES, SHOW VIEW, TRIGGER ON log_db.* TO 'bkp_user'@'localhost';
  • 禁止对 mysqlperformance_schemasys 授权,这些库含敏感元数据
  • 若用 mysqldump --all-databases,必须确认是否真需要全部——生产环境几乎从不这么做

验证权限是否真生效?用 SHOW GRANTS + 实际跑一次 dump

授完权别只信 GRANT 语句成功就完事。真实权限可能因 host 匹配顺序、缓存未刷新、或权限表冲突而失效。

  • 先查:运行 SHOW GRANTS FOR 'bkp_user'@'localhost';,确认输出中每条 GRANT 都是你预期的,没有多余项
  • 再试:用该用户实际执行一次最小化 dump:
    mysqldump -ubkp_user -p -h127.0.0.1 --single-transaction --databases myapp_db > /tmp/test.sql
  • 常见漏掉的坑:bkp_user 创建时指定的是 'bkp_user'@'%',但你连的是 localhost——MySQL 会匹配 'bkp_user'@'localhost'(更高优先级),而这个账户可能根本没建或没授权

最小权限不是设一次就完事的事。备份用户权限要随业务库增减同步调整,每次上线新表、新视图、新触发器,都得回头检查 SHOW GRANTS 输出是否仍覆盖全部对象——否则 dump 会静默跳过某些表,你以为备全了,其实早丢数据了。

热门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,提供了直观易用的用户界面等等。

686

2023.10.12

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

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

327

2023.10.27

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

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

348

2024.02.23

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

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

1159

2024.03.06

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

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

359

2024.03.06

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

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

758

2024.04.07

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

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

577

2024.04.29

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

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

420

2024.04.29

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.23

热门下载

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

精品课程

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

共48课时 | 1.9万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 810人学习

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

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