当一个集群的节点数量增多时,使用jps查看每一个节点的进程这个过程非常繁琐,因此我们可以写一个jpsall脚本,使用循环迭代的方式,在多台远程主机上执行相同的命令,这样就可以节省在每台主机上手动执行命令的时间和精力。
并且如果集群规模扩大,需要监控更多的主机,只需在脚本中添加相应的主机名即可。
脚本实现:
1.进入/usr/bin目录,创建jpsall文件
2.打开jpsall文件,写入以下内容
#!/bin/bash
for host in hadoop01 hadoop02 hadoop03
do
echo =============== $host ===============
ssh $host jps
done
主机名根据自己的主机名进行更改。
3.更改jpsall文件权限
chmod 777 jpsall
之后即可运行jps命令,如图所示:
如果出现以下报错,提示未找到jps命令:
[root@Hadoop01 bin]# jpsall
=============== hadoop01 ===============
bash: jps: command not found
=============== hadoop02 ===============
bash: jps: command not found
=============== hadoop03 ===============
bash: jps: command not found
因为远程主机上的环境变量和路径配置可能与您本地主机不同,所以在
jpsall
脚本中,由于脚本中的命令是在远程主机上执行的,可能导致无法找到jps
命令。为了解决这个问题,您可以尝试在
jpsall
脚本中使用完整的jps
命令路径来执行。您可以使用which jps
命令来获取jps
命令的完整路径,然后将其替换为jpsall
脚本中相应的位置。
例如:
假设
jps
命令的完整路径为/usr/bin/jps
,您可以将jpsall
脚本中的jps
命令替换为/usr/bin/jps
。
修改后的 jpsall
脚本如下所示:
#!/bin/bash
for host in hadoop01 hadoop02 hadoop03
do
echo "=============== $host ==============="
ssh $host /usr/bin/jps
done