为什么在Linux上使用Java Attach API会失败? (即使maven构建完成)
我一直在使用Java Attach API(tools.jar的一部分)连接到正在运行的java进程,并从内部关闭它。
它在Windows上运行完美。 然而,当在linux上运行时尝试实际执行附加代码时,我得到一个java.lang.NoClassDefFoundError
其中包含以下堆栈跟踪原因…
java.lang.ClassNotFoundException:com.sun.tools.attach.VirtualMachine... java.net.URLClassLoader$1.run(URLClassLoader.java:202) java.security.AccessController.doPrivileged(Native Method) java.net.URLClassLoader.findClass(URLClassLoader.java:190) java.lang.ClassLoader.loadClass(ClassLoader.java:306) sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301) java.lang.ClassLoader.loadClass(ClassLoader.java:247)
我正在使用Maven,到目前为止我有这个部分,以便包含tools.jar。
com.sun tools 1.4.2 system ${java.home}/../lib/tools.jar
值得注意的是$ {java.home}计算jre,但即使我将其更改为jdk的直接路径,问题也是一样的。
我很难过……
事实certificate这是maven构建的一个问题。 系统范围要求容器在启动时在类路径上传递tools.jar。 一个简单的java -jar
不会这样做(我不想添加一个显式的classpath参数)。
我解决这个问题的解决方案是让maven构建使用配置文件选择位置,然后在包阶段之前在本地存储库中预先安装jar(允许依赖性只是正常的依赖性)。
简介部分……
default-profile true ${java.home}/../lib/tools.jar ${java.home}/../lib/tools.jar osx_profile false mac ${java.home}/../Classes/classes.jar
安装文件部分……
org.apache.maven.plugins maven-install-plugin jdk_tools prepare-package install-file com.sun tools 1.4.2 jar ${toolsjar}
扶养
com.sun tools 1.4.2
- 本地Tomcat环境无法启动
- 主线程exception上的Android Bump Api网络
- 将Hibernate配置放在不同的位置
- 为什么hibernate将HibernateException更改为(未选中)RuntimeException
- 我应该在throws规范中声明未经检查的exception吗?
- 打开pdf时MUPDF UnsupportedOperationException
- SQLException:ResultSet关闭后不允许操作
- 如何解决Hibernateexception的原因“调用setter时发生了IllegalArgumentException”?
- 常见的下溢和溢出exception