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