linux远程到其他机器执行循环脚本

在实际工作中可能会遇到远程登录到一台机器执行操作命令的情况。这个时候就可以使用ssh然后再执行命令,在使用for循环的时候需要使用阻塞,来等待循环命令执行完毕再继续执行其他命令,这个时候可以使用wait,否则会出现命令执行不完的情况。

#!/bin/sh
#外部参数
biaolist=$1
comidlist=$2
for biao in `cat ${biaolist}`;
do
{
  for comid in `cat ${comidlist}`;
  do
  {
  ssh 192.168.1.1 <<!
  mkdir -p /data/${comid}/${biao}
  rm /data/${comid}/${biao}/*.json
  hadoop fs -get /tmp/${biao}_json/${comid}  /data/${comid}/${biao}/${comid}.json
!
  echo "${comid}_${biao}完毕"
  }&
  done;
  #等待循环程序全部执行完毕再继续往下执行
  wait
  echo "${biao}完毕"
}&
done;
wait
echo "执行完毕"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值