JProfiler 能够为一个用户找到 JVM 进程,但可以为同一台机器上的另一个用户找到它

JProfiler is able to find JVM process for one user but can find it for another user on the same machine

我有一个 ec2-instance,它有两个不同的用户,ec2-user 和 other-user,我每个都有一些 jvm 进程 运行ning。我正在尝试通过 JProfiler 进行远程连接,但我似乎无法在 JProfiler(版本 12.0.3 Build 12084

中找到 JVM 进程

所以我开始深入研究盒子以检查发生了什么,这是我发现的

cd /tmp
pwd
drwxr-xr-x 2 other-user   users    4.0K Jul  7 23:35 hsperfdata_other-user
drwxr-xr-x 2 ec2-user   users    4.0K Jul  7 23:35 hsperfdata_ec2-user
ls /tmp/hsperfdata_ec2-user (Nothing)
ls /tmp/hsperfdata_other-user
9014

9014 这里是 java 进程的 pid,文件包含一些二进制数据。然而,还有另一个 java 进程 运行 作为 ec2-user,但它没有出现在 /tmp/hsperfdata_ec2-user.

这两个 JVM 仅在启动时使用的版本不同

用于 java 进程 运行 作为 ec2-user

openjdk version "11.0.11" 2021-04-20 LTS
OpenJDK Runtime Environment (build 11.0.11+9-LTS)
OpenJDK 64-Bit Server VM (build 11.0.11+9-LTS, mixed mode)

另一个给其他用户

openjdk version "1.8.0_282"
OpenJDK Runtime Environment (build 1.8.0_282-b08)
OpenJDK 64-Bit Server VM (build 25.282-b08, mixed mode)

I 运行 ps aux |grep java 发现两个 pids 都在运行。

我尝试删除该目录,重新启动 ec2-user 的 jvm 进程,然后再次尝试附加它,但没有成功。

我也尝试在 ec2-instance 上像这样在本地使用不同版本的 JProfiler

wget --no-check-certificate https://download-gcdn.ej-technologies.com/jprofiler/jprofiler_linux_11_0.tar.gz -P /tmp/;tar -zxvf /tmp/jprofiler_linux_11_0.tar.gz -C /tmp

sudo -u ec2-user /tmp/jprofiler11.0/bin/jpenable
No unprofiled JVMs found.

If the target JVM is running as a different user, restart as
    sudo -u [user] jpenable

我不知道如何进步。我四处寻找 JProfiler 远程代理的日志,但到目前为止还没有找到任何东西。我认为这是目录的权限问题,但它们似乎没问题。我正在检查发布日志,但没有发现任何问题。

有人可以帮我解决这个问题吗?

想通了。我在另一个进程中启用了这个 jvm arg

<jvmarg value="-XX:+PerfDisableSharedMem"/>

一旦我删除了这个标志,一切都很顺利。