《RabbitMQ系列教程-第四章-02-RabbitMQ工作模式之Work模式》_rabbit 创建一个work模式的bean

    // 3.创建频道
    Channel channel = connection.createChannel();

    // 4.创建队列
    channel.queueDeclare("work\_queues", true, false, false, null);

    //5. 循环发送10条消息到work\_queues队列
    for (int i = 1; i <= 10; i++) {
        String body = "hello" + i;
        channel.basicPublish("", "work\_queues", null, body.getBytes());
    }

    //6.释放资源
    channel.close();
    connection.close();
}

}


#### 4.2.3 消费者1



package com.lscl.rabbitmq;

import com.rabbitmq.client.*;
import java.io.IOException;

public class Consumer02_WorkQueues {

public static void main(String[] args) throws Exception{
    // 创建连接工厂,用于获取频道channel
    ConnectionFactory factory=new ConnectionFactory();

    factory.setHost("192.168.40.132");
    factory.setPort(5672);
    factory.setUsername("lscl");
    factory.setPassword("admin");
    factory.setVirtualHost("/lscl");

    // 2.创建连接
    Connection connection = factory.newConnection();

    // 3.创建频道
    Channel channel = connection.createChannel();

    // 4.创建队列
    channel.queueDeclare("work\_queues",true,false,false,null);

    // 5. 接收消息
    channel.basicConsume("work\_queues", true, new DefaultConsumer(channel){

        // 回调方法,当收到消息之后,会自动执行该方法
        public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {

            System.out.println("body:"+new String(body));
        }
    });
    // 不释放资源,让rabbitmq一直监听
}

}


#### 4.2.4 消费者2


![在这里插入图片描述](https://img-blog.csdnimg.cn/20210104161517666.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0JiMTUwNzAwNDc3NDg=,size_16,color_FFFFFF,t_70#pic_center)


运行后在控制台可以看到多个窗口


![在这里插入图片描述](https://img-blog.csdnimg.cn/20210104161527386.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0JiMTUwNzAwNDc3NDg=,size_16,color_FFFFFF,t_70#pic_center)


#### 4.2.5 rabbitmq负载均衡


当rabbitmq存在有多个Consumer时,会自动采用轮询方式实现消息的负载均衡,将消息分担到不同的Consumer进行消费  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20210104161534107.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0JiMTUwNzAwNDc3NDg=,size_16,color_FFFFFF,t_70#pic_center)


#### 4.2.6 Work模式小结


Work模式与上一节所学的Simple模式在代码上看来是一模一样的,只不过RabbitMQ官方为了区别一个消费者和多个消费者监听同一个队列提出了Simple和Work不同的两种模式;




---


下一篇:[《RabbitMQ系列教程-第四章-03-RabbitMQ工作模式之Pub/Sub发布订阅模式》](https://bbs.csdn.net/topics/618540462)




---








### 给大家的福利


**零基础入门**


对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。


![](https://img-blog.csdnimg.cn/img_convert/95608e9062782d28f4f04f821405d99a.png)


同时每个成长路线对应的板块都有配套的视频提供:


![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a91b9e8100834e9291cfcf1695d8cd42.png#pic_center)


因篇幅有限,仅展示部分资料


网络安全面试题


![](https://img-blog.csdnimg.cn/img_convert/80674985176a4889f7bb130756893764.png)


绿盟护网行动


![](https://img-blog.csdnimg.cn/img_convert/9f3395407120bb0e1b5bf17bb6b6c743.png)


还有大家最喜欢的黑客技术


![](https://img-blog.csdnimg.cn/img_convert/5912337446dee53639406fead3d3f03c.jpeg)


**网络安全源码合集+工具包**


![](https://img-blog.csdnimg.cn/img_convert/5072ce807750c7ec721c2501c29cb7d5.png)


![](https://img-blog.csdnimg.cn/img_convert/4a5f4281817dc4613353c120c9543810.png)

**所有资料共282G**,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/topics/618540462)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值