MySQL 安全管理[通俗易懂]

MySQL 安全管理[通俗易懂]权限表 MySQL 服务器通过权限表来控制用户对数据库的访问,由 mysql_install_db 脚本初始化,MySQL 会根据这些权限表的内容为每个用户赋予相应的权限 1. user 表 user

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 基于以下规则来限制密码重用:

  1. 如果账户密码限制基于密码更改的数量,那么新密码不能从最近限制的密码数量中选择,例如,如果密码更改的最小值为3,那么新密码不能与最近3个密码中任何一个相同
  2. 如果账户密码限制基于时间,那么新密码不能从规定时间内选择,例如,如果重用周期为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 PRIVILEGESG;

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]...

原文地址:https://www.cnblogs.com/Yee-Q/archive/2022/05/01/16213136.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5319.html

(0)
上一篇 2023-05-14 13:30
下一篇 2023-05-14

相关推荐

  • 来聊聊我对华为终端云服务的看法![通俗易懂]

    来聊聊我对华为终端云服务的看法![通俗易懂]     什么是智慧生活?如何做到智慧生活?智慧生活有哪些体验?我认为华为终端云服务可以让用户更好的感知智慧生活的美好。   所有用户,都可以享受华为终端云服务所带来的更便利、更健康、更简单的智慧生…

    2023-02-08
    158
  • Python函数中return的用法总结

    Python函数中return的用法总结Python是一种高级编程语言,其拥有强大的功能,其中函数是Python编程中至关重要的组成部分。在Python中,每个函数都返回一个值,这个值可以是任何类型的。该值由codereturn/code语句定义。如果函数没有返回值,则可以省略该语句。

    2024-08-24
    30
  • 如何在Python中跳出循环

    如何在Python中跳出循环在使用Python编写程序时,有时候需要在满足特定条件的情况下终止程序的一个循环。本篇文章将会对如何在Python中跳出循环进行详细的介绍。

    2024-05-01
    73
  • Python实现温度转换

    Python实现温度转换温度转换是常见的工程计算之一,因为世界上各个国家和地区,对温度的表示方法不尽相同。其中最常用的两种是摄氏度和华氏度。本文将通过Python实现温度转换过程,以加深读者对温度转换的理解和应用。

    2024-09-16
    23
  • mysql5.7.32解压版安装_mysql5.7安装教程

    mysql5.7.32解压版安装_mysql5.7安装教程下载 mysql 的 解压版安装文件mysql-5.7.25-winx64.zip D:mysqlmaster D:mysqlsalve 分别新建 data 和 binlog 目录,以及配置文件 m…

    2023-02-12
    146
  • PostgreSQL公开课(第19期)-Toast技术特点与应用

    PostgreSQL公开课(第19期)-Toast技术特点与应用PostgreSQL公开课(第19期)-Toast技术特点与应用 1、Toast简介 2、Toast的存储方式 3、Toast4种压缩策略 4、Toast表的计算方式 5、Toast表的优点与缺点 …

    2023-03-27
    153
  • Python工程师:掌握Exp计算的基本技能

    Python工程师:掌握Exp计算的基本技能计算机科学中,Exponential(指数)函数非常普遍。在Python中,我们可以使用math模块中的exp()函数来计算。然而,对于大规模数据的处理或复杂的计算,我们需要更高效的方法来计算Exp函数。

    2024-06-11
    51
  • Python中timedelta函数的详细解析

    Python中timedelta函数的详细解析时间是人类社会发展的必然产物,而对于任何研究、计算与管理时间的系统,其中最基础的概念就是时间差,也被称为时间间隔、时间距离等等。这个概念在计算机语言中得到了广泛应用,比如Python中的timedelta函数。timedelta函数是Python里处理时间差的一个库,它提供了一些方法来处理日期、时间、日期时间、时间间隔、时间段等数据,可以方便地对时间进行加减、日期计算、时间差的计算等操作。

    2024-05-27
    70

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注