import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; /** * 消息生产者 */ public class P { private final static String QUEUE_NAME = "hello"; public static void main(String[] argv) throws Exception { //创建一个新的连接工厂 ConnectionFactory factory = new ConnectionFactory(); //用工厂设置RabbitMQ地址 factory.setHost("localhost"); //用工厂创建一个新的连接 Connection connection = factory.newConnection(); //用连接创建一个新的频道 Channel channel = connection.createChannel(); //用频道声明一个新的队列 //在RabbitMQ中,队列声明是幂等性的(一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同), //也就是说,如果不存在,就创建,如果存在,不会对已经存在的队列产生任何影响。 channel.queueDeclare(QUEUE_NAME, false, false, false, null); String message = "Hello World!"; //发送消息到队列中 channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8")); System.out.println("生产者发送消息:" + message ); //关闭频道和连接 channel.close(); connection.close(); } }
package com.gch.rabbit.helloworld; import com.rabbitmq.client.AMQP; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.Consumer; import com.rabbitmq.client.DefaultConsumer; import com.rabbitmq.client.Envelope; import java.io.IOException; /** * 消息消费者 */ public class C { private final static String QUEUE_NAME = "hello"; public static void main(String[] argv) throws Exception { //创建一个新的连接工厂 ConnectionFactory factory = new ConnectionFactory(); //用工厂设置RabbitMQ地址 factory.setHost("localhost"); //用工厂创建一个新的连接 Connection connection = factory.newConnection(); //用连接创建一个频道 Channel channel = connection.createChannel(); //用频道声明要关注的队列 //在RabbitMQ中,队列声明是幂等性的(一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同), //也就是说,如果不存在,就创建,如果存在,不会对已经存在的队列产生任何影响。 channel.queueDeclare(QUEUE_NAME, false, false, false, null); System.out.println("消费者等待消息中..."); //DefaultConsumer类实现了Consumer接口,通过传入一个频道,告诉服务器我们需要那个频道的消息,如果频道中有消息,就会执行回调函数handleDelivery Consumer consumer = new DefaultConsumer(channel) { @Override public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException { String message = new String(body, "UTF-8"); System.out.println("消费者接收消息:" + message); } }; //自动回复队列应答 -- RabbitMQ中的消息确认机制. channel.basicConsume(QUEUE_NAME, true, consumer); } }