|
脚本目的:批量修改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 n8wX3mU% 22
192.168.18.218 root c87;ZnnL 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
|
|
|