写一个bash脚本时,我一直在努力解决这个问题.
基本上,我想测量远程服务器上程序的时间,所以我使用命令:
/usr/bin/time -f%e sh -c“my command> / dev / null 2>& 1”来执行程序.
但是,似乎我根本无法捕获到我的命令(SSH)的输出到一个变量.实际上,结果(时间)不断被打印到标准输出.
基本上,我想测量远程服务器上程序的时间,所以我使用命令:
/usr/bin/time -f%e sh -c“my command> / dev / null 2>& 1”来执行程序.
但是,似乎我根本无法捕获到我的命令(SSH)的输出到一个变量.实际上,结果(时间)不断被打印到标准输出.
完整的代码是:
respond=$(ssh ${fromNode} /usr/bin/time "-f" "%e" "'sh' '-c' 'virsh migrate --live ${VM} qemu+ssh://${toNode}/system --verbose > /dev/null 2>&1'")
响应的值只是空,尽管时间被打印到标准输出.
“time”命令将结果打印到stderr,而不是stdout.因此,它不被插入到您的变量中.
您应该将stderr重新路由到stdout以实现您想要的:
result=$(ssh host time "command" 2>&1)
而你的完整代码可以看起来像这样:
respond=$(ssh ${fromNode} /usr/bin/time "-f" "%e" "'sh' '-c' 'virsh migrate --live ${VM} qemu+ssh://${toNode}/system > /dev/null 2>&1'" 2>&1)