栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

RabbitMQ学习(二)—— 代码实战

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
        
        //若没有明教hello_world的队列,则会创建该队列,如果有则不会创建
        channel.queueDeclare("hello_world", true, false, false, null);
        
        //发送消息
        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();
        
        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. 创建交换机
        
        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发送消息时,也必须指定消息的RoutingKeyExchange不再把消息交给每一个绑定的队列,而是根据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. 创建交换机
        
        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. 创建交换机
        
        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();
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/751433.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号