MySQL数据库必知必会之安全管理
来源:脚本之家
时间:2023-01-07 12:08:20 468浏览 收藏
亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《MySQL数据库必知必会之安全管理》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下安全、MySQL数据库,希望所有认真读完的童鞋们,都有实质性的提高。
权限表
MySQL 服务器通过权限表来控制用户对数据库的访问,由 mysql_install_db 脚本初始化,MySQL 会根据这些权限表的内容为每个用户赋予相应的权限
1. user 表
user 表是 MySQL 最重要的一个权限表,有 49 个字段,这些字段可以分成四类:
- 范围列:包括 Host、User,分别表示主机名、用户名,Host 指明允许访问的 IP 或主机范围,User 指明允许访问的用户名
- 权限列:权限列字段描述用户在全局范围内允许进行的操作,该列的字段值类型为 ENUM,只能取 Y 和 N
- 安全列:安全列有 12 个字段,其中两个和 ssl 相关、两个和 x509 相关、其他八个是授权插件和密码相关
- 资源控制列:用于限制用户使用的资源,一个小时内用户查询或连接数量超过资源控制限制将被锁定,知道下一个小时才可以再次执行
2. db 表
db 表存储用户对某个数据库的操作权限,决定用户能从哪个主机存取哪个数据库,大致可以分为两类字段:
- 用户列:用户列有三个字段,分别是 Host、Db 和 User,分别表示主机名、数据库名和用户名
- 权限列:决定用户是否具有创建和修改存储过程的权限
3. tables_priv 表
tables_priv 表用来对表设置操作权限,有八个字段:
- Host、Db、User 和 Table_name 四个字段分别表示主机名、数据库名、用户名和表名
- Grantor 表示修改记录的用户
- Timestamp 表示修改该记录的时间
- Table_priv 表示对象操作权限。包括 Select、Insert、Delete 等
- Column_priv 表示对表中的列的操作权限,包括 Select、Insert、Update 和 References
4. columns_priv 表
columns_priv 表用来对表的某一列设置权限,字段 Column_name 用来指定对哪些数据列具有操作权限
账户管理
1. 新建普通用户
在 MySQL8 以前可以使用 GRANT 语句新建用户,MySQL8 以后需要先创建用户才能执行 GRANT 语句
CREATE USER user[IDENTIFIED BY 'password'][,user[IDENTIFIED BY 'password']]...
user 参数表示新建用户的账户,由用户(User)和主机名(Host)构成,形式如 Justin@localhost,IDENTIFIED BY 关键字用来设置用户的密码,password 参数表示用户密码,可以同时创建多个用户,新用户可以没有初始密码
2. 删除普通用户
DROP USER user[,user]...
user 参数表示新建用户的账户,由用户(User)和主机名(Host)构成,可以同时删除多个用户
也可以使用 DELETE 语句直接将用户信息从 mysql.user 表删除,前提是拥有对 mysql.user 表的删除权限
DELETE FROM mysql.user WHERE Host='hostname' AND User='username';
3. Root 用户修改自己的密码
root 用户可以使用 ALTER 命令修改密码
ALTER USER USER() IDENTIFIED BY 'new_password'
也可以使用 SET 语句修改密码
SET PASSWORD='new_password'
4. Root 用户修改普通用户的密码
root 用户可以使用 ALTER 命令修改普通用户的密码
ALTER USER user [IDENTIFIED BY 'new_password'][,user [IDENTIFIED BY 'new_password']]...
也可以使用 SET 语句修改普通用户的密码
SET PASSWORD FOR 'username'@'hostname'='new_password'
普通用户也可对自己的密码进行管理,方式与 Root 用户相同
密码管理
1. 密码过期策略
数据库管理员可以手动设置账号密码过期,也可以建立一个自动密码过期策略。过期策略可以是全局的,也可以为每个账号设置单独的过期策略
手动设置账号密码过期:
ALTER USER user PASSWORD EXPIRE
密码过期策略基于最后修改密码的时间自动将密码设置为过期,MySQL 使用 default_password_lifetime 系统变量建立全局密码过期策略,默认值为 0 表示不使用自动过期策略。它允许的值是正整数 N,表示密码必须每隔 N 天进行修改。该值可在服务器的配置文件设置,也可以使用 SQL 语句设置,使用 SQL 语句方式如下:
SET PERSIST default_password_lifetime=180
每个账号既可沿用全局密码过期策略,也可单独设置策略
# 设置账号密码90天过期 CREATE USER 'Justin@localhost' PASSWORD EXPIRE INTERVAL 90 DAY; ALTER USER 'Justin@localhost' PASSWORD EXPIRE INTERVAL 90 DAY; # 设置账号密码永不过期 CREATE USER 'Justin@localhost' PASSWORD EXPIRE NEVER; ALTER USER 'Justin@localhost' PASSWORD EXPIRE NEVER; # 沿用全局密码过期策略 CREATE USER 'Justin@localhost' PASSWORD EXPIRE DEFAULT;
2. 密码重用策略
MySQL 限制使用已用过的密码,重用限制策略基于密码更改时间和使用时间,可以是全局的,也可以为每个账号设置单独的策略
MySQL 基于以下规则来限制密码重用:
- 如果账户密码限制基于密码更改的数量,那么新密码不能从最近限制的密码数量中选择,例如,如果密码更改的最小值为3,那么新密码不能与最近3个密码中任何一个相同
- 如果账户密码限制基于时间,那么新密码不能从规定时间内选择,例如,如果重用周期为60天,那么新密码不能从最近60天内使用的密码中选择
可以在配置文件设置密码重用策略,也可以使用 SQL 语句
# 密码重用数量 SET PERSIST password_history=6; # 密码重用周期 SET PERSIST password_reuse_interval=365;
每个账号既可沿用全局密码重用策略,也可单独设置策略
# 不能使用最近5个密码 CREATE USER 'Justin@localhost' PASSWORD PASSWORD HISTORY 5; ALTER USER 'Justin@localhost' PASSWORD PASSWORD HISTORY 5; # 不能使用最近365天内的密码 CREATE USER 'Justin@localhost' PASSWORD REUSE INTERVAL 365 DAY; ALTER USER 'Justin@localhost' PASSWORD REUSE INTERVAL 365 DAY;
角色
在 MySQL 中,角色是权限的集合,可以为角色添加或移除权限。用户可以被赋予角色,同时也被赋予角色包含的权限
1. 创建角色并授权
创建角色语句如下:
CREATE ROLE 'role_name'[@'host_name'][,'role_name'[@'host_name']]...
为角色授权语句如下:
GRANT privileges ON table_name TO 'role_name'[@'host_name'];
privileges 代表权限的名称,多个权限以逗号1隔开,可以使用 SHOW 语句查询权限名称
SHOW PRIVILEGES\G;
2. 给用户添加角色
GTANT role[,role2,...] TO user[,user2,...];
role 代表角色,user 代表用户,添加之后如果角色处于未激活状态,需要先将用户对应的角色激活
SET ROLE DEFAULT
3. 编辑角色或权限
撤销用户角色的 SQL 语句如下:
REVOKE role FROM user;
撤销角色权限的 SQL 语句如下:
REVOKE privileges ON tablename FROM 'rolename';
4. 删除角色
DROP ROLE role[,role2]...
总结
理论要掌握,实操不能落!以上关于《MySQL数据库必知必会之安全管理》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
320 收藏
-
346 收藏
-
162 收藏
-
443 收藏
-
251 收藏
-
214 收藏
-
155 收藏
-
485 收藏
-
436 收藏
-
125 收藏
-
174 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 笑点低的花瓣
- 这篇文章真是及时雨啊,太详细了,赞 👍👍,码住,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-18 01:32:13
-
- 爱笑的店员
- 很好,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享文章内容!
- 2023-01-15 03:06:30
-
- 俊逸的日记本
- 细节满满,已收藏,感谢大佬的这篇技术文章,我会继续支持!
- 2023-01-12 13:30:39
-
- 有魅力的网络
- 这篇文章内容真及时,细节满满,感谢大佬分享,已加入收藏夹了,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-01-10 16:46:15
-
- 无聊的缘分
- 这篇文章内容真是及时雨啊,博主加油!
- 2023-01-09 20:09:00
-
- 闪闪的狗
- 这篇技术贴真及时,细节满满,感谢大佬分享,收藏了,关注大佬了!希望大佬能多写数据库相关的文章。
- 2023-01-09 04:28:33
-
- 单纯的高山
- 太全面了,已收藏,感谢博主的这篇文章内容,我会继续支持!
- 2023-01-08 17:10:42
-
- 动听的发夹
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者分享技术贴!
- 2023-01-08 14:07:47