IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> RabbitMQ学习(二)—— 代码实战 -> 正文阅读

[Java知识库]RabbitMQ学习(二)—— 代码实战

1.1Work queues工作队列模式

1.1.1 入门程序

完成简单模式的消息传递

生产者代码:

//1.创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //2.设置参数
        factory.setHost("172.155.10.100");
        factory.setPort(5672);
        factory.setVirtualHost("/study");
        factory.setUsername("admin");
        factory.setPassword("admin");
        //3. 创建连接Connection
        Connection connection = factory.newConnection();
        //4. 创建channel
        Channel channel = connection.createChannel();
        //5. 创建队列 queue
        /**
         * 参数
         * queue: 队列名称
         * durable:是否持久化
         * exclusive:是否独占,只能有一个消费者监听这队列
         *            当Connection关闭时,是否删除队列
         * autoDelete:是否自动删除,当没有Consumer时,自动删除掉
         */
        //若没有明教hello_world的队列,则会创建该队列,如果有则不会创建
        channel.queueDeclare("hello_world", true, false, false, null);
        /**
         * exchange: 交换机名称,简单模式下交换机默认使用 “”
         * routingKey:路由名称
         * props:配置信息
         * body: 发送消息数据
         */
        //发送消息
        channel.basicPublish("", "hello_world", null, message.getBytes());
        channel.close();
        connection.close();

消费者代码:

//1.创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //2.设置参数
        factory.setHost("172.155.10.100");
        factory.setPort(5672);
        factory.setVirtualHost("/study");
        factory.setUsername("admin");
        factory.setPassword("admin");
        //3. 创建连接Connection
        Connection connection = factory.newConnection();
        //4. 创建channel
        Channel channel = connection.createChannel();
        /**
         * basicConsume(String name, boolean autoAck, Consumer, callback
         * queue: 队名称
         * autoAck: 是否自动确认
         * callback:回调对象
         */
        com.rabbitmq.client.Consumer consumer = new DefaultConsumer(channel) {
            
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body){
                System.out.println("需要打印的东东");
            }
        };
        channel.basicConsume("hello_world", true, consumer);

1.1.2 工作模式

在这里插入图片描述

  • Work Queues:与入门程序的简单模式相比,多了一个或一些消费端,多个消费端共同消费
  • 应用场景: 对于任务过重或任务较多情况使用工作队列可以提高任务处理的速度
    代码即拷贝一份消费者,两个消费者同时消费队列中的消息,相互之间并不影响,即同一份数据可以同时被C1和C2消费

1.1.3 PUB/Sub订阅模式

在这里插入图片描述
订阅模型中,多了一个Exchange角色,而且过程略有变化

  • P:生产者,不再发送到队列中,而是发送给交换机
  • C:消费者,消息的接收者,会一直等待消息到来
  • Exchange:只负责转发消息,不具备存储消息的功能,因此如果没有任何队列与Exchange绑定,或者没有路由规则的队列,那么消息会丢失

生产者代码:

//1.创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //2.设置参数
        factory.setHost("172.155.10.100");
        factory.setPort(5672);
        factory.setVirtualHost("/study");
        factory.setUsername("admin");
        factory.setPassword("admin");
        //3. 创建连接Connection
        Connection connection = factory.newConnection();
        //4. 创建channel
        Channel channel = connection.createChannel();
        //5. 创建交换机
        /**
         * exchange: 
         * type:交换机类型
         * durable:是否车九华
         * autoDelete: 发送消息数据
         * internal: 是否内部使用 一般false
         * argument:参数
         */
        String exchangeName = "test_fanout";
        channel.exchangeDeclare(exchangeName, BuiltinExchangeType.FANOUT, true, true, false, null);
        //6. 创建队列
        channel.queueDeclare("testQueue1", true, false, false, null);
        //7. 绑定队列和交换机  第一个参数队列名称,第二个交换机名称,第三个为路由规则
        channel.queueBind("testQueue1", exchangeName, "");
        channel.basicPublish("", "hello_world", null, message.getBytes());
        
        channel.close();
        connection.close();

消费者代码基本一致

1.1.4 Routing路由模式

  • 队列与交换机的绑定,不能是任意绑定了,而是要指定一个RoutingKey
  • 消息的发送方再向Exchange发送消息时,也必须指定消息的RoutingKey
  • Exchange不再把消息交给每一个绑定的队列,而是根据RoutingKey进行判断,只有队列RoutingKey鱼消息的RoutingKey完全一直,才会接受到消息
    在这里插入图片描述
    生产者代码:
//1.创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //2.设置参数
        factory.setHost("172.155.10.100");
        factory.setPort(5672);
        factory.setVirtualHost("/study");
        factory.setUsername("admin");
        factory.setPassword("admin");
        //3. 创建连接Connection
        Connection connection = factory.newConnection();
        //4. 创建channel
        Channel channel = connection.createChannel();
        //5. 创建交换机
        /**
         * exchange: 
         * type:交换机类型
         * durable:是否车九华
         * autoDelete: 发送消息数据
         * internal: 是否内部使用 一般false
         * argument:参数
         */
        String exchangeName = "test_direct";
        channel.exchangeDeclare(exchangeName, BuiltinExchangeType.DIRECT, true, true, false, null);
        //6. 创建队列
        String queue1Name = "test_direct_queue1";
        String queue2Name = "test_direct_queue2";
        channel.queueDeclare(queue1Name, true, false, false, null);
        channel.queueDeclare(queue2Name, true, false, false, null);
        //7. 绑定队列和交换机  第一个参数队列名称,第二个交换机名称,第三个为路由规则
        channel.queueBind(queue1Name, exchangeName, "error");
        
        channel.queueBind(queue2Name, exchangeName, "info");
        channel.queueBind(queue2Name, exchangeName, "warn");
        channel.queueBind(queue2Name, exchangeName, "error");
        channel.basicPublish(exchangeName, "hello_world", null, message.getBytes());
        
        channel.close();
        connection.close();

1.1.4 Topics通配符模式

在这里插入图片描述
*代表一个单词,#代表0个或多个单词
生产者代码“

//1.创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //2.设置参数
        factory.setHost("172.155.10.100");
        factory.setPort(5672);
        factory.setVirtualHost("/study");
        factory.setUsername("admin");
        factory.setPassword("admin");
        //3. 创建连接Connection
        Connection connection = factory.newConnection();
        //4. 创建channel
        Channel channel = connection.createChannel();
        //5. 创建交换机
        /**
         * exchange: 
         * type:交换机类型
         * durable:是否车九华
         * autoDelete: 发送消息数据
         * internal: 是否内部使用 一般false
         * argument:参数
         */
        String exchangeName = "test_topic";
        channel.exchangeDeclare(exchangeName, BuiltinExchangeType.TOPIC, true, true, false, null);
        //6. 创建队列
        String queue1Name = "test_topic_queue1";
        String queue2Name = "test_topic_queue2";
        channel.queueDeclare(queue1Name, true, false, false, null);
        channel.queueDeclare(queue2Name, true, false, false, null);
        //7. 绑定队列和交换机  第一个参数队列名称,第二个交换机名称,第三个为路由规则
        channel.queueBind(queue1Name, exchangeName, "#.error");
        channel.queueBind(queue2Name, exchangeName, "order.*");
        channel.queueBind(queue2Name, exchangeName, "*.*");
        channel.basicPublish(exchangeName, "hello_world", null, message.getBytes());
        
        channel.close();
        connection.close();
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-03-04 15:22:29  更:2022-03-04 15:26:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 11:33:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码