win11安装java8后,jps、jvisualvm等jdk工具无法使用的问题

基础环境

jdk-8u261-windows-x64,一直下一步,安装到d盘下

1 找不到jps、jvisualvm等命令问题

运行了一个java程序,想使用jps命令看一下进程id,发现找不到jps命令

1.1 原因

找不到jps命令是因为没有添加环境变量,找到系统变量中的Path,发现自动配置了一个C:\Program Files (x86)\Common Files\Oracle\Java\javapath
在这里插入图片描述
这里面只有很基础的几个软件,jps、javadoc、jvisualvm等都不在这里,于是我们需要配置正确的环境变量

1.2 解决方案

删除这一条:C:\Program Files (x86)\Common Files\Oracle\Java\javapath
添加一条:D:\Program Files\Java\jdk1.8.0_261\bin
问题解决!

2 jdk工具无法正常使用问题

使用jps命令不显示java进程id问题,同时jvisualvm也提示无法检测到本地java应用程序

2.1 原因

其实官方已经给我们答案了:

Local Applications Cannot Be Detected (Error Dialog On Startup)
Description: An error dialog saying that local applications cannot be detected is shown immediately after VisualVM startup.

Resolution:  This can happen on Windows systems, it's caused by misconfigured jvmstat technology used to detect the running applications. There are two possible causes:

Insufficient permissions for %TMP%\hsperfdata_username folder - make sure you're able to create a file in the directory and eventually update the permissions for full folder access. Alternatively you can just re-create the folder which should automatically set the correct access rights. See see this forums.sun.com thread for more details.
Having %TMP%\hsperfdata_username folder on a FAT disk - by default jvmstat doesn't work on FAT disks due to security restrictions. You can bypass the security check by setting the -XX:+PerfBypassFileSystemCheck flag for both VisualVM and the monitored application. See the JDK bug #5042659 for more details.

大概原因是以下两点:

  1. %TMP%\hsperfdata_username文件夹权限不足、文件夹不存在、文件夹存在但不可用。
  2. 文件夹所在的磁盘不是NTFS格式的

2.2 %TMP%\hsperfdata_username文件夹

在 Windows 操作系统中,%TMP%\hsperfdata_username是用于存储 Java 进程的性能数据的目录。其中,%TMP% 是系统环境变量,指向当前用户的临时文件夹,而 username 则是当前登录用户的用户名。

Java 进程在运行时,会产生一些性能数据,例如 CPU 使用率、内存使用情况、线程数量等等。这些数据可以帮助开发人员进行性能优化和调试。在 Windows 操作系统中,Java 进程会将这些性能数据保存到 %TMP%\hsperfdata_username 目录中。

具体来说,每个 Java 进程都会在 %TMP%\hsperfdata_username 目录中创建一个以进程 ID(PID)命名的文件夹,例如 1234。在该文件夹中,会保存当前 Java 进程的性能数据文件,文件名格式为 hsperfdata_pid,例如 hsperfdata_1234

这些性能数据文件可以通过 Java Management Extensions(JMX)API 或其他性能分析工具进行访问和分析。但需要注意的是,由于这些性能数据文件包含敏感信息,如进程内存布局等,因此只有特定的用户才能访问这些文件。在 Windows 操作系统中,只有具有 Performance Log Users 或 Administrators 权限的用户才能访问 %TMP%\hsperfdata_username 目录中的文件。

如何查询出%TMP%\hsperfdata_username 所在的文件夹,使用如下cmd命令查询:

echo %TMP% 

查询出自己的用户名

echo %username%  

2.3 解决方案

首先排查文件夹所在磁盘格式,如果不是NTFS格式,则格式化为NTFS格式即可;

其次,查看%TMP%\hsperfdata_username文件夹是否有限制,如果有限制,删除即可,下次启动java进程时会自动创建该目录;

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Arthas(阿尔萨斯)是阿里巴巴开源的Java诊断工具,深受开发者喜爱。 当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了? 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗? 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现! 是否有一个全局视角来查看系统的运行状况? 有什么办法可以监控到JVM的实时运行状态? 怎么快速定位应用的热点,生成火焰图? Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的Tab自动补全功能,进一步方便进行问题的定位和诊断。   Arthas开源的Java诊断工具 更新日志: v3.5.1 Add vmtool command Remove the useless resetClassFileTransformer in Enhancer 对于非chunk response,返回标准的content-length字段 The jvm command may throw exception: java.lang.NullPointerException jad的一个小小的显示问题 bug remove env JAVA_TOOL_OPTIONS 去掉默认配置项 arthas.enhanceLoaders=java.lang.ClassLoader ,避免attach后导致系统负载飙升 Thread -n -1 不能正常工作 bug 当不到java进程时,提示不清晰,应该提示用户执行jps命令 增加一个 ognl 的在线,可编辑的示例,帮助用户自己调试 ognl表达式 当Object输出时,可能会抛出异常,打印 ERROR DATA!!! exception message: null 把 arthas-demo 改名为 math-game ,避免新用户感到疑惑 arthas spring boot starter启动失败后,没有打印具体出错端口

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

L-960

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值