linux ps -ef 和jps,jps查看hadoop状态一定准确吗?NO,生产遇到深坑

jps是jdk提供的一个查看当前java进程的小工具, 可以看做是JavaVirtual Machine Process Status Tool的缩写。非常简单实用。

首先你要理解的是,这个jps命令可以用来查看hadoop进程,他就是相当于一个查询工具,它并不能代表这个真正是否是在运行,所以某些情况下他的查询结果并不一定准确,往下看就明白了

精品博客,尚齐原创.

1.jps位置

which jps--->他就在你的linux安装的Java目录下

e076d7fada45

which jps

2.jps靠什么读取出来进程

jps通过读取一个目录下对应的Java进程文件,显示出来对应的进程,路径默认是:

/tmp/hsperfdata_username,root用户就是hsperfdata_root,hdfs用户就是hsperfdata_hdfs

e076d7fada45

hsperfdata路径

3.不同用户之间可以看到对方的进程吗?

答案是不可以的,除非是root用户

比如hadoop用户启动了hadoop程序,他jps是可以查看到自己的hadoop程序的,

然后spark用户启动了自己的spark服务,他jps是可以查看到spark进程的,但是他jps是看不到hadoop进程的.

root用户就可以都能看到所有的进程,毕竟是超级管理员权限是最高的

这个之所以jps只有当前用户能看到

4.为什么不同用户之间不能够jps看到对方的进程

原因其实很简单,当前用户之所以能够通过jps看到自己的进程,其实是通过读取/tmp/hsperfdata_username路径下的里面的名字为进程pid的文件

下图为hadoopadmin用户只启动yarn,对应的jps结果和文件夹查看结果

e076d7fada45

image.png

然后别的用户对应的自己的hsperfdata_username都为空,因为他们没有启动相关Java进程,root的也是空的,但是他就是能够读取到进程,我猜root的jps读取的是/tmp/hsperfdata_☆这种方式读取的

5.使用ps-ef查看不分用户

上面讲了,使用jps查看是查看不到其他用户启动的程序的,最好使用ps -ef|grep 程序名来查看这个程序是否启动,因为这个不分用户

比如a用户启动的程序namenode,但是在b用户jps是看不到的,他可以直接ps-ef|grep namenode就能够查出来进程在运行.这样避免了又去启动一次,虽然再次启动会提示namenode正在运行,但是这样肯定不好对吧.

6./tmp/hsperfdata_username文件删除了对进程有影响吗

答案是没有任何影响,唯一的影响是jps看不到了,上面也讲了,这个jps只是帮着查看的,它并不能影响到这个程序是不是在执行,如果你直接kill -9 pid那肯定就影响了,ps -ef|grep pid/name 就查不到了

而且这个文件是在tmp目录下的,linux默认会一段时间将这个tmp目录清空,所以.....

7.b用户kill掉a用户的进程,a用户jps会发生什么

hadoopadmin启动了resourcemanager进程,jps可以查看到

e076d7fada45

image.png

spark用户通过ps -ef|grep resurcemanager找到pid,kill- 9 pid,a用户的jps自然也找不到了

8.b用户删除了a用户下面的hsperfdata_username文件,会发生什么

b用户把a用户这个hsperfdata_username下面文件都删除了,a用户启动而进程用jps就什么也看不到,但是ps-ef还是能够查到,因为这个jps并不能真正的删除进程,所以就容易给a用户造成一个假象,所以生产最好用ps-ef|grep查看任务,最准正确,jps查看任务容易被误导

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值