jps类似linux的ps命令,不同的是ps是用来显示进程,而jps只显示java进程,准确的说是当前用户已启动的部分java进程信息,信息包括进程号和简短的进程command。
用ps -ef|grep java能看到启动的java进程,但是用jps查看却不存在该进程的id。
而jps、jconsole、jvisualvm等工具的数据来源就是这个文件(/tmp/hsperfdata_userName/pid)。所以当该文件不存在或是无法读取时就会出现jps无法查看该进程号,jconsole无法监控等问题。
原因:
2)、临时文件丢失,被删除或是定期清理
这个导致的现象可能会是这样,用jconsole监控进程,发现在某一时段后进程仍然存在,但是却没有监控信息了。
关于设置该文件位置的参数为-Djava.io.tmpdir
其他:
/tmp/hsperfdata_userName/pid文件会在对应java进程退出后被清除。如果java进程非正常退出(如kill -9),那么pid文件会被保留,直到执行一次java命令或是加载了jvm程序的命令(如jps、javac、jstat),会将所有无用的pid文件都清除掉
centos7 写了 java程序的启动脚本,脚本从网上 copy 的。
[Unit]
Description=tomcat-1
After=syslog.target network.target remote-fs.target nss-lookup.target
[Service]
Type=forking
Environment='JAVA_HOME=/usr/local/java/jdk1.8.0_151/'
WorkingDirectory=/usr/local/tomcat-1/webapps
ExecStart=/usr/local/tomcat-1/bin/startup.sh
ExecStop=/usr/local/tomcat-1/bin/shutdown.sh
ExecReload=/bin/kill -s HUP $MAINPID
PrivateTmp=True
User=dev
Group=dev
[Install]
WantedBy=multi-user.target
虽然可以正常启动关停 tomcat,但用 jps 命令根本看不到这个 tomcat 进程。
最终一番排查发现网上 copy 的脚本里有如下这一句,去掉再重启,jps 就可以看到 tomcat 进程了。
PrivateTmp=true
这是因为tomcat启动后会把启动后jdk相关信息写在/tmp/hsperfdata_root目录下,jps就去/tmp目录下打开这个文件,并把信息展现给用户,但/tmp这个目录权限是777,任何人都可以查看,centos7认为这样不安全,容易泄露信息,于是官方启动脚本里就有
PrivateTmp=true这么一句,这样一来tomcat启动后,就不会把相关信息写入/tmp目录里,也就造成jps无法看到tomcat进程了。
我们将启动脚本的PrivateTmp改为false,重启java程序。
jps能够看到该程序啦!