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();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值