问题背景
今天写了两个shell脚本都报错:syntax error near unexpected token `(’
回去看了代码又没有错误,搜索排查了一下原来是比较细节的语法原因
脚本代码
在/home/hadoop/bin这个目录下存放的脚本,hadoop用户可以在系统任何地方直接执行。
#!/bin/bash
#1 获取输入参数个数,如果没有参数,直接退出
pcount=$#
if ((pcount==0)); then
echo no args;
exit;
fi
#2 获取文件名称
p1=$1
fname=`basename $p1`
echo $fname
#3 获取上级目录到绝对路径
pdir=`cd -P $(dirname $p1); pwd`
echo $pdir
#4 获取当前用户名称
user=`whoami`
#5 循环
for((host=1; host<4; host++)); do
echo ------------------- node0$host --------------
rsync -av $pdir/$fname $user@node0$host:$pdir
done
为了便于一键启动hadoop集群,我们可以编写shell脚本
#!/bin/bash
case $1 in
"start" ){
source /etc/profile;
/kkb/install/hadoop-3.1.4/sbin/start-dfs.sh
/kkb/install/hadoop-3.1.4/sbin/start-yarn.sh
/kkb/install/hadoop-3.1.4/sbin/mr-jobhistory-daemon.sh start historyserver
};;
"stop"){
/kkb/install/hadoop-3.1.4/sbin/stop-dfs.sh
/kkb/install/hadoop-3.1.4/sbin/stop-yarn.sh
/kkb/install/hadoop-3.1.4/sbin/mr-jobhistory-daemon.sh stop historyserver
};;
esac
解决方法
有两种解决方法:
第一种:
可以将
for ( ( i=1; i<=$nu; i=i+1 ) ) 改成for (( i=1; i<=$nu; i=i+1 ))
s=$ ( ($s+$i ) ) 改成 s=$[$s+$i]
第二种 删除括号之间的空格
for ( ( i=1; i<=$nu; i=i+1 ) ) 改成for (( i=1; i<=$nu; i=i+1 ))
s=$ ( ($s+$i ) ) 改成 s=$(($s+$i))
另外也还可能是执行方式的原因