RabbitMQ: Publish/Subscribe结构

生产者

java 复制代码
package com.qf.mq2302.publishSub;

import com.qf.mq2302.utils.MQUtils;

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

public class EmitLog {
    private static final String EXCHANGE_NAME = "logs";

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

        Connection conn = MQUtils.getConnection();
        Channel channel = conn.createChannel();

        // 在mq中声明一个交换机
        /**
         * 第一个参数:交换机的名字
         * 第二个参数:交换机的类型,fanout代表该交换机会把收到的消息无差别投递给所有他关联的队列
         */
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");

        String msg = "hello fanout!";

        /**
         * 第一个参数,交换机的名字
         * 第二个参数:如果交换机是 fanout类型的,可以写空串 ;因为fanout类型的交换机会把消息无差别向关联队列投递
         */
        channel.basicPublish(EXCHANGE_NAME,"",null,msg.getBytes("utf-8"));


        channel.close();
        conn.close();
    }
}

消费者1

java 复制代码
package com.qf.mq2302.publishSub;

import com.qf.mq2302.utils.MQUtils;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.DeliverCallback;
import com.rabbitmq.client.Delivery;

import java.io.IOException;

public class ReceiveLogs01 {
    private static final String EXCHANGE_NAME = "logs";

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

        Connection conn = MQUtils.getConnection();
        Channel channel = conn.createChannel();
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 在mq中声明一个名字是随机字符串的队列(队列的所有属性都是默认值),返回队列的名字
        String queueName = channel.queueDeclare().getQueue();
        // 把队列和交换机建立好绑定关系
        /**
         * 参数1: 队列名
         * 参数2: 交换机名
         * 参数3: routingkey,注意,如果交换机是fanout类型,可以写空串
         */
        channel.queueBind(queueName,EXCHANGE_NAME,"");

        channel.basicQos(1);
        channel.basicConsume(queueName, false, new DeliverCallback() {
            @Override
            public void handle(String consumerTag, Delivery message) throws IOException {
                byte[] body = message.getBody();
                String msg = new String(body, "utf-8");
                System.out.println("01:"+msg);

                // 手动ack
                channel.basicAck(message.getEnvelope().getDeliveryTag(),false);
            }
        },c -> {});

    }
}

消费者2

java 复制代码
package com.qf.mq2302.publishSub;

import com.qf.mq2302.utils.MQUtils;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.DeliverCallback;
import com.rabbitmq.client.Delivery;

import java.io.IOException;

public class ReceiveLogs02 {
    private static final String EXCHANGE_NAME = "logs";

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

        Connection conn = MQUtils.getConnection();
        Channel channel = conn.createChannel();
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 在mq中声明一个名字是随机字符串的队列(队列的所有属性都是默认值),返回队列的名字
        String queueName = channel.queueDeclare().getQueue();
        // 把队列和交换机建立好绑定关系
        /**
         * 参数1: 队列名
         * 参数2: 交换机名
         * 参数3: routingkey,注意,如果交换机是fanout类型,可以写空串
         */
        channel.queueBind(queueName,EXCHANGE_NAME,"");

        channel.basicQos(1);
        channel.basicConsume(queueName, false, new DeliverCallback() {
            @Override
            public void handle(String consumerTag, Delivery message) throws IOException {
                byte[] body = message.getBody();
                String msg = new String(body, "utf-8");
                System.out.println("02:"+msg);

                // 手动ack
                channel.basicAck(message.getEnvelope().getDeliveryTag(),false);
            }
        },c -> {});

    }
}

消费者3

java 复制代码
package com.qf.mq2302.publishSub;

import com.qf.mq2302.utils.MQUtils;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.DeliverCallback;
import com.rabbitmq.client.Delivery;

import java.io.IOException;

public class ReceiveLogs03 {
    private static final String EXCHANGE_NAME = "logs";

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

        Connection conn = MQUtils.getConnection();
        Channel channel = conn.createChannel();
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 在mq中声明一个名字是随机字符串的队列(队列的所有属性都是默认值),返回队列的名字
        String queueName = channel.queueDeclare().getQueue();
        // 把队列和交换机建立好绑定关系
        /**
         * 参数1: 队列名
         * 参数2: 交换机名
         * 参数3: routingkey,注意,如果交换机是fanout类型,可以写空串
         */
        channel.queueBind(queueName,EXCHANGE_NAME,"");

        channel.basicQos(1);
        channel.basicConsume(queueName, false, new DeliverCallback() {
            @Override
            public void handle(String consumerTag, Delivery message) throws IOException {
                byte[] body = message.getBody();
                String msg = new String(body, "utf-8");
                System.out.println("03:"+msg);

                // 手动ack
                channel.basicAck(message.getEnvelope().getDeliveryTag(),false);
            }
        },c -> {});

    }
}
相关推荐
闪电悠米8 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
z落落12 小时前
C# 事件(Event)+自定义带参数事件例子
开发语言·分布式·c#
我是一颗柠檬13 小时前
【Java项目技术亮点】分库分表+数据路由策略:单表5000万后的架构升级方案
java·开发语言·分布式·架构
半夜修仙14 小时前
RabbitMQ中如何保证消息的可靠性传输
java·分布式·中间件·rabbitmq·github·java-rabbitmq
小二·16 小时前
Redis 7 分布式缓存架构实战
redis·分布式·缓存
zhuhai_xigedian17 小时前
源网荷储一体化 vs 传统供用电模式:差异、优势与转型路径
大数据·人工智能·分布式·系统架构·能源
凯源智能18 小时前
屋顶分布式光伏箱变远程测控实战:宝鸡法士特项目高效交付解析
分布式
Amy1870211182319 小时前
东南亚智慧物流园区的“隐形守护者”:有源滤波柜如何驯服变频器5/7次谐波
分布式·能源
闪电悠米20 小时前
黑马点评-Redis 消息队列-04_stream_seckill_order
数据库·redis·分布式·缓存·oracle·junit·lua
HLAIA光子20 小时前
分布式锁与事务:你的微服务可能根本不需要它们
分布式·后端·微服务