Linux shell脚本使用while循环执行ssh的注意事项
浏览:7902次 出处信息
如果要使用ssh批量登录到其它系统上操作时,我们会采用循环的方式去处理,那么这里存在一个巨大坑,你必须要小心了。
一、场景还原:
我现在是想用一个脚本获取一定列表服务器的运行时间,首先我建立一个名字为ip.txt的IP列表(一个IP一行),再建好密钥实现不用密码直接登录。然后写脚本如下:
#!/bin/bash
while read ips;
do
echo $ips;
done < ip.txt脚本实现了逐行读取列表中的IP,但是:
#!/bin/bash
while read ips;
do
echo $ips;
upt=`ssh root@$ips "uptime"`;
echo $upt;
done < ip.txt脚本只对第一个IP做了检测,就直接跳出来了。
二、问题分析:
while使用重定向机制,ip.txt文件中的信息都已经读入并重定向给了整个while语句,所以当我们在while循环中再一次调用read语句,就会读取到下一条记录。问题就出在这里,ssh语句正好回读取输入中的所有东西。为了禁止ssh读所有东西增加一个< /dev/null,将ssh 的输入重定向输入。
三、解决策略:
1、使用for循环代表while,因为for没有一次把文件内容缓存获取过来,代码段修改如下:
for ips in `cat ip.txt`; do
echo ${ips};
upt=`ssh root@${ips} uptime`;
echo $upt;
done2、若坚持使用while循环,那么需要对ssh增加-n参数,为什么增加了-n参数也可以解决问题呢?通过man ssh查看-n参数的说明:
Redirects stdin from /dev/null (actually, prevents reading from stdin)
这就和
修改后的代码如下:
#!/bin/bash
while read ips;
do
echo $ips;
upt=`ssh -n root@$ips "uptime"`;
echo $upt;
done < ip.txt
建议继续学习:
- 在ssh服务里使用chroot (阅读:5722)
- 为什么要用公钥/私钥而不是密码去做SSH身份验证 (阅读:5607)
- 如何让ssh登录更加安全 (阅读:5467)
- ssh连接超时解决办法 (阅读:5381)
- 懒人连ssh不输密码若干大法 (阅读:5361)
- SSH无密码登录 (阅读:5350)
- ssh命令 (阅读:5099)
- 共享会话的ssh连接配置 (阅读:4558)
- SSH下连接Oracle的方法 (阅读:4406)
- SSH日常用法小例 (阅读:4014)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
文章信息
- 作者:吞拿鱼手卷 来源: 运维派
- 标签: ssh
- 发布时间:2015-04-08 00:01:25
建议继续学习
近3天十大热文
-
[782] WordPress插件开发 -- 在插件使用 -
[61] cookie窃取和session劫持 -
[61] Java将Object对象转换为String -
[58] 学习:一个并发的Cache -
[56] 你必须了解的Session的本质 -
[51] 最萌域名.cat背后的故事:加泰与西班牙政府 -
[51] Linux如何统计进程的CPU利用率 -
[50] 解读iPhone平台的一些优秀设计思路 -
[50] 再谈“我是怎么招聘程序员的” -
[48] 我对技术方向的一些反思
