我想从Eclipse启动远程主机上的Tomcat调试会话,但它失败并出现此错误:
Failed to connect to remote VM
com.sun.jdi.connect.spi.ClosedConnectionException
我认为我的Tomcat已正确配置为在端口8000上接收调试会话:
tomcat 18771 1 1 17:18 ? 00:00:16 /usr/lib/jvm/java/bin/java -Xdebug -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n -Djava.rmi.server.hostname=10.30.0.17 -Dcatalina.ext.dirs=/usr/share/tomcat5/shared/lib:/usr/share/tomcat5/common/lib -Djavax.sql.DataSource.Factory=org.apache.commons.dbcp.BasicDataSourceFactory -Djava.endorsed.dirs=/usr/share/tomcat5/common/endorsed -classpath /usr/lib/jvm/java/lib/tools.jar:/usr/share/tomcat5/bin/bootstrap.jar:/usr/share/tomcat5/bin/commons-logging-api.jar:/usr/share/java/mx4j/mx4j-impl.jar:/usr/share/java/mx4j/mx4j-jmx.jar -Dcatalina.base=/usr/share/tomcat5 -Dcatalina.home=/usr/share/tomcat5 -Djava.io.tmpdir=/usr/share/tomcat5/temp org.apache.catalina.startup.Bootstrap start
我的电脑和远程服务器之间有防火墙,但端口打开很好,因为我可以在服务器上看到tcpdump
的这些数据包:
17:41:17.110977 IP X.X.X.X.57010 > Y.Y.Y.Y.irdmi: S 868833744:868833744(0) win 8192 <mss 1460,nop,wscale 8,nop,nop,sackOK>
17:41:17.111183 IP Y.Y.Y.Y.irdmi > X.X.X.X.57010: S 3571247457:3571247457(0) ack 868833745 win 5840 <mss 1460,nop,nop,sackOK,nop,wscale 7>
17:41:17.112624 IP X.X.X.X.57010 > Y.Y.Y.Y.irdmi: . ack 1 win 256
17:41:19.113216 IP Y.Y.Y.Y.irdmi > X.X.X.X.57010: F 1:1(0) ack 1 win 46
17:41:19.114246 IP X.X.X.X.57010 > Y.Y.Y.Y.irdmi: P 1:15(14) ack 1 win 256
17:41:19.114279 IP Y.Y.Y.Y.irdmi > X.X.X.X.57010: R 3571247458:3571247458(0) win 0
Tomcat日志中唯一的写入消息是 调试器无法附加:握手期间超时
我无法弄清楚我在网上发现的错误信息是什么。
任何人都可以帮助我吗?
我的服务器:RHEL 5.9,Tomcat 5.5,java 1.6
此致 罗伯特
答案 0 :(得分:0)
我解决了我的问题:在我的PC和服务器之间的防火墙上激活了数据包检查。它允许某些TCP数据包通过,因此可以发生TCP握手,但阻止数据TCP数据包。
据我所知,首先,建立TCP连接,然后由具有TCP数据包的java服务器完成应用程序握手。由于数据包被防火墙过滤,应用程序握手无法完成,应用程序通过发送FIN数据包来关闭TCP连接。
此致 罗伯特