Linux shell脚本使用while循环执行ssh的注意事项
浏览:7760次 出处信息
如果要使用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 (阅读:5626)
- 为什么要用公钥/私钥而不是密码去做SSH身份验证 (阅读:5494)
- 如何让ssh登录更加安全 (阅读:5349)
- ssh连接超时解决办法 (阅读:5270)
- 懒人连ssh不输密码若干大法 (阅读:5253)
- SSH无密码登录 (阅读:5235)
- ssh命令 (阅读:4991)
- 共享会话的ssh连接配置 (阅读:4436)
- SSH下连接Oracle的方法 (阅读:4305)
- SSH日常用法小例 (阅读:3940)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
文章信息
- 作者:吞拿鱼手卷 来源: 运维派
- 标签: ssh
- 发布时间:2015-04-08 00:01:25
建议继续学习
近3天十大热文
-
[335] WordPress插件开发 -- 在插件使用 -
[150] 解决 nginx 反向代理网页首尾出现神秘字 -
[90] IOS安全–浅谈关于IOS加固的几种方法 -
[55] 二维码的生成细节和原理 -
[49] 到底什么是MVC? -
[48] Shell的那些事儿 -
[48] Linux Used内存到底哪里去了? -
[47] 中间件和稳定性平台 -
[47] Hacker News 排名算法工作原理 -
[44] 浅谈MySQL索引背后的数据结构及算法
