我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL 用户权限:实用指南

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL 用户权限:实用指南

在数据库管理领域,控制用户访问对于维护数据完整性和安全性至关重要。这篇博文将引导您完成设置 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 用户权限。

以上就是MySQL 用户权限:实用指南的详细内容,更多请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL 用户权限:实用指南

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL 用户权限:实用指南

在数据库管理领域,控制用户访问对于维护数据完整性和安全性至关重要。这篇博文将引导您完成设置 mysql 用户权限的真实场景,包括过程、潜在陷阱和调试步骤。场景假设您是一家拥有多个数据库的公司的数据库管理员:原始数据库:产品、客户、订单、分析
MySQL 用户权限:实用指南
2024-09-20

Discuz权限设置实操指南:轻松规划用户权限体系

【Discuz权限设置实操指南:轻松规划用户权限体系,需要具体代码示例】在现今互联网时代,网站作为各种信息传播和交流的主要场所,严谨的权限体系管理显得尤为重要。Discuz作为一款功能强大的论坛系统,在权限管理方面提供了丰富的功能和选项。
Discuz权限设置实操指南:轻松规划用户权限体系
2024-03-10

Mysql 用户权限管理实现

1. MySQL 权限介绍 mysql中存在4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表,我当前的版本mysql 5.7.22 。 mysql权限表的验证过程为:先从user表中的Host
2022-05-25

Discuz用户权限设置指南:掌握权限管理的关键技巧

Discuz用户权限设置指南随着互联网的快速发展,在线社区已经成为人们交流、分享信息的重要平台。而Discuz作为一款知名的论坛系统,在其权限管理方面拥有非常丰富的功能,包括用户权限设置、版块权限控制等,可以帮助管理员更好地管理论坛,保障
Discuz用户权限设置指南:掌握权限管理的关键技巧
2024-03-10

MySQL用户权限操作

查看当前用户:select user,host from user;或: SELECT DISTINCT CONCAT(‘User: ‘‘‘,user,‘‘‘@‘‘‘,host,‘‘‘;‘) AS query FROM mysql.user; 创建用户:(创建
MySQL用户权限操作
2016-04-08

mysql如何授权用户权限

授权mysql用户权限的过程包括:登录mysql使用具有管理权限的用户。创建要授权的用户(如果不存在)。使用grant语句授予所需的权限。刷新权限表以使更改生效。MySQL授权用户权限如何授权用户权限授权MySQL用户权限的过程包括以下
mysql如何授权用户权限
2024-06-15

MYSQL用户权限管理

1.在MySQL中,用户是怎么定义的#mysql中,定义一个用户是:用户名@‘主机域‘#用户名写法:用户名如果是字符:mysql> create user [email protected]‘10.0.0.1‘;用户名是数字需要加引号:mysql> creat
MYSQL用户权限管理
2015-02-26

MySQL修改用户权限

最近测试中台的存储服务,涉及到MySQL用户操作的命令,记录一下。1、查看所有用户select user from mysql.user;2、查看当前登陆用户select user(); 3、创建用户CREATE USER "username"@"host"
MySQL修改用户权限
2016-08-30

MySQL授予用户权限

使用该命令可以展示出mysql中存在的权限。 show privileges; 给用户授权的方式有 2 种,分别是通过把角色赋予用户给用户授权(mysql8.0的特性) 和 直接给用户授权。用户是数据库的使用者,我们可以通过给用户授予访问数
2023-08-16

MySQL REVOKE实现删除用户权限

在 MySQL 中,可以使用 REVOKE 语句删除某个用户的某些权限(此用户不会被删除),在一定程度上可以保证系统的安全性。例如,如果数据库管理员觉得某个用户不应该拥有 DELETE 权限,那么就可以删除 DELETE 权限。 使用 RE
2022-05-28

mysql用户权限管理实例分析

本文实例讲述了mysql用户权限管理。分享给大家供大家参考,具体如下: 本文内容:什么是用户权限恰当的用户权限查看权限修改权限删除权限首发日期:2018-04-19什么是用户权限:每个用户都有自己的用户权限,这些用户权限比如有查询表权限、修
2022-05-15

Mysql如何实现用户权限管理

小编给大家分享一下Mysql如何实现用户权限管理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. MySQL 权限介绍mysql中存在4个控制权限的表,分别为u
2023-06-15

编程热搜

目录