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