【问题标题】:"java.io.EOFException: SSL peer shut down incorrectly" thrown when not using SSL不使用 SSL 时抛出“java.io.EOFException:SSL 对等体错误关闭”
【发布时间】:2015-01-16 22:49:42
【问题描述】:

我无法将 VisualVM 连接到远程 JVM。我已经使用以下参数启动了远程 JVM:

 java -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.local.only=false -Dcom.sun.management.jmxremote.port=9000 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=[server ip] -Dlog4j.configurationFile=file:///home/ubuntu/servicesLog4j2.xml -jar /home/ubuntu/Program.jar &

注意-Dcom.sun.management.jmxremote.ssl=false

然后我启动 VisualVM 并向服务器添加一个新的 JMX 连接。我专门检查了这个选项:

不需要 SLL 连接

当连接失败时,我可以在 VisualVM 日志中看到以下错误。如果我在远程 VM 上使用标志禁用 SSL 并指定在 VisualVM 中不需要 SSL,我不确定为什么会涉及 SSL。但看起来这个错误正在阻止连接。我错过了什么?

java.io.EOFException: SSL peer shut down incorrectly
    at sun.security.ssl.InputRecord.read(InputRecord.java:505)
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:954)
Caused: javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:973)
    at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1343)
    at sun.security.ssl.SSLSocketImpl.writeRecord(SSLSocketImpl.java:728)
    at sun.security.ssl.AppOutputStream.write(AppOutputStream.java:123)
    at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:82)
    at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:140)
    at java.io.DataOutputStream.flush(DataOutputStream.java:123)
    at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:229)
Caused: java.rmi.ConnectIOException: error during JRMP connection establishment; nested exception is: 
    javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake
    at sun.rmi.transport.tcp.TCPChannel.createConnection(TCPChannel.java:304)
    at sun.rmi.transport.tcp.TCPChannel.newConnection(TCPChannel.java:202)
    at sun.rmi.server.UnicastRef.newCall(UnicastRef.java:342)
    at sun.rmi.registry.RegistryImpl_Stub.lookup(Unknown Source)
    at com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:118)
Caused: javax.naming.CommunicationException [Root exception is java.rmi.ConnectIOException: error during JRMP connection establishment; nested exception is: 
    javax.net.ssl.SSLHandshakeException: Remote host closed connection during handshake]
    at com.sun.jndi.rmi.registry.RegistryContext.lookup(RegistryContext.java:122)
    at com.sun.jndi.toolkit.url.GenericURLContext.lookup(GenericURLContext.java:205)
    at javax.naming.InitialContext.lookup(InitialContext.java:417)
    at javax.management.remote.rmi.RMIConnector.findRMIServerJNDI(RMIConnector.java:1929)
    at javax.management.remote.rmi.RMIConnector.findRMIServer(RMIConnector.java:1896)
    at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:287)
Caused: java.io.IOException: Failed to retrieve RMIServer stub
    at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:369)
    at com.sun.tools.visualvm.jmx.impl.JmxModelImpl$ProxyClient.tryConnect(JmxModelImpl.java:569)
[catch] at com.sun.tools.visualvm.jmx.impl.JmxModelImpl$ProxyClient.connect(JmxModelImpl.java:506)
    at com.sun.tools.visualvm.jmx.impl.JmxModelImpl.connect(JmxModelImpl.java:234)
    at com.sun.tools.visualvm.jmx.impl.JmxModelImpl.<init>(JmxModelImpl.java:223)
    at com.sun.tools.visualvm.jmx.impl.JmxModelProvider.createModelFor(JmxModelProvider.java:60)
    at com.sun.tools.visualvm.jmx.impl.JmxModelProvider.createModelFor(JmxModelProvider.java:41)
    at com.sun.tools.visualvm.core.model.ModelFactory.getModel(ModelFactory.java:111)
    at com.sun.tools.visualvm.tools.jmx.JmxModelFactory.getJmxModelFor(JmxModelFactory.java:69)
    at com.sun.tools.visualvm.jmx.impl.JmxApplicationProvider.addJmxApplication(JmxApplicationProvider.java:295)
    at com.sun.tools.visualvm.jmx.impl.JmxApplicationProvider.createJmxApplication(JmxApplicationProvider.java:200)
    at com.sun.tools.visualvm.jmx.JmxApplicationsSupport.createJmxApplicationImpl(JmxApplicationsSupport.java:319)
    at com.sun.tools.visualvm.jmx.JmxApplicationsSupport.createJmxApplicationInteractive(JmxApplicationsSupport.java:296)
    at com.sun.tools.visualvm.jmx.impl.AddJMXConnectionAction$1.run(AddJMXConnectionAction.java:80)
    at org.openide.util.RequestProcessor$Task.run(RequestProcessor.java:1423)
    at org.openide.util.RequestProcessor$Processor.run(RequestProcessor.java:2033)

【问题讨论】:

  • 连接是否通过代理?

标签: java visualvm jvisualvm


【解决方案1】:

在头疼之后我是如何解决这个问题的:

  1. 如果远程计算机上有防火墙,则第二个随机端口(导出远程对象的位置)可能存在问题。尝试禁用防火墙,如果它有效,那么您可能需要执行类似this 的操作。 Tomcat有一个监听器来解决它:link

  2. 确保 -Djava.rmi.server.hostname 下的值从您的客户端位置解析为主机(这是我的情况)

  3. 最后 jconsole(在 JDK bin 文件夹中,与 VisualVM 相同)提供了非常有用的信息。 使用 -debug 选项从控制台执行它。使用调试选项,Jconsole 将弹出堆栈跟踪,解释您的客户端无法连接的真正原因。当您尝试连接到非 SSL 服务器时,JConsole 最初会失败,然后它会要求您连接“不安全”,接下来您将看到真正的原因,在我的情况下,它正在寻找环回 IP 127.0 处的对象导出端口。 0.1(因为我没有使用 -Djava.rmi.server.hostname 选项)。

希望对你有帮助!

【讨论】:

  • 这个问题是在初始端口,注册表端口,在进行查找时引起的。不在自己的端口上调用对象。见星迹。错误的端口会给你一个连接拒绝。防火墙端口未打开会导致连接超时。错误的主机名会导致拒绝或超时。这些都不会导致 OP 的错误。
  • 我理解您对堆栈跟踪所说的内容以及它似乎正在发生的事情的担忧。当我解决这个问题时,我有完全相同的堆栈跟踪。首先让我感到担忧的是,为什么在不涉及 SSL 的情况下会出现 SSL 握手问题?答案是 VisialVM 在一次不成功的非 SSL 尝试后支持 SSL 并隐藏了真正的异常原因。总之,在处理非安全连接时不要信任 VisualVM 日志,通过 jconsole 来完成。
猜你喜欢
  • 1970-01-01
  • 2018-10-18
  • 1970-01-01
  • 1970-01-01
  • 2018-05-17
  • 1970-01-01
  • 2021-12-04
  • 2015-05-08
  • 2016-12-10
相关资源
最近更新 更多