MySQL8密码复杂度设置

在MySQL中,密码复杂度设置可以通过调整密码验证插件的配置参数来实现。MySQL 8.0 引入了 validate_password 插件,用于强制实施密码策略。

查询是否已安装的插件:show plugins;确认是否已安装插件validate_password

查询mysql插件目录位置:show variables like "%plugin_dir%";

确认插件:validate_password.dll

安装方式一(无需重启):

install plugin validate_password soname 'validate_password.dll';

INSTALL PLUGIN validate_password SONAME 'validate_password.so';

安装方式二(需要重启服务):

mysqld

plugin-load=validate_password=validate_password.dll

设置密码安全策略:

set global validate_password_policy=2

有三种取值,分别是0、1和2。

0-表示低策略,密码长度至少为8位;

1-表示中策略,密码长度至少为8位,必须包含大小写字母、数字和特殊字符;

2-表示高策略,密码长度至少为8位,必须包含大小写字母、数字、特殊字符和字典词汇检查。

默认参数值:

validate_password_check_user_name ON

validate_password_dictionary_file

validate_password_length 8

validate_password_mixed_case_count 1

validate_password_number_count 1

validate_password_policy MEDIUM

validate_password_special_char_count 1

validate-password=ON/OFF/FORCE/FORCE_PLUS_PERMANENT: 决定是否使用该插件(及强制/永久强制使用)。

validate_password_dictionary_file:插件用于验证密码强度的字典文件路径。

validate_password_length:密码最小长度。

validate_password_mixed_case_count:密码至少要包含的小写字母个数和大写字母个数。

validate_password_number_count:密码至少要包含的数字个数。

validate_password_policy:密码强度检查等级,0/LOW、1/MEDIUM、2/STRONG。

validate_password_special_char_count:密码至少要包含的特殊字符数。

其中,关于validate_password_policy-密码强度检查等级:

0/LOW:只检查长度。

1/MEDIUM:检查长度、数字、大小写、特殊字符。

2/STRONG:检查长度、数字、大小写、特殊字符字典文件。

设置案例:

mysqld

default_password_lifetime=90

plugin-load=validate_password=validate_password.dll

validate-password=FORCE_PLUS_PERMANENT

validate_password_length = 12

validate_password_number_count = 2

validate_password_special_char_count = 1

validate_password_mixed_case_count = 1

validate_password_policy = STRONG

password_reuse_interval

查看参数:

show variables like '%validate_password%';

相关推荐
我不听你讲话1 小时前
关系型与非关系型数据库视角下的 MySQL:特性解析与 Linux 部署实践
linux·mysql·nosql
原来是猿7 小时前
MySQL【内置函数】
数据库·mysql
FirstFrost --sy9 小时前
MySQL关于表的操作
数据库·mysql
Y0011123611 小时前
Day8-MySQL-多表查询-1
数据库·sql·mysql
V1ncent Chen12 小时前
SQL大师之路 13 聚合函数和分组
数据库·sql·mysql·数据分析
翻斗包菜14 小时前
MySQL 从入门到精通:数据库核心知识与实战指南
数据库·mysql
grizzliesster214 小时前
MySQL——表的约束
数据库·mysql
卤炖阑尾炎15 小时前
MySQL 数据库初体验:从基础概念到服务部署全攻略
数据库·mysql·oracle
hongtianzai15 小时前
MySQL中between and的基本用法
android·数据库·mysql
艾莉丝努力练剑16 小时前
【MYSQL】MYSQL学习的一大重点:数据库基础
linux·运维·服务器·数据库·c++·学习·mysql