mysql 用户权限配置(详解MySQL 用户权限管理)
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 语句创建好用户之后再单独进行授权。下面通过示例来具体看下:
|
# 创建用户 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 用户权限管理的资料请关注开心学习网其它相关文章!
原文链接:https://mp.weixin.qq.com/s/ZB66xO1-d7uMaK3l0HTGJg
- mysql8使用技巧(一篇学会MySQL 8.0 ROLE管理)
- MySQL自定义函数
- 阿里云的自带mysql怎么开启(阿里云云服务器mysql密码找回的方法)
- mysql中innodb四种事务级别(MySQL InnoDB 锁的相关总结)
- mysql有什么索引(MySQL 普通索引和唯一索引的区别详解)
- navicat不能连接到mysql报错2013(Navicat连接SQL Server数据:报错08001-命名管道提供程序的完美解决方法)
- mysql查询数据去除重复(MySQL 大批量插入,如何过滤掉重复数据?)
- 如何重新配置mysql的端口(如何快速修改MySQL用户的host属性)
- mysql完整整理(Mysql隔离性之Read View的用法说明)
- mysql事务级别设置(mysql在项目中怎么选事务隔离级别)
- 如何用wampserver打开自己写的php(WampServer下安装多个版本的PHP、mysql、apache图文教程)
- mysql在centos7中如何安装(阿里云centos7安装mysql8.0.22的详细教程)
- mysqlworkbench怎么设置连接(详解MySQL Workbench使用教程)
- 怎么用docker中的mysql连接数据库(解决Docker之mysql容器数据库更改不生效的问题)
- mysql乐观锁一定比悲观锁性能高(mysql居然还能实现分布式锁的方法)
- mysql重新安装失败
- 元宵晚会槽点多,芒果台上来就假唱,岳云鹏不说相声改评书了(元宵晚会槽点多)
- 岳云鹏跟凤凰传奇谈心,说出了人生中最重要的三个人,这才成功(岳云鹏跟凤凰传奇谈心)
- 爱情可以当饭吃吗(爱情能当饭吃吗)
- Top 3 JSHS《运动与健康科学 英文 》跻身SCI体育学期刊世界前三(Top3JSHS运动与健康科学)
- 体坛传媒LOGO全新升级,多元发展迈出坚实步伐(体坛传媒LOGO全新升级)
- 超撩人治愈的绝美水彩,原来出自她之手 一笔一画令无数人沉醉(超撩人治愈的绝美水彩)
热门推荐
- vue 为什么使用虚拟dom(Vue虚拟Dom到真实Dom的转换)
- thinkphp微信开发教程(微信公众平台开发教程④ ThinkPHP框架下微信支付功能图文详解)
- python中return 类的实例(Python实现Event回调机制的方法)
- thinkphp5配置入口路径(ThinkPHP5.1框架数据库链接和增删改查操作示例)
- vue3 ref 的用法(Vue3中watchEffect的用途浅析)
- php服务器有哪些(php服务器的系统详解)
- mysql的默认隔离级别(再有人问你MySQL的隔离级别是什么,就把这篇文章发给他!)
- dedecms会员入驻(dedecms会员注册成功后直接跳转到验证的邮箱地址)
- python用指针合并两个有序数组(Python3实现计算两个数组的交集算法示例)
- django框架教程第100讲(详解Django+Vue+Docker搭建接口测试平台实战)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9