jpsall脚本

当一个集群的节点数量增多时,使用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
相关推荐
林农1 小时前
C05S14-MySQL高级语句
linux·mysql·云计算
Wanliang Li2 小时前
Linux电源管理——CPU Hotplug 流程
linux·嵌入式硬件·嵌入式·armv8·电源管理·cpuhotplug
fnd_LN2 小时前
Linux文件目录 --- mkdir命令,创建目录,多级目录,设置目录权限
linux·运维·服务器
达帮主2 小时前
7.C语言 宏(Macro) 宏定义,宏函数
linux·c语言·算法
行思理2 小时前
Linux 下SVN新手操作手册
linux·运维·svn
初学者丶一起加油3 小时前
C语言基础:指针(数组指针与指针数组)
linux·c语言·开发语言·数据结构·c++·算法·visual studio
一只搬砖的猹3 小时前
cJson系列——常用cJson库函数
linux·前端·javascript·python·物联网·mysql·json
莫固执,朋友4 小时前
Linux下编译 libwebsockets简介和使用示例
linux·websocket·音视频
DCTANT4 小时前
【合作原创】使用Termux搭建可以使用的生产力环境(八)
linux·debian·idea·termux·vnc·xfce4·termux-x11
开疆智能4 小时前
ModbusTCP转Profinet:工业通信的利器
linux·服务器·网络