RabbitMQ连接重置

时间:2018-05-28 08:33:45

标签: java rabbitmq

我试图使用java代码将简单的RabbitMQ连接到我的服务器(正在执行RabbitMQ服务)。 执行以下代码(source here)会给出 java.net.SocketException:Connection Reset 异常。

import java.io.*;
import java.security.*;


import com.rabbitmq.client.*;

public class test
{
    public static void main(String[] args) throws Exception
    {

        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost("myIP");  //myIP is just dummy text, I have a real IP there
        factory.setPort(5672);
        factory.setUsername("admin");
        factory.setPassword("sesgo");
        factory.setVirtualHost("vSESGO");

        factory.useSslProtocol();

        Connection conn = factory.newConnection();
        Channel channel = conn.createChannel();

        channel.queueDeclare("rabbitmq-java-test", false, true, true, null);
        channel.basicPublish("", "rabbitmq-java-test", null, "Hello, World".getBytes());


        GetResponse chResponse = channel.basicGet("rabbitmq-java-test", false);
        if(chResponse == null) {
            System.out.println("No message retrieved");
        } else {
            byte[] body = chResponse.getBody();
            System.out.println("Recieved: " + new String(body));
        }


        channel.close();
        conn.close();
    }
}

我已经在线寻找答案,我已经尝试过了:

  1. 验证服务器是否已连接到已打开的端口。
  2. 验证客户端不会阻止我与防火墙等的连接
  3. 在RabbitMQ上创建一个新的虚拟主机并为其授予权限。
  4. 验证iptables并没有阻止我在服务器端。
  5. 似乎没什么用,有什么想法吗?

    这里有完整的堆栈跟踪:

    This trust manager trusts every certificate, effectively disabling peer verification. This is convenient for local development but prone to man-in-the-middle attacks. Please see http://www.rabbitmq.com/ssl.html#validating-cerficates to learn more about peer certificate validation.
    Exception in thread "main" java.net.SocketException: Connection reset
     at java.net.SocketInputStream.read(Unknown Source)
     at java.net.SocketInputStream.read(Unknown Source)
     at sun.security.ssl.InputRecord.readFully(Unknown Source)
     at sun.security.ssl.InputRecord.read(Unknown Source)
     at sun.security.ssl.SSLSocketImpl.readRecord(Unknown Source)
     at sun.security.ssl.SSLSocketImpl.performInitialHandshake(Unknown Source)
     at sun.security.ssl.SSLSocketImpl.writeRecord(Unknown Source)
     at sun.security.ssl.AppOutputStream.write(Unknown Source)
     at java.io.BufferedOutputStream.flushBuffer(Unknown Source)
     at java.io.BufferedOutputStream.flush(Unknown Source)
     at java.io.DataOutputStream.flush(Unknown Source)
     at com.rabbitmq.client.impl.SocketFrameHandler.sendHeader(SocketFrameHandler.java:147)
     at com.rabbitmq.client.impl.SocketFrameHandler.sendHeader(SocketFrameHandler.java:153)
     at com.rabbitmq.client.impl.AMQConnection.start(AMQConnection.java:294)
     at com.rabbitmq.client.impl.recovery.RecoveryAwareAMQConnectionFactory.newConnection(RecoveryAwareAMQConnectionFactory.java:63)
     at com.rabbitmq.client.impl.recovery.AutorecoveringConnection.init(AutorecoveringConnection.java:99)
     at com.rabbitmq.client.ConnectionFactory.newConnection(ConnectionFactory.java:921)
     at com.rabbitmq.client.ConnectionFactory.newConnection(ConnectionFactory.java:880)
     at com.rabbitmq.client.ConnectionFactory.newConnection(ConnectionFactory.java:838)
     at com.rabbitmq.client.ConnectionFactory.newConnection(ConnectionFactory.java:990)
     at test.main(test.java:25)
    

2 个答案:

答案 0 :(得分:1)

我在这里遇到同样的问题:RabbitMQ Connection reset Exception。 Windows的解决方案是在Rabbit配置文件中添加反斜杠,以获取证书和密钥的路径。

答案 1 :(得分:0)

我不知道这是否适用于您的情况,但是最近我在测试RabbitMQ 3.8.3时解决了类似的情况,原因是我所引用的密钥受密码保护,但是我未能提供RabbitMQ配置中的密码,如下所示:

ssl_options.password = password

不幸的是,即使将日志级别设置为debug,RabbitMQ日志中也绝对没有关于此的内容。通过各种客户端进行测试时,建立了连接,但是RabbitMQ立即发送了连接重置信息。