Java实现RabbitMQ以及Jar包的实现

今天应上级要求,撰写JAVA代码测试RabbitMQ。

以下为环境要求:

RabbitMQ环境不在此电脑,并且无法通讯,需要写完之后打成jar包,运行在另一台主机。开发工具Myeclipse10,JDK1.6,RabbitMQ3.4,所需jar包在www.rabbitmq.com上下载的rabbitmq-java-client-bin-3.6.1。

第一步,建立工程rabbitMQTest,,结构如图所示。所需Jar包放在了lib目录下,

二步,新建class名为,Send.java,来为RabbitMQ测试发送数据。代码如下

package com.mq;


import java.util.concurrent.TimeoutException;


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


public class Send {
    private static final String TASK_QUEUE_NAME = "task_queue";


    public static void main(String[] argv) throws java.io.IOException, TimeoutException, InterruptedException {
    <span style="white-space:pre">	</span>    System.out.println("----------main method is begin----------");
    <span style="white-space:pre">	</span>    //创建工厂
        ConnectionFactory factory = new ConnectionFactory();
        System.out.println("----------factory successful!----------");
        //设置IP,端口,账户和密码
        factory.setHost("192.168.228.87");
        factory.setPort(5672);
        factory.setUsername("mq");
        factory.setPassword("mq");
        //创建连接对象
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();
        System.out.println("----------connected successful!----------");


        // 指定队列持久化
        channel.queueDeclare(TASK_QUEUE_NAME, true, false, false, null);
        String message = getMessage(argv);
        //共发送10万条数据,每隔1S发送1次
        int index=0;
<span style="white-space:pre">	</span>    while (index<100000){
<span style="white-space:pre">		</span>Thread.sleep(1*1000);
<span style="white-space:pre">		</span>channel.basicPublish("", TASK_QUEUE_NAME, MessageProperties.PERSISTENT_TEXT_PLAIN, message.getBytes());
<span style="white-space:pre">		</span>System.out.println(" [x] Sent '" + message + "'");
<span style="white-space:pre">		</span>index++;
<span style="white-space:pre">		</span>}
        channel.close();
        connection.close();
    }




    private static String getMessage(String[] strings) {
        if (strings.length < 1)
            return "Hello World!";
        return joinStrings(strings, " ");
    }


    private static String joinStrings(String[] strings, String delimiter) {
        int length = strings.length;
        if (length == 0)
            return "";
        StringBuilder words = new StringBuilder(strings[0]);
        for (int i = 1; i < length; i++) {
            words.append(delimiter).append(strings[i]);
        }
        return words.toString();
    }
}
第三步,新建Class名为Recv.java, 来为RabbitMQ测试接收 数据。代码如下

package com.mq;
import java.io.IOException;
import java.util.concurrent.TimeoutException;

import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.QueueingConsumer;
public class Recv {
	private static final String TASK_QUEUE_NAME = "task_queue";

    public static void recv() throws java.io.IOException, java.lang.InterruptedException, TimeoutException {
    	System.out.print("----------main method is begin----------");
        ConnectionFactory factory = new ConnectionFactory();
        System.out.println("----------factory successful!----------");
        factory.setHost("192.168.228.87");
        factory.setPort(5672);
        factory.setUsername("mq");
        factory.setPassword("mq");
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();
        System.out.println("----------connected successful!----------");

        // 指定队列持久化
        channel.queueDeclare(TASK_QUEUE_NAME, true, false, false, null);
        System.out.println(" [*] Waiting for messages. To exit press CTRL+C");

        // 指定该线程同时只接收一条消息
        channel.basicQos(1);

        QueueingConsumer consumer = new QueueingConsumer(channel);

        // 打开消息应答机制
        channel.basicConsume(TASK_QUEUE_NAME, false, consumer);

        while (true) {
            QueueingConsumer.Delivery delivery = consumer.nextDelivery();
            String message = new String(delivery.getBody());

            System.out.println(" [x] Received '" + message + "'");
            doWork(message);
            System.out.println(" [x] Done");

            // 返回接收到消息的确认信息
            channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);
        }
    }

    private static void doWork(String task) throws InterruptedException {
        for (char ch : task.toCharArray()) {
            if (ch == '.')
                Thread.sleep(1000);
        }
    }
    public static void main(String[] args) throws IOException, InterruptedException, TimeoutException {
    	recv();
	}
}
最后,打成Jar包,分别为Send.jar和Recv.jar,在下图2的第1步中Send.jar要选Send的main方法,Recv.jar要选Recv的main方法,这里只对Sen.jar贴图:

图1

图2

打好的包,即可在另一台装有rabbitMQ环境和JRE环境中运行,具体使用的命令是:

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Java实现RabbitMQ消息推送,首先需要引入RabbitMQjar包。根据引用,我们可以通过引入amqp-client的包来实现。在你的项目的pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.rabbitmq</groupId> <artifactId>amqp-client</artifactId> </dependency> ``` 接下来,你需要建立与RabbitMQ的连接,创建一个通道,以及声明一个队列来发送消息。以下是一个基本的示例代码: ```java import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.Connection; import com.rabbitmq.client.Channel; public class RabbitMQProducer { private final static String QUEUE_NAME = "my_queue"; public static void main(String[] argv) throws Exception { // 建立连接 ConnectionFactory factory = new ConnectionFactory(); factory.setHost("localhost"); Connection connection = factory.newConnection(); Channel channel = connection.createChannel(); // 声明队列 channel.queueDeclare(QUEUE_NAME, false, false, false, null); // 发送消息 String message = "Hello, RabbitMQ!"; channel.basicPublish("", QUEUE_NAME, null, message.getBytes()); System.out.println("Sent message: " + message); // 关闭连接 channel.close(); connection.close(); } } ``` 这段代码首先建立与RabbitMQ的连接,然后创建一个通道,并声明一个名为"my_queue"的队列。接着,它发送了一条消息"Hello, RabbitMQ!"到该队列中。最后,关闭了通道和连接。 以上是一个简单的Java实现RabbitMQ消息推送的例子,你可以根据自己的需求修改其中的细节。希望对你有帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [使用Java体验RabbitMQ消息的发送与消费过程](https://blog.csdn.net/cssweb_sh/article/details/125133874)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Java编程rabbitMQ实现消息的收发](https://download.csdn.net/download/weixin_38570278/12772878)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值