”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > MySQL 用户权限:实用指南

MySQL 用户权限:实用指南

发布于2024-11-07
浏览:853

MySQL User Permissions: A Practical Guide

在数据库管理领域,控制用户访问对于维护数据完整性和安全性至关重要。这篇博文将引导您完成设置 MySQL 用户权限的真实场景,包括过程、潜在陷阱和调试步骤。

场景

假设您是一家拥有多个数据库的公司的数据库管理员:

  • 原始数据库:产品、客户、订单、分析
  • 复制数据库:products_copy、customers_copy、orders_copy、analytics_copy

您的任务是为名为“analyst”的用户设置权限,并满足以下要求:

  1. 分析师应该能够查看原始数据库中的数据库和表。
  2. 分析师不应该能够编辑原始数据库。
  3. 分析师不应该能够创建新的数据库。
  4. 分析师应对“_copy”数据库拥有完全访问权限(查看、编辑、删除、创建表)。

让我们深入了解如何使用 MySQL 的 GRANT 和 REVOKE 语句来实现这一点。

第 1 步:初始设置

首先,我们需要使用管理帐户连接MySQL服务器:

mysql -h hostname -P port -u admin -p

将“主机名”、“端口”和“管理员”替换为您的实际服务器详细信息和管理员用户名。

第 2 步:创建用户

如果用户尚不存在,我们需要创建它:

CREATE USER 'analyst'@'%' IDENTIFIED BY 'password';

将“密码”替换为安全强度高的密码。

第 3 步:授予必要的权限

现在,让我们授予所需的权限:

-- Grant SELECT on original databases
GRANT SELECT ON products.* TO 'analyst'@'%';
GRANT SELECT ON customers.* TO 'analyst'@'%';
GRANT SELECT ON orders.* TO 'analyst'@'%';
GRANT SELECT ON analytics.* TO 'analyst'@'%';

-- Grant all privileges on copy databases
GRANT ALL PRIVILEGES ON products_copy.* TO 'analyst'@'%';
GRANT ALL PRIVILEGES ON customers_copy.* TO 'analyst'@'%';
GRANT ALL PRIVILEGES ON orders_copy.* TO 'analyst'@'%';
GRANT ALL PRIVILEGES ON analytics_copy.* TO 'analyst'@'%';

-- Grant global privileges
GRANT PROCESS, SHOW DATABASES ON *.* TO 'analyst'@'%';

-- Apply the changes
FLUSH PRIVILEGES;

第 4 步:验证权限

设置权限后,验证权限至关重要:

SHOW GRANTS FOR 'analyst'@'%';

调试和故障排除

问题一:权限过多

在我们的场景中,我们最初遇到了“分析师”拥有太多特权的问题:

mysql> SHOW GRANTS FOR 'analyst'@'%';
 --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
| Grants for analyst@%                                                                                                                                                                                                                                                                                                              |
 --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
| GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, RELOAD, PROCESS, REFERENCES, INDEX, ALTER, SHOW DATABASES, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE, REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER ON *.* TO "analyst"@"%" WITH GRANT OPTION |
| GRANT REPLICATION_APPLIER,ROLE_ADMIN ON *.* TO "analyst"@"%" WITH GRANT OPTION                                                                                                                                                                                                                                                    |
...
 --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 

解决方案:

为了解决这个问题,我们撤销了所有权限,然后仅授予必要的权限:

REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'analyst'@'%';
GRANT PROCESS, SHOW DATABASES ON *.* TO 'analyst'@'%';
-- Then re-grant the specific permissions as shown in Step 3

问题 2:缺少复制数据库的权限

修复过多的权限后,我们注意到复制数据库的权限丢失了:

mysql> SHOW GRANTS FOR 'analyst'@'%';
 ----------------------------------------------------- 
| Grants for analyst@%                                |
 ----------------------------------------------------- 
| GRANT PROCESS, SHOW DATABASES ON *.* TO "analyst"@"%"|
| GRANT SELECT ON "products".* TO "analyst"@"%"       |
| GRANT SELECT ON "customers".* TO "analyst"@"%"      |
| GRANT SELECT ON "orders".* TO "analyst"@"%"         |
| GRANT SELECT ON "analytics".* TO "analyst"@"%"      |
 ----------------------------------------------------- 

解决方案:

我们添加了副本数据库缺少的授权:

GRANT ALL PRIVILEGES ON products_copy.* TO 'analyst'@'%';
GRANT ALL PRIVILEGES ON customers_copy.* TO 'analyst'@'%';
GRANT ALL PRIVILEGES ON orders_copy.* TO 'analyst'@'%';
GRANT ALL PRIVILEGES ON analytics_copy.* TO 'analyst'@'%';
FLUSH PRIVILEGES;

最终结果

应用所有这些更改和修复后,最终的拨款应如下所示:

mysql> SHOW GRANTS FOR 'analyst'@'%';
 ----------------------------------------------------- 
| Grants for analyst@%                                |
 ----------------------------------------------------- 
| GRANT PROCESS, SHOW DATABASES ON *.* TO "analyst"@"%"|
| GRANT SELECT ON "products".* TO "analyst"@"%"       |
| GRANT SELECT ON "customers".* TO "analyst"@"%"      |
| GRANT SELECT ON "orders".* TO "analyst"@"%"         |
| GRANT SELECT ON "analytics".* TO "analyst"@"%"      |
| GRANT ALL PRIVILEGES ON "products_copy".* TO "analyst"@"%"|
| GRANT ALL PRIVILEGES ON "customers_copy".* TO "analyst"@"%"|
| GRANT ALL PRIVILEGES ON "orders_copy".* TO "analyst"@"%"|
| GRANT ALL PRIVILEGES ON "analytics_copy".* TO "analyst"@"%"|
 ----------------------------------------------------- 

结论

设置适当的 MySQL 用户权限可能很棘手,但这是数据库管理的一个重要方面。通过仔细使用 GRANT 和 REVOKE 语句并始终验证结果,您可以为您的用户创建一个安全且功能齐全的环境。

记住这些要点:

  1. 始终从最小特权原则开始。
  2. 进行更改后使用 SHOW GRANTS 验证权限。
  3. 小心全局权限(ON .)。
  4. 进行更改后不要忘记刷新权限。

通过遵循本文中概述的这些准则和步骤,您将能够有效地管理 MySQL 用户权限。

版本声明 本文转载于:https://dev.to/manojspace/mysql-user-permissions-a-practical-guide-2ldb?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • MySQL 如何处理较短列中的长整数:溢出或截断?
    MySQL 如何处理较短列中的长整数:溢出或截断?
    较短列中的长整数转换:机制和公式将长整数插入较短整数列时,MySQL 通常会截断该值以适合指定的长度。但是,在某些情况下,行为可能会有所不同,从而导致意外的转换。考虑一个 10 位长整数列 some_number。如果将超过最大整数范围 (2147483647) 的值插入到此列中,MySQL 会将该...
    编程 发布于2024-11-08
  • 如何在教义 2 中创建带有额外字段的多对多链接表?
    如何在教义 2 中创建带有额外字段的多对多链接表?
    Doctrine 2 和带有额外字段的多对多链接表本文解决了在 Dotrine 2 中创建多对多关系的问题,其中链接表包含一个附加值,特别是在库存系统的上下文中。原则 2 中的多对多关系可以使用不包含任何附加字段的链接表来建立。但是,当每个链接都需要额外的值时,必须将链接表重新定义为新实体。提供的代...
    编程 发布于2024-11-08
  • JavaScript 中的单管道运算符如何处理浮点数和整数?
    JavaScript 中的单管道运算符如何处理浮点数和整数?
    探索 JavaScript 中单管道运算符的按位性质在 JavaScript 中,单管道运算符(“|”)执行按位运算称为按位或的运算。理解此操作对于理解其对不同输入值的影响至关重要,如以下示例所示:console.log(0.5 | 0); // 0 console.log(-1 | 0); //...
    编程 发布于2024-11-08
  • 列表理解和Regae
    列表理解和Regae
    啊。我一直害怕的那一刻。 第一篇文章,包含我自己的想法、观点和可能的知识细分。 请注意,亲爱的读者,这并不是对 Python 单行 for 循环、追加到列表和返回一些数据的能力的深入探讨或令人难以置信的分解。不,不。这只是展示了如何有趣——以及如何愚蠢——小东西可以组合在一起,让一...
    编程 发布于2024-11-08
  • 如何解决 WAMP 上由于缺少 Openssl 扩展而导致的 Composer 错误?
    如何解决 WAMP 上由于缺少 Openssl 扩展而导致的 Composer 错误?
    Composer 出现问题? WAMP 上缺少 Openssl 扩展尝试将 Composer 合并到 WAMP 设置中时,您可能会遇到警告:“The openssl 扩展丢失。”此消息表明,如果没有此扩展程序,您的系统的安全性和稳定性将会受到影响。故障排除步骤:您已经认真浏览了 WAMP 界面,标记...
    编程 发布于2024-11-08
  • 如何解决 Windows 上 PHP 中的 SSL 套接字传输问题?
    如何解决 Windows 上 PHP 中的 SSL 套接字传输问题?
    解决 PHP 中的 SSL Socket 传输问题在 Windows 系统上使用 PHP 时,开发人员可能会遇到错误“无法连接到 ssl: //...”由于启用“ssl”套接字传输存在困难。本文将指导您排除故障并解决此问题,并介绍您迄今为止已采取的具体步骤。故障排除步骤检查 PHP 配置:确保 ph...
    编程 发布于2024-11-08
  • 为什么模拟鼠标悬停在 Chrome 中不会触发 CSS 悬停?
    为什么模拟鼠标悬停在 Chrome 中不会触发 CSS 悬停?
    在 JavaScript 中模拟鼠标悬停:澄清差异并实现手动控制尝试在 Chrome 中模拟鼠标悬停事件时,您可能遇到了一个有趣的问题问题。尽管“mouseover”事件监听器已成功激活,但相应的CSS“hover”声明并未生效。此外,尝试在鼠标悬停侦听器中使用 classList.add(&quo...
    编程 发布于2024-11-08
  • 你能衡量 MySQL 索引的有效性吗?
    你能衡量 MySQL 索引的有效性吗?
    了解 MySQL 索引性能优化 MySQL 查询对于高效的数据库处理至关重要。索引是提高搜索性能的关键技术,但监控其有效性也同样重要。本文解决了是否可以评估 MySQL 索引性能的问题并提供了解决方案。识别查询性能确定查询是否使用索引,执行以下查询:EXPLAIN EXTENDED SELECT c...
    编程 发布于2024-11-08
  • 如何自定义 PDF.js
    如何自定义 PDF.js
    PDF.js 是一个很棒的开源项目,它经常更新并且不断添加新功能,但是从外观上看它很丑陋,或者可以说它看起来已经过时了。从 PDF.js 获取最新的 PDF 功能和修复,但在演示方面拥有流畅的外观怎么样? PdfJsKit 的 pdf 查看器并不引人注目,它不会直接更改 PDF.js 的代码,它只是...
    编程 发布于2024-11-08
  • 即将推出大事
    即将推出大事
    我决定从头开始构建全栈 Web 开发人员课程,从 HID 一直到服务器和可扩展性。所有需要知道的,都将免费涵盖免费! 以下是涵盖的内容: 互联网 互联网是如何运作的? 什么是HTTP? 浏览器及其工作原理? DNS 及其工作原理? 什么是域名? 什么是托管? 前端 H...
    编程 发布于2024-11-08
  • HTML 页面的剖析
    HTML 页面的剖析
    编程 发布于2024-11-08
  • 设计有效数据库的终极指南(说真的,我们是认真的)
    设计有效数据库的终极指南(说真的,我们是认真的)
    Alright, you’ve got a shiny new project. Maybe it's a cutting-edge mobile app or a massive e-commerce platform. Whatever it is, behind all that glitz ...
    编程 发布于2024-11-08
  • 使用 html css 和 javascript 的图像轮播旋转幻觉
    使用 html css 和 javascript 的图像轮播旋转幻觉
    代码 旋转图像轮播 身体 { 显示:柔性; 调整内容:居中; 对齐项目:居中; 高度:100vh; 保证金:0; 背景颜色:#0d0d0d; 溢出:隐藏; ...
    编程 发布于2024-11-08
  • 如何开始 Web 开发
    如何开始 Web 开发
    介绍 Web 开发是当今最受欢迎的职业之一,对于那些对 前端(用户看到的内容)和 后端(服务器逻辑)感兴趣的人来说)。如果您刚刚起步,想知道从哪里开始或者作为开发者可以赚多少钱,本指南将为您提供清晰的入门路径和资源。 什么是网页开发? 网络开发分为两大区域: 前端:...
    编程 发布于2024-11-08
  • 如何在不使用 Composer 本身的情况下安装 Composer PHP 包?
    如何在不使用 Composer 本身的情况下安装 Composer PHP 包?
    如何在没有 Composer 的情况下安装 Composer PHP 软件包在本文中,我们将解决在没有 Composer 工具的情况下安装 Composer PHP 软件包的挑战本身。当您遇到 Composer 对于您的工作流程不可用或不切实际的情况时,此方法非常有用。识别依赖关系第一步是识别包所需...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3