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

标签 java docker networking rabbitmq amqp

我正在本地 mac 的 docker 容器中运行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 -> { });
    }
}

最佳答案

docker run -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management

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

关于java - 如何从本地docker容器中运行的rabbitmq队列读取消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59808210/

相关文章:

java - 使用方法调用合并两个数组

java - 公共(public)类 Extra<BASE> 扩展 BASE

docker - Docker Compose不公开网络端口

amazon-web-services - AWS ECR端点no_proxy问题

networking - 计算数据包的总传输时间

multithreading - 在 Windows 上等待 Network.Socket.accept 的 Haskell 或 Haskell OS 线程能否被杀死?

java - 无法将应用程序转换到类

java - 如何使用for循环在java中的数组中存储多个电影标题

多阶段构建中的 Docker-Compose Args(变量扩展)

linux - Backtrack 4 无线不工作