脚本目的:批量修改linux系统用户密码
条件:必须是修改的用户是root,因为只有root才有权限使用passwd命令
说明:先把IP、用户、密码、端口信息写到old_info文件中,脚本从这个文件读取对应的信息,利用expect免交互登陆系统。将随机生成的8位密码修改为root用户新密码。然后将新密码保存到net_info文件中。
1
2
3
4
5
|
# cat old_info
# ip user passwd port
#------------------------------------------------
192.168.18.217 root 123456 22
192.168.18.218 root 123456 22
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
# cat change_pass.sh
#!/bin/bash
OLD_INFO=~
/old_info
NEW_INFO=~
/new_info
for
IP
in
`
awk
'/^[^#]/{print $1}'
$OLD_INFO`;
do
USER=`
awk
-
v
I=$IP
'{if(I==$1)print $2}'
$OLD_INFO`
PASS=`
awk
-
v
I=$IP
'{if(I==$1)print $3}'
$OLD_INFO`
PORT=`
awk
-
v
I=$IP
'{if(I==$1)print $4}'
$OLD_INFO`
NEW_PASS=`mkpasswd -l 8`
echo
"$IP $USER $NEW_PASS $PORT"
>> $NEW_INFO
expect -c "
spawn
ssh
-p$PORT $USER@$IP
set
timeout 2
expect {
\"(
yes
/no
)\" {send \"
yes
\r\";exp_continue}
\"password:\" {send \"$PASS\r\";exp_continue}
\"$USER@*\" {send \"
echo
\'$NEW_PASS\' |
passwd
--stdin $USER\r
exit
\r\";exp_continue}
#\"$USER@*\" {send \"df -h\r exit\r\";exp_continue}
}"
done
|
1
2
3
|
# cat new_info
192.168.18.217 root n8wX3mU% 22
192.168.18.218 root c87;ZnnL 22
|
本文转自 李振良OK 51CTO博客,原文链接:http://blog.51cto.com/lizhenliang/1674791,如需转载请自行联系原作者