Linuxでユーザーのパスワード期限を確認・管理する方法

この記事では、Linux環境でユーザーのパスワード期限を確認する方法について詳しく解説します。具体的なコード例とその解説、さらに実用的な応用例を4つ以上紹介します。

目次

なぜパスワード期限確認が重要か

システムのセキュリティを維持するためには、定期的なパスワードの変更が推奨されます。特に多数のユーザーを管理するシステム管理者にとって、各ユーザーのパスワード期限を把握することは非常に重要です。

基本的な確認方法

Linuxでは`chage`コマンドを用いて、ユーザーのパスワード期限を確認することができます。

sudo chage -l username  # username のパスワード期限を確認

このコマンドで出力される情報には、最後にパスワードが変更された日、次に変更する必要がある日、アカウントが無効になる日などが含まれます。

出力の読み方

`chage -l` コマンドの出力は次のような形式になります。

“`
Last password change : Jan 01, 2020
Password expires : never
Password inactive : never
Account expires : never
“`

ここで、「Password expires」がパスワードの有効期限です。’never’ の場合は、パスワードの有効期限が設定されていないことを意味します。

応用例

応用例1: すべてのユーザーのパスワード期限を一覧表示

getent passwd | cut -d: -f1 | xargs -I {} sudo chage -l {}  # すべてのユーザーのパスワード期限を表示

応用例2: パスワードが期限切れのユーザーだけをリストアップ

getent passwd | cut -d: -f1 | xargs -I {} bash -c 'sudo chage -l {} | grep -q "Password expires.*: never" || echo {}'  # パスワードが期限切れのユーザーを表示

応用例3: 期限が1週間以内のユーザーを警告

この応用例では、シェルスクリプトを用います。

# 1週間以内に期限が切れるユーザーを警告するスクリプト

応用例4: パスワード期限をメールで通知

この例では、`mail`コマンドを使用して、期限が近いユーザーにメールで通知します。

# パスワード期限が近いユーザーにメールで通知するスクリプト

まとめ

Linuxでユーザーのパスワード期限を確認・管理する方法には、基本的に`chage`コマンドが使用されます。このコマンドを使って、セキュリティ維持のために定期的な確認を行いましょう。応用例を参考に、より高度な管理が可能です。

created by Rinker
オライリージャパン
¥3,080 (2025/01/19 00:35:17時点 Amazon調べ-詳細)

コメント

コメントする

目次