执行命令
/usr/local/jdk1.8.0_121/bin/jstat -gc 52684 250 20
报错
52684 not found
但ps -ef | grep java是可以看到进程的
原因:java进程默认把jvm perfdata写入/tmp/hsperfdata_{user}/{pid}中,但我的程序是自启动的,即通过systemctl start {service-name}来启动的,在/tmp/hsperfdata_{user}/下没有找到52684这个文件
解决:
// 找到pid文件位置
find / -name 52684
// 移到/tmp/hsperfdata_{user}/
cp /tmp/systemd-private-......service/tmp/hsperfdata_{user}/52684 /tmp/hsperfdata_{user}/
再执行/usr/local/jdk1.8.0_121/bin/jstat -gc 52684 250 20,就成功了
注意
hsperfdata_{user}的权限需要是755。777的时候还是会报错