最近遇到一个很奇怪的问题,产品的某个功能可以根据日志文件的异常纪录,去处理这些异常,不过在测试的时候发现每次都只能处理一条异常,然后整个循环就退出了。

开始以为是某个函数里面调用了exit命令,看了一整遍代码也没有发现使用exit的函数。最后只好在while循环里面一点一点的注释,然后观察运行结果。最后竟然定位到是在一个函数里面,调用了另外一个shell文件,而且这个shell文件里的某个函数只要一执行,就会导致循环退出,然后定位到是一条ssh命令导致的。

搞不通ssh命令为什么会导致shell退出,最后上网搜了一下才找到答案。

  1. ssh命令在每次执行时,会读取所有的标准输入中的内容。
  2. 对于while循环,当按照如下方式使用时:

    cat file | while read line

    这里使用重定向,将文件内容输入到while命令,while命令每次使用read从输入中读取一行数据。

问题就在这里,如果在while循环中调用了ssh命令,那么ssh就会把当前输入中所有的数据读走,也就是cat file重定向给while命令的数据,都被ssh命令读走了,以至于下次循环的时候,read读到的内容为空,导致循环提前结束。

解决这个问题两种方式

  1. ssh -n 使用-n参数
  2. ssh xxxx < /dev/null重定向shell命令的输入