笔者最近在使用开源物联网框架thingsboard时,发现docker内部的java进程通过jps命令查不到,凡是通过jps能查到的java进程,以linux系统为例都会在/tmp/hsperfdata_当前用户/(如/tmp/hsperfdata_root/)目录下创建以java进程id命名的文件,最终排查是因为thingsboard启动时传入了-XX:+PerfDisableSharedMem这个jvm参数导致,jvm参数里面有以下参数控制着该文件
java -XX:+PrintFlagsFinal |grep Perf
bool PerfAllowAtExitRegistration = false {product}
bool PerfBypassFileSystemCheck = false {product}
intx PerfDataMemorySize = 32768 {product}
intx PerfDataSamplingInterval = 50 {product}
ccstr PerfDataSaveFile = {product}
bool PerfDataSaveToFile = false {product}
bool PerfDisableSharedMem = false {product}
intx PerfMaxStringConstLength = 1024 {product}
bool UsePerfData = true {product}
上面参数中尤其UsePerfData、PerfDisableSharedMem最重要,直接控制着是否产生该perf文件。
关于上面两个参数的详细说明,可以参考https://mp.weixin.qq.com/s/gCE9eXbtMuze3jhuRm1YXA
参考文章
1、https://mp.weixin.qq.com/s/gCE9eXbtMuze3jhuRm1YXA
PS:
其实通过jps查不到java进程的原因可能有很多,下面是一些情况:
1、(
Can't attach to the process
sun.jvm.hotspot.debugger.DebuggerException: sun.jvm.hotspot.debugger.DebuggerException: Can't attach to the process
)http://blog.sina.com.cn/s/blog_3fba24680102x6k1.html
2、磁盘读写、目录权限问题 (需要确认当前用户userName对路径/tmp/hsperfdata_userName/,及其下面的文件是否有读写权限,还应当却/tmp目录是否可写)
3、临时文件丢失,被删除或是定期清理(需确认/tmp/hsperfdata_userName/下的文件是否被定时清除了,最简单的办法就是重启该进程看看)
4、java进程信息文件存储地址被设置,不在/tmp目录下 (启动进程的时候可以通过-Djava.io.tmpdir参数来设置进程信息存储地址,jps、jconsole都只会从/tmp目录读取,因此需要确认是否被修改过)