运维 Linux中密码策略
需求
- 密码必须符合复杂度要求,字母、数字、特殊字符组成。长度大于8位。
- 密码定期更改,最长不超过90天。
- 用户不能重复使用5次内已使用的口令。
- 尝试登陆失败错误次数,必须设置不能超过5次,超过5次后,暂时锁定20分钟或以上。
实现
安装 PAM 的 cracklib 模块,cracklib 能提供额外的密码检查能力
密码必须符合复杂度要求,字母、数字、特殊字符组成。长度大于8位。
修改文件:/ect/pam.d/system-auth,找到同时有 “password” 和 “pam_cracklib.so” 字段1password requisite pam_cracklib.so retry=3 difok=3 minlen=8 lcredit=-1 dcredit=-1 ocredit=-1密码定期更改,最长不超过90天
配置文件中 /etc/login.defs 修改配置文件
1234PASS_MAX_DAYS 90PASS_MIN_DAYS 0PASS_MIN_LEN 5PASS_WARN_AGE 7通过chage -l xxx(用户名) 查看定期修改的时间
用户不能重复使用5次内已使用的口令
修改文件:/ect/pam.d/system-auth,找到同时有 “password” 和 “pam_unix.so” 字段1password sufficient pam_unix.so sha512 shadow nullok try_first_pass use_authtok remember=5通过/etc/security/opasswd中查看禁止使用近期用过的5个密码
尝试登陆失败错误次数,必须设置不能超过5次,超过5次后,暂时锁定20分钟或以上
查看系统中是否含有pam_tally2.so模块,如果没有,则需要使用pam_tally.so模块
find /lib -iname “pam_tally2.so”
find /lib -iname “pam_tally.so”
在配置文件中/etc/pam.d/sshd中的第二行,如下添加内容1auth required pam_tally2.so deny=5 unlock_time=1200查看用户错误登陆次数:
pam_tally2 –user xxx (用户名)1234567891011pam_cracklib.so比较重要和难于理解的是它的一些参数和计数方法,其常用参数包括:debug:将调试信息写入日志;type=xxx:当添加/修改密码时,系统给出的缺省提示符是“New UNIX password:”以及“Retype UNIXpassword:”,而使用该参数可以自定义输入密码的提示符,比如指定type=your own word;retry=N:定义登录/修改密码失败时,可以重试的次数;Difok=N:定义新密码中必须有几个字符要与旧密码不同。但是如果新密码中有1/2以上的字符与旧密码不同时,该新密码将被接受;minlen=N:定义用户密码的最小长度;dcredit=N:定义用户密码中必须包含多少个数字;ucredit=N:定义用户密码中必须包含多少个大写字母;lcredit=N:定义用户密码中必须包含多少个小些字母;ocredit=N:定义用户密码中必须包含多少个特殊字符(除数字、字母之外);