使用eclipse远程调试jnlp应用程序

我正在调试一个jnlp应用程序,我曾经能够通过eclipse远程调试它,但现在不再了。

启动它的命令是:

/usr/java/jdk1.6.0_14/jre/bin/java -Xnoagent -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=1445 -Djnlpx.heapsize=64m,512m -DtrustProxy=true -Xverify:remote -Djava.security.policy=/lib/security/javaws.policy -Dfile.encoding=UTF-8 -Xbootclasspath/a:/usr/java/jdk1.6.0_14/jre/lib/deploy.jar:/usr/java/jdk1.6.0_14/jre/lib/javaws.jar:/usr/java/jdk1.6.0_14/jre/lib/plugin.jar -classpath /usr/java/jdk1.6.0_14/jre/lib/deploy.jar com.sun.javaws.Main launch.jnlp Listening for transport dt_socket at address: 1445 

问题是,当我附加eclipse调试器时,它会关闭并重新启动; 所以调试器附加到第一个进程; 当它死了,调试器也是如此。

调试器脚本实际上并不重要; 因为如果suspend = n,在调试器启动之前,jnlp进程会自行重新启动。

我试过跟踪它,但选项-XX:TraceSupport = true(以及我尝试的其他变体)会导致jvm错误。

我正在使用Fedora 11,Eclipse Java EE IDE for Web Developers。 (构建ID:20090621-0832)

我问是否有人知道如何解决这个问题,或者至少如何打开更好的日志记录(即将所有控制台输出捕获到日志中;这样我就可以看一下屏幕上闪烁的第一个控制台一毫秒)

谢谢!

这篇博客文章包含可以设置为调试jnlp的环境变量。 这一直对我有用。

  set JAVAWS_TRACE_NATIVE=1 set JAVAWS_VM_ARGS=-Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=8989,server=y,suspend=y javaws http://server:port/descriptor.jnlp 

我的老板找到了答案:

看来jnlp文件中的标签对于较新的JRE更具限制性。 根据Sun文档 :

“对于不受信任的应用程序,JNLP文件中设置的系统属性只有在被认为是安全的时候才能由Java Web Start设置,或者如果属性名称以”jnlp“开头。 或“javaws。”。“

看起来不受信任的状态会导致应用程序第二次使用适当的属性启动。

在重新编译并修复了一个希望无关的问题,其中换行符导致签名的APPLICATION.JNLP和launch.jnlp看起来不是“相同”,调试器现在正在工作。