[英]NodeJS child_process: run two process in parallel over ssh and stream outputs
首先,使用ssh2可以轻松完成此操作,但是由于它不支持证书身份验证 ,因此我无法使用它。
因此,眼下的问题是:
我正在使用child_process
运行ssh binary
并连接到远程服务器。 我可以运行命令并通过生成的进程的stdin
和stdout
获取它们的输出。 但是我有一个用例,其中我需要并行运行两个命令 。 一个是运行时间很长的命令,我需要逐行流式传输,另一个是轻量级命令,其输入取决于流式传输的行的内容。 是否可以在不产生两个 ssh
进程的情况下做到这一点?
也欢迎使用ssh2或类似方法来解决。
(编辑)添加一个描述性示例:
Process 1
运行很长时间,并且一直在向stdout / file写入行, Process 2
需要像在Process 1
产生一行时一样在每行上运行。 在每一点上,当某行的Process 2
完成时,我需要input line printed by Process 1
和the corresponding output of Process 2
有一个非常简单的方法:使用gnu并行。 https://www.gnu.org/software/parallel/使用sudo apt -y install parallel
安装在Ubuntu fe上
ssh host \
'echo -e "date > 1.out && sleep 5\n date > 2.out && sleep 5" | parallel -j0'
ssh host cat 1.out
> Th 14. Jun 10:54:15 CEST 2018
ssh host cat 2.out
> Th 14. Jun 10:54:15 CEST 2018
现在,您可以使用ssh命令访问1.out和2.out。
但是,让我们考虑一下您以后的编辑:
prog1.sh:
for i in {1..5}; do
echo $i >> 1.out
sleep 1;
done
echo "done" >> 1.out
sleep 1
echo -e "\n" >> 1.out
prog2.sh(监视1.out并执行一些命令,此处为尾部):
inotifywait -e close_write,moved_to,create -m . |
while read -r directory events filename; do
if [ "$filename" = "1.out" ]; then
# 1.out changed we need to do something
res=$(tail -1 1.out)
if [ $res = "done" ]; then
break;
fi
fi
done
ssh host 'echo -e "./prog2.sh \n ./prog1.sh" | parallel -j 2'
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.