hadoop自制快速查看命令jpsall遇到的问题(bash: jpsall: 未找到命令...,bash识别shell文件错误)

 

目录

问题1:

 问题二:

 jpsall:

myhadoop.sh:

xsync:


为了解决这个问题我查了很多资料都没有找到具体的解决办法,我去网上专门学了bash到底是干嘛的才发现错哪了.......

首先看问题1:

 我是在/home/myroot/bin目录下弄了三个快速访问的命令,以便我们后面学习hadoop集群使用,分别是jps集群检查(jpsall),xsync群体分发,myhadoop.sh集群打开不用我们一个一个的start和stop了,我后面把源码粘贴给大家。

 然后刚开始我在这个bin目录下发现jpsall命令有问题,什么问题呢?

[root@hadoop102 bin]# . jpsall
: 未找到命令...
-bash: jpsall:行4: 未预期的符号 `$'do\r'' 附近有语法错误
'bash: jpsall:行4: `do

 至于为什么我在jpsall前面加了一个.是因为不加这个点直接就会显示找不到命令无法运行,其实就是因为jpsall命令无法被找到,加.是让系统在当前文件夹检测和source命令是一样的,它显示的是语法有问题,但我们从外面copy进来的不可能有问题,我找了很多资料发现是格式的问题,shell命令在linux里面是可以找到的,因为window和linux格式是不一样的,所以我们复制之前必须改格式,这里推荐一种方法

1.用yum下载dos2unix实现liunx格式转换即可,然后将jpsall转换之后就ok了语法没错了

[root@hadoop102 bin]# yum install -y dos2unix
[root@hadoop102 bin]# dos2unix jpsall 
dos2unix: converting file jpsall to Unix format ...

 问题二:

[root@hadoop102 bin]# jpsall
bash: jpsall: 未找到命令...

 发现找不到命令,我们用echo $PATH查看我们的系统配置里面有没有/home/myroot/bin的执行命令发现果然没有,这时候我们需要去我们PATH的文件里面加一条配置,vim /etc/profile,注意这里面的bin目录改成自己的目录即可

export PATH=$PATH:/home/myroot/bin

然后用source /etc/profile命令让其生效即可

然后看结果 ,发现已经成功访问了,结束

 jpsall:

#!/bin/bash

for host in hadoop102 hadoop103 hadoop104
do
        echo =============== $host ===============
        ssh $host jps 
done

myhadoop.sh:

#!/bin/bash
if [ $# -lt 1 ]
then
    echo "No Args Input..."
    exit ;
fi
case $1 in
"start")
        echo " =================== 启动 hadoop集群 ==================="

        echo " --------------- 启动 hdfs ---------------"
        ssh hadoop102 "/opt/module/hadoop-3.1.3/sbin/start-dfs.sh"
        echo " --------------- 启动 yarn ---------------"
        ssh hadoop103 "/opt/module/hadoop-3.1.3/sbin/start-yarn.sh"
        echo " --------------- 启动 historyserver ---------------"
        ssh hadoop102 "/opt/module/hadoop-3.1.3/bin/mapred --daemon start historyserver"
;;
"stop")
        echo " =================== 关闭 hadoop集群 ==================="

        echo " --------------- 关闭 historyserver ---------------"
        ssh hadoop102 "/opt/module/hadoop-3.1.3/bin/mapred --daemon stop historyserver"
        echo " --------------- 关闭 yarn ---------------"
        ssh hadoop103 "/opt/module/hadoop-3.1.3/sbin/stop-yarn.sh"
        echo " --------------- 关闭 hdfs ---------------"
        ssh hadoop102 "/opt/module/hadoop-3.1.3/sbin/stop-dfs.sh"
;;
*)
    echo "Input Args Error..."
;;
esac

xsync:

#!/bin/bash
#1 获取输入参数个数,如果没有参数,直接退出
pcount=$#
if((pcount==0)); then
echo no args;
exit;
fi
 
 
#2 获取文件名称
p1=$1
fname=`basename $p1`
echo fname=$fname
 
 
#3 获取上级目录到绝对路径
pdir=`cd -P $(dirname $p1); pwd`
echo pdir=$pdir
 
 
#4 获取当前用户名称
user=`whoami`
 
 
#5 循环
for((host=128;host<131;host++)); do
        echo ------------------- hadoop$host --------------
        rsync -rvl $pdir/$fname $user@hadoop$host:$pdir
done

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

新城已无旧少年_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值