ps命令用于显示当前进程 (process) 的状态。
jps用于显示当前java进程的状态。
如果输入jps没有反应,但是实际上Java进程正常运行
java程序启动后,默认(请注意是默认)会在/tmp/hsperfdata_userName目录下以该进程的id为文件名新建文件,并在该文件中存储jvm运行的相关信息,其中的userName为当前的用户名,
/tmp/hsperfdata_userName目录会存放该用户所有已经启动的java进程信息。
对于windows机器/tmp用Windows存放临时文件目录代替。
而jps、jconsole、jvisualvm等工具的数据来源就是这个文件(/tmp/hsperfdata_userName/pid)。
所以当该文件不存在或是无法读取时就会出现jps无法查看该进程号,jconsole无法监控等问题
或者hsperfdata_hdfs目录文件权限是777,修改为755,重新启动Java程序即可
或者文件所有者和文件所属用户组与启动进程的用户不一致的话,在进程启动之后,就没有权限写/tmp/hsperfdata_username,所以/tmp/hsperfdata_username是一个空文件,理所当然jps也就没有任何显示