批量创建用户并设置初始密码
目录:
1.脚本功能介绍
2.脚本制作技术需求
2.1 useradd命令
2.2 id命令
2.3 passwd命令
2.4 随机密码
2.5 while循环+case+select
3.脚本编写案例
一、脚本功能介绍
在企业中生产或运维中,经常会遇到VPN服务器、企业网盘、企业邮箱、云桌面私有账号等等一系列的服务器。当批量新员工入职时,经常需要批量账号分配给新员工,若此类账号存储在数据库时,管理员可根据公司账号命名规范通过专有图形化系统进行录入账号,若账号存储在系统本地,此时通过脚本实现更为方便。
如企业账号规范:用户名规范为取员工名字中姓的全拼且首字母大写,名字的首字母,如有重复自动加重复用户名次数+1。密码规范为取字母数字中8位长度的任意字符。
二、脚本制作技术需求
2.1 useradd命令
useradd命令的功能作用就是修改/etc/passwd文件中预定义的7个字段的内容,语法结构:useradd [option] login,常用用法如下:
useradd user1 #添加用户user1 useradd -u 120 user1 #修改用户user1的UID为120 useradd -g grouptest user1 #修改用户的默认组为grouptest useradd -d /app/home/user1 user1 #修改指定user1的家目录为/app/home/user1 useradd -s /sbin/nologin user1 #修改用户的shell |
2.2 id命令
id命令的功能作用就是查看当前用户的id信息,包括UID、GID和默认组,如果不存在账户时,则提示不存在,$?返回值大于0
[[email protected] ~]#id root &>/dev/null #判断用户root是否存储 [[email protected] ~]#echo $? 0 #返回值为0,用户存在 [[email protected] ~]#id rootbad &>/dev/null [[email protected] ~]#echo $? 1 #返回值大于0,用户不存在 |
2.3 passwd命令
passwd命令的功能作为就是修改/etc/shadow文件中预定义的9个字段的内容,其中/etc/shadow的语义格式为:
bin : * : 16659 : 0 : 99999 : 7 : : : 字段1 字段2 字段3 字段4 字段5 字段6 字段7 字段8 字段9 字段1:表示用户名,与/etc/passwd中的账号相匹配 字段2:默认是加密后的字符,如果为*或!!表示没有秘密,如果为!!(加密字符)表示此账号加锁 字段3:表示上一次修改密码的时间 字段4:表示密码最短存活时间,其含义就是多久内不能修改密码 字段5:表示密码最长存活时间,其含义就是密码最长有效期 字段6:表示密码提前多少天开始提醒用户账号快到期 字段7:表示密码到期后多少天宽限期,哲学含义就是容忍度是有限的,不要碰触底线 字段8:表示密码彻底失效,哲学含义就是已经触犯底线,将密码禁止 字段9:表示保留字段,目前尚未使用 |
最长用的就是修改锁定密码和修改账号,具体用法如下:
passwd -l user1 #锁定某个账号,将shadow文件中第二个字段!!(加密字符)字样; passwd -u user1 #解锁某个账号,将shadow文件中第二个字段中的!!去掉 passwd --stdin user1 #设置密码通过标准输入进行设置 [[email protected] ~]#echo "centos123"|passwd --stdin xiaoxue [[email protected] ~]#echo "centos123"|passwd --stdin xiaowang &>/dev/nul |
2.4 随机密码
在系统中随机密码有多种方式,其中优先使用专有的密码生成工具mkpasswd,mkpasswd工具来自expect的rpm包,因此使用mkpasswd时,必须先安装expect包,具体使用如下:
mkpasswd [option] -l 指定密码生成的长度,默认是9 -d 指定密码生成时至少包含几个数字,默认是3个 -c 指定密码生成时至少包含几个小写字母,默认为2个 -C 指定密码生成时至少包含几个大写字母,默认2个 -s 指定密码生成时至少包含几个字符,默认1个 [[email protected] ~]#mkpasswd -l 10 |
其次当系统中不方便安装mkpasswd工具时,使用系统随机字母字符生成器设备/dev/urandom,利用他生成随机数后进行过滤字母、数字,注意特殊字符过多,不一定连续,因此使用/dev/urandom时取特殊字符不好控制,建议使用mkpasswd,urandom具体使用如下:
[[email protected] ~]#a=`cat /dev/urandom |tr -dc "a-zA-Z0-9"|head -c8` [[email protected] ~]#echo $a mFPAW5Tn [[email protected] ~]#a=`cat /dev/urandom |tr -dc "a-zA-Z0-9"|head -c8` |
2.5 while+case+break+select
while循环执行某些指令动作,case实现选择性执行某些指令,break实现遇到某些指令后执行跳出循环,seletc是自动生成菜单,因此在脚本的结构中while+case+break+select实现
三、脚本案例
脚本实现两种方式安装,菜单中选择1表示手工安装,手工安装适合批量较少时,无需自动化安装,菜单中选择2时表示自动化安装,适合批量增加用户,如新进大批员工,从人力资源获取相关信息后,根据人力资源提供的姓名创建大批用户,具体脚本如下:
#!/bin/bash addlog=/var/log/useradd.log execlog=/var/log/userexec.log setpasswd=`mkpasswd -l 10` #判断开头是否包含变量name所含的字段,从而判断是否有名字缩写的重复 let num=`awk -F: "/^"$name"[0-9]?+/{i++}END{print i}" /etc/passwd`+1 ######################Define main function |