首页 游戏 软件 资讯 排行榜 专题
首页
数据库
mysql如何设置密码过期策略_配置default_password_life

mysql如何设置密码过期策略_配置default_password_life

热心网友
37
转载
2026-04-25

MySQL密码过期策略全面解析:从全局配置到用户级管理的实战指南

mysql如何设置密码过期策略_配置default_password_life

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

首先需要明确一个核心概念:default_password_lifetime 是 MySQL 5.7.4 及以上版本中,用于控制新创建用户默认密码有效期的全局系统变量,其计量单位是天。然而,这个变量存在一个至关重要的限制——它仅对新创建的用户账户生效,对数据库中已存在的用户没有任何影响。若要让现有用户的密码也遵循过期策略,必须使用 ALTER USER 语句进行显式配置。

default_password_lifetime 详解与常见失效原因

简而言之,default_password_lifetime 是 MySQL 自 5.7.4 版本起引入的全局变量,专门用于设定新账户的默认密码生存周期。然而,它最显著的特性,也恰恰是运维工作中最常见的误区:此变量仅作用于“新建用户”,对数据库内已有的存量用户完全无效。

一个典型的运维失误场景如下:管理员执行了 SET GLOBAL default_password_lifetime = 90; 命令,系统提示设置成功。但随后检查时发现,现有用户登录时一切正常,既未收到强制修改密码的提示,密码也未显示过期迹象。问题的根源在于,该变量的设计初衷就是管理“新生”账户,而非“存量”账户。

  • 要真正落实全库密码策略,必须结合 CREATE USERALTER USER 命令,为每个用户进行显式设定。
  • 从 MySQL 8.0.19 版本开始,此变量的默认值从 0(代表永不过期)调整为 360(即360天),但这一变更同样只适用于此后新建的用户。
  • 关于参数取值:设置为 0 表示该用户密码永不过期;设置为 NULL 则表示该用户继承全局的 default_password_lifetime 设置。

如何为现有用户配置密码过期策略(ALTER USER 实战用法)

那么,如何为数据库中已有的“存量”用户强制实施密码过期策略呢?答案是,不要期望通过修改全局变量来实现,必须使用 ALTER USER 命令进行显式指定。这是目前最可靠且标准的方法。

此方法在以下场景中尤为实用:运维团队进行批量账户安全加固时、为满足合规审计要求必须定期轮换密码时,或在测试环境中需要模拟密码过期流程时。

  • ALTER USER 'app_user'@'%' PASSWORD EXPIRE; —— 这是最“立竿见影”的方式,直接令密码立即过期,用户下次登录时必须更改密码。
  • ALTER USER 'app_user'@'%' PASSWORD EXPIRE INTERVAL 180 DAY; —— 相对温和的方式,设定密码在180天后过期。
  • ALTER USER 'app_user'@'%' PASSWORD EXPIRE NEVER; —— 取消该用户的密码过期策略。请特别注意,取消过期的关键字是 NEVER,而非 DEFAULT
  • 执行上述命令后无需重启MySQL服务,更改会立即生效。但需注意,它只影响用户下一次的认证过程,当前已建立的数据库连接不受影响。

如何查看用户密码过期状态及剩余有效天数

配置完成后,如何验证效果并查看状态呢?MySQL并未直接提供类似“days_until_expire”的字段来直观显示密码剩余天数。但我们可以通过查询 mysql.user 系统表,或使用 SHOW CREATE USER 命令来推断当前状态。

判断的关键,在于 password_expiredpassword_last_changed 这两个核心字段。

  • 最直接的查询语句:SELECT user, host, password_expired, password_last_changed FROM mysql.user WHERE user = 'app_user';
  • 查看用户创建语句:SHOW CREATE USER 'app_user'@'%'; —— 如果输出结果中包含 PASSWORD EXPIREPASSWORD EXPIRE INTERVAL 子句,则说明已配置过期策略。
  • 需要注意一个细节:password_last_changed 字段记录的是UTC时间。如需计算剩余天数,需手动结合 default_password_lifetime 的值进行计算,因为MySQL本身不提供自动计算剩余天数的功能。
  • 此外,请勿混淆概念。MySQL 8.0.19+ 版本引入了 password_reuse_history(密码重用历史)和 password_reuse_time(密码重用时间)等策略,它们管理的是密码能否被重复使用,与密码是否过期是两个独立的安全维度。

密码过期策略在主从复制与集群环境中的行为差异

在部署了主从复制或集群架构的生产环境中,密码过期策略的行为会存在一些差异。密码过期信息属于用户元数据的一部分,理论上会通过DDL语句同步到从库,但在同步时机和权限处理上,存在一些需要特别注意的细节。

理解这些差异,对于在高可用集群中统一管理账户生命周期、避免出现主库密码已过期但从库仍可登录的权限不一致问题,至关重要。

  • ALTER USER ... PASSWORD EXPIRE 是一条标准的DDL语句,它会被写入二进制日志(binlog),从而在从库回放时同样生效。
  • 但是,如果从库设置了 read_only=ON(只读模式),并且执行复制操作的用户在从库上没有 SUPER 权限,那么这条 ALTER USER 命令在从库回放时可能会报错:ERROR 1290 (HY000): The MySQL server is running with the --read-only option so it cannot execute this statement
  • 解决方案通常有两种:要么临时关闭从库的 read_only 模式(通常不推荐,存在安全风险),要么在拥有相应权限的情况下,手动在从库上再次执行相同的 ALTER USER 命令。
  • 还需要了解的是,如ProxySQL、MHA这类数据库中间件或高可用工具,它们本身并不感知MySQL内部的密码过期逻辑。因此,它们既不会拦截过期连接,也不会给出相关提示,密码过期的触发完全依赖于客户端直接连接MySQL服务器时的认证过程。

最后,分享一个实战中容易被忽略的关键点。真正的挑战往往不在于设置几个参数,而在于深刻理解两个底层机制:第一,default_password_lifetime 对老用户完全无效;第二,password_last_changed 这个时间戳不会自动刷新。例如,如果用户使用 SET PASSWORD 命令修改密码,该字段并不会更新。只有通过 ALTER USER ... IDENTIFIED BY 或特定的认证插件触发密码变更时,它才会被刷新。这一点在功能测试时特别容易遗漏,务必引起重视。

来源:https://www.php.cn/faq/2306752.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

mysql如何快速撤销所有库的写权限_MySQL全库GRANT逻辑修改
数据库
mysql如何快速撤销所有库的写权限_MySQL全库GRANT逻辑修改

MySQL全局写权限撤销:一个必须直面的“硬骨头” 当需要紧急锁定一个MySQL账户的写操作时,很多人的第一反应是执行一条“全局撤销”命令。但真相是,MySQL的权限体系里,压根就没有一个叫“全局写权限”的开关。这意味着,你无法像关灯一样,用一条命令就熄灭所有库的写入能力。那种试图用REVOKE I

热心网友
04.25
mysql如何写一条简单的查询语句_mysql查询基础操作
数据库
mysql如何写一条简单的查询语句_mysql查询基础操作

MySQL查询入门指南:掌握核心语法与常见避坑技巧 编写SELECT查询语句是操作MySQL数据库的基础技能,看似简单却暗藏诸多细节。无论是数据库新手还是经验丰富的开发者,都可能在这些基础环节遇到问题。从语句的基本结构到字符集配置,每一个步骤都需要准确理解,才能确保查询高效、稳定地执行。 SELEC

热心网友
04.25
MySQL主从切换后如何恢复原始架构_重建从库数据的方法
数据库
MySQL主从切换后如何恢复原始架构_重建从库数据的方法

主从切换后如何恢复原始架构:重建从库数据的方法 主从切换后原主库变从库,CHANGE REPLICATION SOURCE TO 报错 ERROR 3021 主从角色互换后,想把原来的主库重新配置成从库,结果一执行 CHANGE REPLICATION SOURCE TO 就碰钉子——ERROR 3

热心网友
04.25
mysql主从复制的锁机制会影响性能吗_性能调优说明
数据库
mysql主从复制的锁机制会影响性能吗_性能调优说明

MySQL主从复制无复制锁,但从库SQL Thread单线程回放易因大事务、DDL等引发MDL锁或行锁阻塞,导致延迟;优化需启用多线程复制、避免从库DDL、控制事务粒度并监控锁等待。 主从复制本身不加锁,但写操作和同步延迟会间接引发锁竞争 说到MySQL主从复制,一个常见的误解是复制过程本身会“加锁

热心网友
04.25
mysql安装时依赖包缺失如何解决_mysql依赖环境快速修复
数据库
mysql安装时依赖包缺失如何解决_mysql依赖环境快速修复

MySQL安装依赖缺失?别慌,这份快速修复指南帮你搞定 在部署MySQL数据库时,最令人沮丧的情况莫过于一切准备就绪,却在启动或初始化阶段遭遇依赖错误。这些看似复杂的问题,通常都有明确的解决方案。本文将详细梳理MySQL安装过程中最常见的依赖和环境问题,并提供精准、高效的修复步骤,助你快速完成数据库

热心网友
04.25

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

COD救不了XGP!分析师早已预料到降价:毫不意外
游戏评测
COD救不了XGP!分析师早已预料到降价:毫不意外

微软调整XGP战略:降价与《使命召唤》延期入库的背后 最近游戏圈有个大消息:微软宣布下调Xbox Game Pass Ultimate和PC Game Pass的月度订阅价格。具体来看,Ultimate档位从每月29 99美元降到了22 99美元,PC Game Pass则从16 49美元降至13

热心网友
04.25
XGP迎重大变革!降价还没完 还有“自选套餐”模式
游戏评测
XGP迎重大变革!降价还没完 还有“自选套餐”模式

2026年,Xbox新掌门的第一把火:Game Pass要变“自助餐”了 2026年2月,阿莎·夏尔马接棒菲尔·斯宾塞,成为Xbox的新任CEO。这位新官上任,动作可谓雷厉风行。就在昨天,她点燃了第一把火:Xbox Game Pass Ultimate的月费,从29 99美元直接降到了22 99美元

热心网友
04.25
《AC起源》男主劝退
游戏评测
《AC起源》男主劝退"乔尔"演员做游戏:这行太残酷!

当明星演员想开游戏工作室:资深同行为何直言“别这么做”? 最近,游戏圈里发生了一场有趣的隔空对话。为《最后生还者》《死亡搁浅》等大作献声的知名演员特洛伊·贝克,在采访中透露了一个雄心勃勃的计划:他想创立自己的游戏工作室,去讲述“自己的故事”。他甚至提到,自己的灵感来源之一,正是曾为《刺客信条:起源》

热心网友
04.25
突发!Steam新手柄售价曝光:评测已偷跑!
游戏评测
突发!Steam新手柄售价曝光:评测已偷跑!

Steam新款手柄评测视频意外流出,定价信息同步曝光 游戏硬件圈最近有个不大不小的“意外”。根据海外多个科技消息源的报道,Valve即将推出的新款Steam Controller手柄,其评测视频竟然提前在网上泄露了。更关键的是,视频里还直接公布了这款产品的售价:99美元。 事情是这样的:一个名为“T

热心网友
04.25
索尼新规主机断网不让玩:内部人士回应了!
游戏评测
索尼新规主机断网不让玩:内部人士回应了!

此前,外网消息源透露,目前PlayStation在PS4和PS5的数字版游戏中加入了DRM验证(正版在线验证)机制。 前情提要>> 简单来说,这个新机制的效果是这样的:从今往后,如果你通过数字商店购买新游戏,那么主机就必须定期连接到PSN网络进行正版验证。具体规则是,如果主机连续超过30天处于离线状

热心网友
04.25