rabbitMQ——生产者(头部消息),消费者(获取头部消息)

1.生产者


package net.stxy.one.message;

import java.util.HashMap;
import java.util.Map;

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

public class Producer {

    public static void main(String[] args) throws Exception {
        //1.创建连接工厂,并进行配置
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("127.0.0.1");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");
        //2.创建连接
        Connection connection = connectionFactory.newConnection();
        //3.创建连接通道
        Channel channel = connection.createChannel();
        //自定义属性
        Map<String,Object> headers = new HashMap<>();
        headers.put("my1", "111");
        headers.put("my2", "222");
        AMQP.BasicProperties  properties =new AMQP.BasicProperties.Builder()
                .deliveryMode(2)//2表示持久化
                .contentEncoding("UTF-8")
                .expiration("10000")//10秒钟过期
                .headers(headers)//自定义属性
                .build();

        //4.发送数据,exchange,routingkey,props:消息附加属性,body:消息实体
        for (int i = 0; i < 50; i++) {
            String msg = "lulu张雪喜欢你";
            channel.basicPublish("", "lulu", properties, msg.getBytes());
            System.out.println(msg);
        }
        //5.关闭连接:由小到大
        channel.close();
        connection.close();
        
    }
}
 


2.消费者1


package net.stxy.one.message;

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

public class Consumer1 {
    public static void main(String[] args) throws Exception {
        //1.创建连接工厂,并进行配置
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("127.0.0.1");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");
        //2.创建连接
        Connection connection = connectionFactory.newConnection();
        //3.创建连接通道
        Channel channel = connection.createChannel();
        //4.生命一个队列   1. 队列称,2.持久化,3.独占:只只有改通道能监听,4.脱离exchange会自动删除5.扩展参数
        String queueName = "lulu1";
        channel.queueDeclare(queueName, true, false, false, null);
        //5.创建一个消费者
        QueueingConsumer queueingConsumer = new QueueingConsumer(channel);
        //6.设置channel   1.队列名称,2.自动签收 3.消费者对象
        channel.basicConsume(queueName, true, queueingConsumer);
        //7.获取消息   会一直阻塞。可以设置时间通过                                                                   
        while (true) {
            System.out.println("开始消费数据");
            
            Delivery delivery = queueingConsumer.nextDelivery();//没有设置时间一直阻塞。
            
            String msg = new String(delivery.getBody());//消息实体body
            System.out.println("消费端收到消息"+msg);
            System.err.println("消费端收到消息"+msg);
            //Envelope envelope = delivery.getEnvelope();//消息属性     

            
        }
 
    }
}
 


3.消费者2


package net.stxy.one.message;

import java.util.Map;

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

public class Consumer {
    public static void main(String[] args) throws Exception {
        //1.创建连接工厂,并进行配置
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("127.0.0.1");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");
        //2.创建连接
        Connection connection = connectionFactory.newConnection();
        //3.创建连接通道
        Channel channel = connection.createChannel();
        //4.生命一个队列   1. 队列称,2.持久化,3.独占:只只有改通道能监听,4.脱离exchange会自动删除5.扩展参数
        String queueName = "lulu";
        channel.queueDeclare(queueName, true, false, false, null);
        //5.创建一个消费者
        QueueingConsumer queueingConsumer = new QueueingConsumer(channel);
        //6.设置channel   1.队列名称,2.自动签收 3.消费者对象
        channel.basicConsume(queueName, true, queueingConsumer);
        //7.获取消息   会一直阻塞。可以设置时间通过                                                                   
        while (true) {
            System.out.println("开始消费数据");
            
            Delivery delivery = queueingConsumer.nextDelivery();//没有设置时间一直阻塞。
            
            String msg = new String(delivery.getBody());//消息实体body
            Map<String,Object> headers = delivery.getProperties().getHeaders();
            System.out.println(headers.get("my1"));
            System.out.println(headers.get("my2"));
            //Envelope envelope = delivery.getEnvelope();//消息属性     

            
        }
        
        
    
        
    }
}
 



 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

择业

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值