通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加 – 21运维
通知: .-...

通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加

shell 21运维 3905浏览 0评论

21运维原创,转载请注明出处。
有一个朋友问我如何批量创建用户和设置密码 ,我就简单给他写了两个脚本,让他自己参考下并自己根据实际情况进行修改,毕竟他需要的用户名和密码都是实际生产环境的。

这里分两种情况,一种是测试for循环批量添加用户,一个是根据实际生产环境进行批量添加。分别写一下案例如下:
1,for添加指定类型用户以及设置随机密码。
脚本作用:批量添加user1-10用户并设置随机8位数随机密码

#!/bin/bash
#test add user and set passwd
for n in `seq 10`
do
useradd  user$n;
echo user$n |passwd  `echo user$n |md5sum |cut -c1-8`
done

2,实际生产环境批量添加用户和设置对应密码
脚本作用:在生产环境中批量添加指定用户、设置对应密码,并禁止sudo -s、sudo -i切换到root。
思路:将所有要添加的用户名和密码放到一个数组中,设置一个函数进行截取用户名和密码并进行添加用户、设置密码。最后用一个循环调用这个函数即可添加。

#!/bin/bash
#adduser and set passwd

userlist=(
 user21:123456
 user22:456789
 user23:876543
)
function adduser_setpasswd_sudo(){
user=`echo $1 |awk -F: '{print $1}'`
passwd=`echo $1 |awk -F: '{print $2}'`
useradd -m -s /bin/bash $user
echo "$user:$passwd"|chpasswd
sed -i "/${user}/d"  /etc/sudoers
echo "${user} ALL=NOPASSWD:ALL,!/usr/bin/passwd,/usr/bin/passwd  [a-zA-Z]*,!/usr/bin/passwd root,!/bin/bash" >> /etc/sudoers
}

for n in ${userlist[@]}
do
adduser_setpasswd_sudo  $n
done

3,删除要取消的账户以及取消sudo权限

#!/bin/bash

cat < <EOF
##############################################################
  delete  username  and  cancle  sudo privileges.
##############################################################
EOF
read -p  "Please  input username  which you want to del:" username
userdel  -r $username
sed  -i "/${username}/d" /etc/sudoers

echo "Delete $username finished."

转载请注明:21运维 » 通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加

发表我的评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

网友最新评论 (5)

  1. echo "${user} ALL=NOPASSWD:ALL,!/usr/bin/passwd,/usr/bin/passwd[a-zA-Z]*,!/usr/bin/passwd root,!/bin/su" >> /etc/sudoers 提示“;&"语法错误
    zhangsan2017-09-15 17:50 回复
    • 抱歉,编辑器原因导致的,>> 应该是两个>符号,已经修正。
      21运维2017-09-18 10:39 回复
  2. 说明: 1,注意编辑器的原因< < 带有空格,要执行的时候需要注意下。这里只是抛砖引玉,可以自己进行后续优化调整。 2,>是一个标准输出符号>,编辑器无法直接识别,需自行修改。 3,这里权限控制不严格,以sudo为例,安全起见可以根据自己实际需要具体细化设置,比如禁止useradd userdel以及chattr 等,细化权限管理安全。
    21运维2017-05-26 11:48 回复
  3. 建议将动态生成的密码记录到文本 脚本二可以将用户名和密码放到一个指定的文本文件里,通过脚本批量增加用户设置密码 from 运维社区
    loner2016-12-09 14:48 回复
    • 也可以,这样不用每次都修改脚本了。我搞的这个包括还没有写进来的修改密码函数,每次需要编辑脚本才行。
      21运维2016-12-09 17:58 回复