java实现rabbitmq_java实现rabbitMQ

首先创建maven项目,在pom.xml中配置rabbitMQ

实现代码:

producer:

package com.rabbit.demo;

import com.rabbitmq.client.Channel;

import com.rabbitmq.client.Connection;

import com.rabbitmq.client.ConnectionFactory;

import com.rabbitmq.client.MessageProperties;

/**

* @author xbyangd

* 生产者

* producer

*/

public class DemoProducer {

private static String queueName = "rabbit";

public static void main(String[] args) throws Exception{

ConnectionFactory factory = new ConnectionFactory();

factory.setHost("127.0.0.1");

factory.setUsername("rabbit");

factory.setPassword("123456");

Connection connection = factory.newConnection();

Channel channel = connection.createChannel();

channel.queueDeclare(queueName, true, false, false, null);

for (int i = 0; i < 100; i++) {

//发送的消息

String message = "hello world!"+i;

//往队列中发出一条消息

channel.basicPublish("", queueName, MessageProperties.PERSISTENT_TEXT_PLAIN, message.getBytes());

System.out.println(" [x] Sent '" + message + "'");

//            Thread.sleep(1000);

}

//关闭频道和连接

channel.close();

connection.close();

}

}

consumer:

package com.rabbit.demo;

import com.rabbitmq.client.Channel;

import com.rabbitmq.client.Connection;

import com.rabbitmq.client.ConnectionFactory;

import com.rabbitmq.client.QueueingConsumer;

/**

* @author xbyangd

* 消费者

* consumer

*/

public class DemoConsumer {

private static String queueName = "rabbit";

public static void main(String[] args) throws Exception {

ConnectionFactory factory = new ConnectionFactory();

factory.setHost("127.0.0.1");

factory.setUsername("guest");

factory.setPassword("guest");

Connection connection = factory.newConnection();

Channel channel = connection.createChannel();

// 声明队列,主要为了防止消息接收者先运行此程序,队列还不存在时创建队列。

channel.queueDeclare(queueName, true, false, false, null);

// 创建队列消费者

QueueingConsumer consumer = new QueueingConsumer(channel);

// 设置最大服务消息接收数量

int prefetchCount = 1;

channel.basicQos(prefetchCount);

boolean ack = false; // 是否自动确认消息被成功消费

channel.basicConsume(queueName, ack, consumer); // 指定消费队列

while (true) {

// nextDelivery是一个阻塞方法(内部实现其实是阻塞队列的take方法)

QueueingConsumer.Delivery delivery = consumer.nextDelivery();

String message = new String(delivery.getBody());

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

channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);

Thread.sleep(2000);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值