Linux配置用户密码过期时间的方法

配置Linux用户密码过期时间主要通过chage命令管理单个用户和修改/etc/login.defs设置新用户默认策略。使用chage -M、-W、-m等选项可设定密码最长有效期、警告天数和最短修改间隔,如sudo chage -M 90 -W 7 testuser使密码90天后过期并提前7天警告;通过编辑/etc/login.defs中的PASS_MAX_DAYS等参数可为新用户设定默认策略,例如PASS_MAX_DAYS 90。查看用户策略用chage -l username,输出包含密码修改、过期、警告等详细信息。批量修改现有用户需结合awk解析/etc/passwd筛选普通用户,并在循环中调用chage命令,如for user in $(awk -F: ‘$3>=1000 && $1!=”nobody” {print $1}’ /etc/passwd); do sudo chage -M 90 -W 7 “$user”; done。实际应用中需注意服务账户处理、避免频繁过期导致弱密码问题,推荐结合密码复杂度、历史限制和多因素认证(MFA)提升安全性,同时定期审计日志并进行安全意识培训,构建纵深防御体系。

linux配置用户密码过期时间的方法

在Linux系统中,配置用户密码的过期时间主要通过

chage

命令以及修改

/etc/login.defs

文件来实现。这两种方法各有侧重,

chage

用于管理单个现有用户的密码策略,而

/etc/login.defs

则设定了新创建用户的默认密码策略。这是一个核心的安全实践,旨在强制用户定期更新密码,从而降低因密码泄露或猜测而导致的安全风险。

解决方案

要具体配置Linux用户密码的过期时间,我们通常会用到以下几种方法:

首先,对于单个现有用户

chage

命令是你的首选工具。这个命令非常强大,可以精细控制用户的密码有效期、最短修改间隔、过期前警告天数以及账户本身的失效日期。

比如,你想让用户

testuser

的密码在90天后过期,并且在过期前7天开始警告他:

sudo chage -M 90 -W 7 testuser

这里的

-M 90

表示密码最长有效期是90天,

-W 7

表示在密码过期前7天开始提醒用户。

如果你想设置用户密码至少在3天后才能再次修改(避免用户立即改回旧密码),可以这样做:

sudo chage -m 3 testuser

-m 3

就是设置密码最短修改间隔为3天。

还有一种情况,如果用户密码已经过期,但你希望给他一个宽限期,比如10天,让他在这10天内登录并修改密码,否则账户将被锁定:

sudo chage -I 10 testuser

这里的

-I 10

设置了密码过期后的非活动天数。

甚至,你可以直接设置一个账户的最终过期日期,到那天无论密码是否过期,账户都会失效:

sudo chage -E 2024-12-31 testuser

这在管理临时账户或者项目结束时非常有用。

其次,对于新创建的用户,我们希望他们一开始就遵循一定的密码策略,这时就需要修改

/etc/login.defs

文件。这个文件定义了系统范围内用户和密码管理的默认参数。

打开

/etc/login.defs

文件(通常需要root权限):

sudo vi /etc/login.defs

你会看到类似这样的几行(可能被注释掉了):

#PASS_MAX_DAYS   99999#PASS_MIN_DAYS   0#PASS_WARN_AGE   7
PASS_MAX_DAYS

:设置密码最长有效期,例如将其改为

PASS_MAX_DAYS 90

,那么新创建的用户密码默认将在90天后过期。

PASS_MIN_DAYS

:设置密码最短修改间隔,例如

PASS_MIN_DAYS 3

,新用户密码修改后至少3天才能再次修改。

PASS_WARN_AGE

:设置密码过期前多少天开始警告用户,例如

PASS_WARN_AGE 7

需要注意的是,修改

/etc/login.defs

文件只对之后创建的用户生效,对已经存在的用户没有任何影响。所以,如果你想对现有用户应用新的全局策略,你可能还需要结合

chage

命令进行批量操作。

如何查看Linux用户密码的当前过期策略?

了解一个用户的密码策略是管理工作的基础。在Linux中,最直接、最准确的方式就是使用

chage

命令,加上

-l

(list)选项,后面跟上用户名。

例如,要查看用户

testuser

的密码过期信息:

sudo chage -l testuser

输出会非常详细,通常包含以下几项:

美间AI 美间AI

美间AI:让设计更简单

美间AI 45 查看详情 美间AI

Last change                               : Jul 15, 2024  # 上次密码修改日期Password expires                          : Oct 13, 2024  # 密码过期日期Password inactive                         : never         # 密码过期后账户非活动天数,never表示永不非活动Account expires                           : never         # 账户过期日期,never表示永不失效Minimum number of days between password change    : 0       # 两次密码修改之间的最短天数Maximum number of days between password change    : 90      # 两次密码修改之间的最长天数Number of days of warning before password expires : 7       # 密码过期前警告天数

通过这些信息,你可以清晰地知道当前用户的密码状态和策略。如果

Password expires

显示为

never

,通常意味着该用户没有设置密码过期策略,或者其

PASS_MAX_DAYS

被设置为一个非常大的值。

除了

chage -l

,你也可以查看

/etc/login.defs

文件来了解系统默认的密码策略。但请记住,这只是默认值,不代表所有现有用户的实际情况。现有用户的实际策略存储在

/etc/shadow

文件中,

chage

命令就是读取和修改这个文件来工作的,但我们通常不直接编辑

shadow

文件,因为它包含了敏感的密码哈希信息,直接编辑容易出错且不安全。

如何为新用户设置默认密码过期策略,并批量修改现有用户?

为新用户设置默认密码策略,我们刚才提到了,主要就是通过编辑

/etc/login.defs

文件。这是系统级别的配置,一旦修改并保存,之后通过

useradd

命令创建的任何新用户都会继承这些设置。

例如,如果你想让所有新用户默认密码90天过期,最短修改间隔5天,过期前10天警告:

sudo vi /etc/login.defs

找到并修改(或取消注释)以下行:

PASS_MAX_DAYS   90PASS_MIN_DAYS   5PASS_WARN_AGE   10

保存并退出。之后创建的用户,比如

sudo useradd newuser

,就会自动应用这些策略。

至于批量修改现有用户的密码过期策略,这在企业环境中非常常见,比如为了满足合规性要求,需要对所有普通用户强制执行新的密码过期规则。这时,我们可以结合

chage

命令和Shell脚本的循环功能。

一个常见的场景是,我们想把所有普通用户的密码最长有效期都设置为90天。首先,我们需要获取所有普通用户的列表。通常,UID大于1000(或特定发行版如CentOS 500)且不是

nobody

的用户被认为是普通用户。

你可以这样做:

for user in $(awk -F: '$3 >= 1000 && $1 != "nobody" {print $1}' /etc/passwd); do    echo "Processing user: $user"    sudo chage -M 90 -W 7 "$user"    # 如果还需要设置最短修改间隔,可以加上 -m    # sudo chage -m 3 "$user"done

这段脚本会遍历

/etc/passwd

文件,筛选出UID大于等于1000且用户名不是

nobody

的用户,然后对每个用户执行

chage -M 90 -W 7

命令,将其密码最长有效期设置为90天,并在过期前7天发出警告。

重要提示: 在执行任何批量操作之前,务必先在一个测试环境或对少量用户进行测试。同时,要仔细考虑是否需要排除某些特殊的服务账户或系统账户,因为它们可能不适合遵循标准的密码过期策略(例如,某些自动化脚本使用的账户可能依赖于长期不变的密码或密钥认证)。错误的批量操作可能会导致大量用户无法登录,造成生产环境中断。

密码过期策略的常见挑战、最佳实践与安全性考量

密码过期策略听起来很美,但实际落地时,我们往往会遇到一些挑战,并且需要结合最佳实践和更广阔的安全性视角来考量。

常见挑战:

用户体验与弱密码问题: 最常见的抱怨就是“密码改得太频繁了,我记不住”。这导致用户可能采取一些不安全的行为,比如使用非常简单、容易猜测的密码(比如

password123

),或者更糟糕的是,将密码写在便利贴上、保存在未加密的文档中。讽刺的是,强制过期反而可能降低实际的密码强度。管理复杂性: 频繁的密码过期会导致更多的用户忘记密码,从而增加IT支持团队的工作量。账户锁定也是一个常见问题,尤其是当用户尝试次数过多导致账户被锁定,需要管理员介入解锁。服务账户与自动化脚本: 很多自动化任务、服务或应用程序会使用特定的用户账户来运行。这些账户的密码如果强制过期,可能会导致服务中断,因为它们通常不具备交互式登录来修改密码的能力。处理这类账户的密码过期是一个特殊的挑战。

最佳实践:

平衡过期频率与复杂度要求: 过于频繁的过期(比如30天)往往适得其反。一个更合理的周期可能是90到180天。更重要的是,应该结合强制性的密码复杂度要求(长度、大小写、数字、特殊字符)和历史密码限制(不允许使用最近N次用过的密码)。这样,即使密码不经常过期,其强度也能得到保证。教育用户: 仅仅强制过期是不够的,还需要对用户进行安全意识培训,让他们理解为什么需要设置强密码、如何创建易记但难猜的密码,以及密码管理的重要性。多因素认证 (MFA): 这绝对是现代安全实践的基石。如果你的系统支持MFA,那么在很大程度上,MFA可以弥补单一密码的不足。在MFA的保护下,甚至可以适当放宽密码过期要求,因为即使密码被盗,攻击者也无法仅凭密码登录。服务账户的特殊处理: 对于自动化脚本或服务账户,尽量避免使用需要定期修改的密码。优先考虑使用密钥对认证(SSH密钥)、API令牌、或者专业的秘密管理工具(如HashiCorp Vault、AWS Secrets Manager)来管理凭据。这些方法通常比定期修改密码更安全、更易于管理。定期审计与日志监控 无论密码策略如何,都应该定期审计用户账户活动和系统日志,以便及时发现异常行为,这比单纯依赖密码过期要有效得多。

安全性考量:

密码过期策略是“纵深防御”安全策略中的一环,但它绝不是银弹。一个完善的安全体系需要多方面协同工作:

强密码策略本身: 不仅是过期,还有长度、复杂度和历史限制。多因素认证 (MFA)。最小权限原则: 用户和应用程序只拥有完成任务所需的最小权限。入侵检测与预防系统 (IDS/IPS)。安全补丁管理: 及时更新系统和应用程序,修复已知漏洞。安全意识培训。日志审计与监控。

在我看来,盲目追求“密码过期越频繁越安全”的观念是片面的,甚至可能适得其反。我们应该更注重密码的整体强度和多因素认证的部署,将密码过期策略作为一个辅助手段,并根据实际业务需求和风险评估来制定,而不是一刀切地强制执行。毕竟,一个强壮但永不过期的密码,可能比一个频繁更换但每次都换成“password123”的密码要安全得多。

以上就是Linux配置用户密码过期时间的方法的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何在电脑上屏蔽广告弹窗 广告拦截软件使用技巧
上一篇 2025年11月7日 13:25:08
如何自定义Laravel的用户认证逻辑?
下一篇 2025年11月7日 13:25:10

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • Debian syslog性能优化技巧有哪些

    提升Debian系统syslog (通常基于rsyslog)性能,关键在于精简配置和高效处理日志。以下策略能有效优化日志管理,提升系统整体性能: 精简配置,高效加载: 在rsyslog配置文件中,仅加载必要的输入、输出和解析模块。 使用全局指令设置日志级别和格式,避免不必要的处理。 自定义模板: 创…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • 理解编程指令:当结果正确,但实现方式不符要求时

    本文探讨了在编程实践中,即使程序输出了正确的结果,但若其实现方式未能严格遵循既定指令,仍可能被视为“不正确”的问题。我们将通过具体示例,对比直接求和与累加求和两种实现策略,强调理解和遵守编程规范的重要性,以确保代码的健壮性、可维护性及符合项目要求。 在软件开发过程中,我们经常会遇到这样的情况:编写的…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    100
  • 网站标题关键词更新后,搜索引擎为何仍显示旧标题?

    网站标题更新后,搜索引擎为何显示旧标题? 网站SEO优化中,站长常修改网站标题关键词,期望搜索结果显示自定义标题。然而,即使更新标签、meta keywords、meta description和结构化数据中的name属性后,搜索结果仍显示旧标题,这令人费解。本文将对此进行解释。 问题:站长修改了网…

    2026年5月10日
    100
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • 如何插入查询结果数据_SQL插入Select查询结果方法

    如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法

    使用INSERT INTO…SELECT语句可高效插入数据,通过NOT EXISTS、LEFT JOIN、MERGE语句或唯一约束避免重复;表结构不一致时可通过别名、类型转换、默认值或计算字段处理;结合存储过程可提升可维护性,支持参数化与动态SQL。 将查询结果数据插入到另一个表中,可以…

    2026年5月10日 用户投稿
    000
  • Discord.py 交互按钮超时与持久化解决方案

    本教程旨在解决Discord.py中交互按钮在一段时间后出现“This Interaction Failed”错误的问题。我们将深入探讨视图(View)的超时机制,并提供通过正确设置timeout参数以及利用bot.add_view()方法实现按钮持久化的具体方案,确保您的机器人交互功能稳定可靠,即…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    100
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • JavaScript函数中插入加载动画(Spinner)的正确方法

    本文旨在解决在JavaScript函数中插入加载动画(Spinner)时遇到的异步问题。通过引入async/await和Promise.all,确保在数据处理完成前后正确显示和隐藏加载动画,提升用户体验。我们将提供两种实现方案,并详细解释其原理和优势。 在Web开发中,当执行耗时操作时,显示加载动画…

    2026年5月10日
    100
  • JS如何实现迭代器?迭代器协议

    JavaScript中实现迭代器需遵循可迭代协议和迭代器协议,通过定义[Symbol.iterator]方法返回具备next()方法的迭代器对象,从而支持for…of和展开运算符;该机制统一了数据结构的遍历接口,实现惰性求值,适用于自定义对象、树、图及无限序列等复杂场景,提升代码通用性与…

    2026年5月10日
    100

发表回复

登录后才能评论
关注微信