剑指MySQL:架构、调优与运维
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人

1.5 MySQL 8.0的密码强度评估

1.5.1 MySQL不同版本的密码设置

出于安全考虑,用户需要隔一段时间修改一次数据库密码。如果用户使用的是MySQL 8.0以前的版本,那么可以直接执行如下SQL语句修改数据库密码。

但是,在MySQL 8.0中执行上述语句会报错,如下所示。这是因为MySQL 8.0的密码安全策略与之前版本的密码安全策略有些许差别。

1.5.2 MySQL 8.0的密码安全策略

MySQL 8.0以前版本采用的是validate_password插件检测、验证账号密码强度的形式来保障账号的安全性,而MySQL 8.0采用的是组件形式来保障账号的安全性。

1.validate_password组件说明

MySQL 8.0引入了服务器组件(Components)这个特性,validate_password插件已被服务器采用组件的形式重新实现。在MySQL 8.0.25中,默认自动安装validate_password组件。

在MySQL 8.0中使用如下SQL语句查看组件。

下面解释一下validate_password组件对应的系统变量,如表1-1所示。

表1-1 validate_password组件对应的系统变量

这些系统变量在MySQL 5.7和MySQL 8.0中的默认值可能有所不同。例如,在MySQL 5.7中,validate_password.check_user_name变量的默认值为OFF。

2.修改密码安全策略强度

表1-1中的系统变量validate_password.policy用于设置密码安全策略强度。有3种密码安全策略强度可供使用,分别是LOW(低等级)、MEDIUM(中等级)和STRONG(强等级)。在MySQL 8.0中,修改密码安全策略强度的SQL语句如下所示。

或者使用如下SQL语句修改密码安全策略强度。

在MySQL 5.7中,修改密码安全策略强度的SQL语句如下所示,区别在于将半角句号“.”修改为下画线“_”。

3.密码复杂度测试

我们在修改密码的时候,曾遇到“Your password does not satisfy the current policy requirements”这样的问题,这是因为密码复杂度不够,加大密码复杂度即可。

在设置密码前,可以通过函数组件来测试密码复杂度是否满足条件,评分在0~100分之间,评分越高,表示密码复杂度越高。当评分为100分时,说明使用了“大写字母+小写字母+特殊字符+数字”的8位以上密码。

例如,当密码为“medium”时,评分为25分,如下所示,表示密码复杂度很低。

又如,当密码为“K354*45jKd5”时,评分为100分,如下所示,表示密码复杂度很高。

如果没有安装validate_password组件,那么VALIDATE_PASSWORD_STRENGTH()函数永远返回0。密码复杂度对应的评分如表1-2所示。

表1-2 密码复杂度对应的评分