所以我有一个小脚本应该通过不同的服务器连接到1000个左右的帐户,如下所示。
for account in $(cat $SSH_LIST)
do echo -e "\n$account\n"
SERVER=$(echo $account | cut -d',' -f1 | awk '{print tolower($0)}') ; USER=$(echo $account | cut -d',' -f2) ; PASS=$(echo $account | cut -d',' -f3)
sshpass -p $PASS ssh -o StrictHostKeyChecking=no $USER@$SERVER "ls passwd.cdb && exit"
问题是,当ssh命中权限被拒绝时,脚本退出。可以理解的是,SSH Permission Denied就像退出代码一样,退出了脚本。我需要它来简单地记录被拒绝的权限并继续它的快乐方式SSH' ing。
有什么建议吗?
答案 0 :(得分:7)
通常情况下,bash不会在第一个错误时退出,除非在脚本中将$(document).ajaxSend(function () {
$.mobile.loading("show")
}).ajaxStop(function () {
$.mobile.loading("hide")
});
设置得更高。尝试在set -e
循环之前加上它。
for
P.S。您在循环结束时错过了set +e
。我认为这只是一个剪切和粘贴错误。
答案 1 :(得分:3)
尝试以下方法:
if ! sshpass -p $PASS ssh -o StrictHostKeyChecking=no $USER@$SERVER "ls passwd.cdb && exit"; then
echo >&2 "WARNING: access denied for $USER@$SERVER"
fi
您也可以使用逻辑运算符OR
:
sshpass -p $PASS ssh -o StrictHostKeyChecking=no $USER@$SERVER "ls passwd.cdb && exit" ||
echo >&2 "WARNING: access denied for $USER@$SERVER"
答案 2 :(得分:1)
刚刚在这里更新,我知道已经有一段时间了,一直很忙:)。事实证明-e是在脚本顶部的一些混淆代码中设置的。让混淆代码的人删除它。还要感谢slava semushin记录拒绝访问消息的好主意。