1

我们有一个 Spring MVC Web 应用程序(WAR)部署到 Tomcat(6.0.35),它在部署时在单独的 JVM 中启动一个线程(不要问为什么 -不是我的设计),然后通过 RMI 通过端口与该线程通信8888。

尽管完全令人费解,但直到昨天为止,这一切都很好,现在线程在启动时失败了,尽管我们尽最大努力将日志记录添加到组合中,但我们还是碰壁了。这是我们能够在日志中找到的唯一异常:

Jun 12, 2012 3:11:36 AM com.ourapp.ImageController destroy
SEVERE: Shutdown Error: Lookup of RMI stub failed; nested exception is      java.rmi.ConnectException: Connection refused to host: localhost; nested exception is:
    java.net.ConnectException: Connection refused
Jun 12, 2012 3:11:37 AM org.apache.catalina.core.StandardContext listenerStop
SEVERE: Exception sending context destroyed event to listener instance of class    org.springframework.web.context.ContextLoaderListener
java.lang.NoClassDefFoundError: org/springframework/web/context/ContextCleanupListener
    at org.springframework.web.context.ContextLoaderListener.contextDestroyed(ContextLoaderListener.java:80)
    at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:3973)
    at org.apache.catalina.core.StandardContext.stop(StandardContext.java:4577)
    at org.apache.catalina.startup.HostConfig.checkResources(HostConfig.java:1165)
    at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1271)
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:296)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
    at org.apache.catalina.core.ContainerBase.backgroundProcess(ContainerBase.java:1337)
    at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1601)
    at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1610)
    at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1590)
    at java.lang.Thread.run(Thread.java:662)
Caused by: java.lang.ClassNotFoundException: org.springframework.web.context.ContextCleanupListener
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
    ... 12 more

这是负责启动这个守护进程/生成的 RMI 线程ImageController的 Spring MVC 。Controller根据此错误的措辞,是否有人知道可能导致此“连接被拒绝”错误的原因?

运行 a netstat -an | grep 8888(这是一台 Linux 机器)不会产生任何输出,这意味着该端口上没有任何东西在监听。提前感谢任何导致修复的想法/建议。

编辑:这是ConnectionException我们看到的另一个:

Caused by: java.net.ConnectException: Connection refused
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:351)
    at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:213)
    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:200)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
    at java.net.Socket.connect(Socket.java:529)
    at java.net.Socket.connect(Socket.java:478)
    at java.net.Socket.<init>(Socket.java:375)
    at java.net.Socket.<init>(Socket.java:189)
    at sun.rmi.transport.proxy.RMIDirectSocketFactory.createSocket(RMIDirectSocketFactory.java:22)
    at sun.rmi.transport.proxy.RMIMasterSocketFactory.createSocket(RMIMasterSocketFactory.java:128)
    at sun.rmi.transport.tcp.TCPEndpoint.newSocket(TCPEndpoint.java:595)
    ... 74 more
4

2 回答 2

2

我会将我的评论移至此答案。

日志中的所有内容都表明问题出在您连接到端口 8888 的另一台计算机上。netstat结果证明没有进程在该端口上侦听 - 因此日志中出现连接错误。

我将采取的下一步是检查另一台机器(或其他JVM)上的应用程序是否正在运行(例如ps ax|grep java)。如果确实如此,请检查其日志以了解它未能启动 RMI 服务的原因,或者如果它没有 - 启动它。

通常,如果应用程序无法打开套接字,这是因为其他应用程序已经在使用该端口。你的情况并非如此。可能是同一个应用程序的两个实例已启动:第一个应用程序占用 8888 端口,第二个应用程序无法占用 8888 并失败,然后第一个应用程序被关闭。毕竟你最终没有人在监听端口。

于 2012-06-12T11:01:47.173 回答
0

有谁知道可能导致此“连接被拒绝”错误的原因?

它就在堆栈跟踪中:

java.lang.NoClassDefFoundError: org/springframework/web/context/ContextCleanupListener

您的部署缺少该类,即它所包含的 JAR 文件。

于 2012-06-12T10:46:38.360 回答