在实际工作中可能会遇到远程登录到一台机器执行操作命令的情况。这个时候就可以使用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 "执行完毕"