RabbitMQ - 发布者应用程序


现在让我们创建一个发布者应用程序,它将向 RabbitMQ Exchange 发送消息。该交换器会将消息传递到与该交换器绑定的队列。

创建项目

使用 eclipse,选择FileNewMaven Project。勾选“创建一个简单项目(跳过原型选择)”,然后单击“下一步”。

输入详细信息,如下所示 -

  • groupId - com.tutorialspoint

  • artifactId - 发布者

  • 版本- 0.0.1-SNAPSHOT

  • 名称- RabbitMQ 发布者

单击完成按钮,将创建一个新项目。

pom.xml

现在更新 pom.xml 的内容以包含 RabbitMQ 的依赖项。

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint.activemq</groupId>
   <artifactId>publisher</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <name>RabbitMQ Publisher</name>
   <properties>
      <java.version>11</java.version>
   </properties>
   <dependencies>
      <dependency>
         <groupId>com.rabbitmq</groupId>
         <artifactId>amqp-client</artifactId>
         <version>5.14.2</version>
      </dependency>
      <dependency>
         <groupId>org.slf4j</groupId>
         <artifactId>slf4j-api</artifactId>
         <version>1.7.26</version>
      </dependency>
      <dependency>
         <groupId>org.slf4j</groupId>
         <artifactId>slf4j-simple</artifactId>
         <version>1.7.26</version>
      </dependency>
   </dependencies>
</project>

现在创建一个 Publisher 类,它将向 RabbitMQ 主题发送消息,以将其广播给所有订阅者。

package com.tutorialspoint.rabbitmq;

import java.io.IOException;
import java.util.Scanner;
import java.util.concurrent.TimeoutException;

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

public class Publisher {
   private static final String EXCHANGE = "MyExchange";
   public static void main(String[] args) throws IOException, TimeoutException {
      ConnectionFactory factory = new ConnectionFactory();
      factory.setHost("localhost");
      try (Connection connection = factory.newConnection();
      Channel channel = connection.createChannel()) {
         channel.exchangeDeclare(EXCHANGE, "fanout");
         Scanner input = new Scanner(System.in);
         String message;
         do {
            System.out.println("Enter message: ");
            message = input.nextLine();
            channel.basicPublish(EXCHANGE, "", null, message.getBytes());
         } while (!message.equalsIgnoreCase("Quit"));
      }
   }
}

生产者类创建一个连接,创建一个通道,声明一个交换,然后要求用户输入消息。消息被发送到交换器并作为队列名称,我们没有传递队列名称,因此绑定到该交换器的所有队列都将收到消息。如果用户输入 quit,则应用程序终止,否则它将向主题发送消息。

我们将在RabbitMQ - 测试应用程序一章中运行此应用程序。