Java 如何从本地docker容器中运行的rabbitmq队列读取消息

Java 如何从本地docker容器中运行的rabbitmq队列读取消息,java,docker,networking,rabbitmq,amqp,Java,Docker,Networking,Rabbitmq,Amqp,我正在docker容器中的本地mac中运行rabbitmq。我通过浏览器中的GUI(15672端口)访问了它,并创建了一个队列,在队列中交换和发布了一些消息。我正在尝试编写一个java应用程序,它可以从队列中读取消息并在控制台中打印出来,但是我遇到了这个错误 rjashnani-ltm:rabbitmq rjashnani$ java -cp .:amqp-client-5.7.1.jar:slf4j-api-1.7.26.jar:slf4j-simple-1.7.26.jar Recv Exc

我正在docker容器中的本地mac中运行rabbitmq。我通过浏览器中的GUI(15672端口)访问了它,并创建了一个队列,在队列中交换和发布了一些消息。我正在尝试编写一个java应用程序,它可以从队列中读取消息并在控制台中打印出来,但是我遇到了这个错误

rjashnani-ltm:rabbitmq rjashnani$ java -cp .:amqp-client-5.7.1.jar:slf4j-api-1.7.26.jar:slf4j-simple-1.7.26.jar Recv
Exception in thread "main" java.net.ConnectException: Connection refused (Connection refused)
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
我使用这个命令创建了docker容器

docker run -d --hostname my-rabbit --name some-rabbit2 -p 15672:15672 -p 5672:5672 rabbitmq:3-management
这是我的Java应用程序代码

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.DeliverCallback;

public class Recv {

    private final static String QUEUE_NAME = "test-queue";

    public static void main(String[] argv) throws Exception {
        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost("localhost");
        factory.setPort(5762);
        factory.setUsername("guest");
        factory.setPassword("guest");
        factory.setVirtualHost("/");
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();

        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        System.out.println(" [*] Waiting for messages. To exit press CTRL+C");

        DeliverCallback deliverCallback = (consumerTag, delivery) -> {
            String message = new String(delivery.getBody(), "UTF-8");
            System.out.println(" [x] Received '" + message + "'");
        };
        channel.basicConsume(QUEUE_NAME, true, deliverCallback, consumerTag -> { });
    }
}

使用
-it
参数运行docker,解决了问题

factory.setPort(5762)而您正在转发
5672
端口。@michalk没有。我不知道该怎么做。您有一个输入错误。您的连接工厂为端口
5762
创建连接,但您正在
docker run
命令中将
5672
发布到主机。
docker run -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management