
本文旨在解决使用 `jstack` 命令获取 java 进程线程转储时常见的权限问题。当 `jstack` 报告“well-known file is not secure”错误时,通常是由于执行命令的用户与目标 java 进程的实际所有者不匹配所致。教程将详细解释此错误的原因,并提供识别进程所有者、切换用户以及正确执行 `jstack` 命令的步骤,确保您能成功获取所需的诊断信息。
jstack 是 JDK 提供的一个强大工具,用于打印指定 Java 进程的所有 Java 线程的堆栈信息。这些信息对于诊断死锁、性能瓶颈或其他并发问题至关重要。然而,为了确保系统安全和进程隔离,jstack 在尝试访问另一个进程的内存空间时,会严格检查执行命令的用户权限。
当您遇到类似“well-known file /tmp/.java_pid23264 is not secure: file should be owned by the current user (which is 0) but is owned by 9001”的错误信息时,这表明:
即使尝试使用 -F 选项(强制模式)也可能无法解决此问题,因为它无法绕过底层的权限检查,通常会报告“Error attaching to core file: cannot open binary file”,这进一步证实了权限不足是根本原因。
解决此问题的核心原则是:执行 jstack 命令的用户必须与目标 Java 进程的所有者用户一致。
立即学习“Java免费学习笔记(深入)”;
以下是详细的解决步骤:
在尝试获取线程转储之前,首先需要确定目标 Java 进程是由哪个用户启动的。可以通过 ps 命令结合 grep 来查找:
ps -ef | grep <PID>
将 <PID> 替换为您的 Java 进程 ID。输出的第三列通常显示进程的所有者用户名。
示例: 假设您的 Java 进程 ID 是 23264。
ps -ef | grep 23264
输出可能类似这样:
appuser 23264 1 0 10:30 ? 00:01:23 /usr/lib/jvm/java-11-openjdk-amd64/bin/java -jar myapp.jar root 23268 23000 0 11:45 pts/0 00:00:00 grep --color=auto 23264
从第一行可以看出,进程 23264 的所有者是 appuser。
一旦确定了进程所有者,您需要切换到该用户身份来执行 jstack 命令。可以使用 su 或 sudo -u 命令。
使用 su 切换用户:
su - appuser
输入 appuser 用户的密码后,您将切换到该用户会话。
使用 sudo -u (无需切换会话):
如果您有 sudo 权限,并且 sudo 配置允许您以其他用户身份执行命令,可以使用以下方式:
sudo -u appuser jstack 23264 > threaddump.txt
这种方式的优点是您不需要完全切换用户会话,直接以指定用户身份执行单条命令。
切换到正确的用户或使用 sudo -u 后,您现在可以以正确的权限执行 jstack 命令来获取线程转储:
jstack 23264 > threaddump.txt
这条命令会将进程 23264 的线程转储输出到名为 threaddump.txt 的文件中。
假设我们有一个 Java 应用程序 myapp.jar 以用户 appuser 身份运行,其进程 ID 为 23264。
作为 root 用户尝试执行 jstack (失败)
# 假设当前是 root 用户 jstack 23264 > threaddump.txt
输出:
23264: well-known file /tmp/.java_pid23264 is not secure: file should be owned by the current user (which is 0) but is owned by 9001
识别进程所有者
ps -ef | grep 23264
输出(简化):
appuser 23264 1 0 10:30 ? 00:01:23 /usr/lib/jvm/java-11-openjdk-amd64/bin/java -jar myapp.jar
确认进程所有者为 appuser。
切换到 appuser 用户并执行 jstack (成功)
su - appuser # 输入 appuser 密码 jstack 23264 > threaddump.txt
输出: (无错误输出,threaddump.txt 文件将被成功创建并包含线程转储信息)
当 jstack 无法获取线程转储并报告权限错误时,最常见的原因是执行命令的用户与目标 Java 进程的所有者不匹配。通过识别进程的实际所有者并以该用户身份(或使用 sudo -u)执行 jstack 命令,可以有效地解决此问题。理解并遵循这一权限要求,是成功进行 Java 进程诊断的关键一步。
以上就是Java 进程诊断:jstack 权限与用户匹配指南的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号