详解MySQL 用户权限管理
网络编程 2021-07-05 14:37www.168986.cn编程入门
这篇文章主要介绍了MySQL 用户权限管理的相关资料,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
前言
不清楚各位同学对数据库用户权限管理是否了解,作为一名 DBA ,用户权限管理是绕不开的一项工作内容。特别是生产库,数据库用户权限更应该规范管理。本篇文章将会介绍下 MySQL 用户权限管理相关内容。
1.用户权限简介
当我们创建过数据库用户后,还不能执行任何操作,需要为该用户分配适当的访问权限。
关于 MySQL 用户权限简单的理解就是数据库只允许用户做你权利以内的事情,不可以越界。比如只允许你执行 select 操作,那么你就不能执行 update 操作。只允许你从某个 IP 上连接 MySQL ,那么你就不能从除那个 IP 以外的其他机器连接 MySQL 。
在 MySQL 中,用户权限也是分级别的,可以授予的权限有如下几组
- 列级别,和表中的一个具体列相关。例如,可以使用 UPDATE 语句更新表 students 中 student_name 列的值的权限。
- 表级别,和一个具体表中的所有数据相关。例如,可以使用 SELECT 语句查询表 students 的所有数据的权限。
- 数据库级别,和一个具体的数据库中的所有表相关。例如,可以在已有的数据库 mytest 中创建新表的权限。
- 全局,和 MySQL 中所有的数据库相关。例如,可以删除已有的数据库或者创建一个新的数据库的权限。
权限信息存储在 mysql 系统库的 user、db、tables_priv、columns_priv、procs_priv 这几个系统表中。
- user 表存放用户账户信息以及全局级别(所有数据库)权限。
- db 表存放数据库级别的权限,决定了来自哪些主机的哪些用户可以访问此数据库。
- tables_priv 表存放表级别的权限,决定了来自哪些主机的哪些用户可以访问数据库的这个表。
- columns_priv 表存放列级别的权限,决定了来自哪些主机的哪些用户可以访问数据库表的这个字段。
- procs_priv 表存放存储过程和函数级别的权限。
参考官方文档,可授予的权限如下表所示
看起来各种可授予的权限有很多,其实可以大致分为数据、结构、管理三类,大概可分类如下
2.权限管理实战
我们一般用 grant 语句为数据库用户赋权,建议大家先用 create user 语句创建好用户之后再单独进行授权。狼蚁网站SEO优化通过示例来具体看下
# 创建用户 create user 'test_user'@'%' identified by 'xxxxxxxx'; # 全局权限 GRANT super,select on . to 'test_user'@'%'; # 库权限 GRANT select,insert,update,delete,create,alter,execute on `testdb`. to 'test_user'@'%'; # 表权限 GRANT select,insert on `testdb`.tb to 'test_user'@'%'; # 列权限 GRANT select (col1), insert (col1, col2) ON `testdb`.mytbl to 'test_user'@'%'; # GRANT命令说明 super,select 表示具体要授予的权限。 ON 用来指定权限针对哪些库和表。 . 中前面的号用来指定数据库名,后面的号用来指定表名。 TO 表示将权限赋予某个用户。 'test_user'@'%' 表示test_user用户,@后面接限制的主机,可以是IP、IP段、域名以及%,%表示任何地方。 # 刷新权限 flush privileges; # 查看某个用户的权限 show grants for 'test_user'@'%'; # 回收权限 revoke delete on `testdb`. from 'test_user'@'%';
权限管理是一件不容忽视的事,我们不能为了方便而给数据库用户很大的权限。特别是对于生产库,更应该进行权限管控,建议程序用户只赋予增删改查等基础权限,个人用户只赋予查询权限。
出于安全考虑,建议遵循以下几个经验原则
- 只授予能满足需要的最小权限,防止用户干坏事。比如用户只是需要查询,那就只给 select 权限就可以了。
- 创建用户的时候限制用户的登录主机,一般是限制成指定 IP 或者内网 IP 段。
- 给各个服务单独创建数据库用户,单个用户最好只能操作单个库。
- 及时记录各数据库用户权限等信息,以免忘记。
- 若有外部系统调用,应配置只读用户,并且权限要精确到表或视图。
- 定期清理不需要的用户,回收权限或者删除用户。
以上就是详解MySQL 用户权限管理的详细内容,更多关于MySQL 用户权限管理的资料请关注狼蚁SEO其它相关文章!
上一篇:Mysql MVCC机制原理详解
下一篇:mysql死锁和分库分表问题详解
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程