[背景]:确认Support服务的冗余关系,包括授权信息、线上的连接数以及配置文件中的最大连接,保证切换时机器环境一致性。对于主库、从库授权信息,我的做法是获取数据库上所有User和Host,然后将它们授权信息输出到文件中再diff这些文件,从而比较授权信息。
[问题所在]:脚本中需要在while循环中每次从文件中获取主机名和IP,然后ssh到该机器上执行show grants命令将授权信息定位到文件中。发现每次执行一行,然后循环就结束了而文件中远远不止一行。
脚本结构是:
while read line do echo $line ssh mysql@$host "xxxxxx" done<${host}.list
一开始以为文件换行不对,但是将ssh所在行注释掉,会输出每一行;加上ssh,只有echo第一行。
[原因所在以及解决方案]
ssh默认情况的情况下,会将从第二行开始之后的文件内容作为其命令的参数输入,将其“吃掉”,这是ssh所谓的贪婪模式决定。加上-f参数可以比较这一情况,-f将命令在后台执行,不会吃掉文件后面的内容,从而达到正确的结果。