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

14 篇文章 1 订阅

这里分两种情况,一种是测试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权限

1.手动输入某一个的用户

#!/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."

2.利用以上函数写一个批量删除的脚本

#!/bin/bash

[ `id -u` -ne 0 ] && echo "Please change to root user ..." && exit 10

#用户名数组
userlist=(
zhangdan
lisi
xiaohong
xiaoming
    
)
#增添用户设置密码函数
function delete_user(){
user=`echo $1 |awk -F: '{print $1}'`
userdel  -r $user &> /dev/null
u= "$?"
sed  -i "/${user}/d" /etc/sudoers

}
#循环调用函数,增加用户
for n in ${userlist[@]}
do
delete_user $n
 if [ "$u" == 0 ]; then
  echo "user $n hasbeen delete successfully !"
else
  
    echo "user $n  failed delete or not exit"
fi

done

 4.写一个增加用户的脚本

#!/bin/bash
userlistyw=(
zhangsan:12345678
)
#用户名数组
userlistyf=(
lisi:12345678
)
function adduser_setpasswdyw(){
#循环取得数组里的用户名密码
user=`echo $1 |awk -F: '{print $1}'`
passwd=`echo $1 |awk -F: '{print $2}'`
#增加用户
useradd -m -s /bin/bash $user
#设置密码
echo "$user:$passwd"| sudo chpasswd
#增加sudo权限
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/su" >> /etc/sudoers
}

function adduser_setpasswdyf(){
user=`echo $1 |awk -F: '{print $1}'`
passwd=`echo $1 |awk -F: '{print $2}'`
useradd -m -s /bin/bash $user
echo "$user:$passwd"| sudo chpasswd
}
#循环调用函数,增加运维用户
for n in ${userlistyw[@]}
do
adduser_setpasswdyw $n
echo "user $n hasbeen set successfully !"
done
#循环调用函数,增加研发用户
for n in ${userlistyf[@]}
do
adduser_setpasswdyf $n
echo "user $n hasbeen set successfully !"
done

 

#!/bin/bash
#adduser and set passwd
#用户名数组
userlist=(
zhangsan:12345678
lisi12345678
)
#增添用户设置密码函数
function adduser_setpasswd(){
#循环取得数组里的用户名密码
user=`echo $1 |awk -F: '{print $1}'`
passwd=`echo $1 |awk -F: '{print $2}'`
#增加用户
useradd -m -s /bin/bash $user
#设置密码
echo "$user:$passwd"| sudo chpasswd
#增加sudo权限
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/su" >> /etc/sudoers
}
#循环调用函数,增加用户
for n in ${userlist[@]}
do
adduser_setpasswd $n
echo "user $n hasbeen set successfully !"
done

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值