-XX:+PerfDisableSharedMem导致jps查不到java进程问题

笔者最近在使用开源物联网框架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目录读取,因此需要确认是否被修改过)

 

你可能感兴趣的:(thingsboard,java)