当前位置: 首页 > news >正文

营销网站建站公司个人做多个网站备案

营销网站建站公司,个人做多个网站备案,廊坊网站制作网页,天津网站建设教程实现思路 使用扇出交换机#xff08;Fanout Exchange#xff09;#xff1a;扇出交换机会将消息广播到所有绑定的队列#xff0c;确保每个消费者组都能接收到相同的消息。为每个消费者组创建独立的队列#xff1a;每个消费者组拥有自己的队列#xff0c;所有属于该组的消…实现思路 使用扇出交换机Fanout Exchange扇出交换机会将消息广播到所有绑定的队列确保每个消费者组都能接收到相同的消息。为每个消费者组创建独立的队列每个消费者组拥有自己的队列所有属于该组的消费者都订阅这个队列。确保同一组内的消费者竞争消费RabbitMQ 会将消息推送给组内第一个可用的消费者确保同一消息不会被同一组中的多个消费者处理。 示例场景 假设我们有两个消费者组GroupA 和 GroupB。我们希望发送的消息能够同时被 GroupA 和 GroupB 消费但每个组内的多个消费者只会有一个成员消费该消息。 Spring Boot RabbitMQ 广播式分组消费示例 1. 引入依赖 首先在 pom.xml 中添加 RabbitMQ 和 Spring AMQP 的依赖 dependencies!-- Spring Boot Starter for RabbitMQ --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-amqp/artifactId/dependency!-- 其他依赖... -- /dependencies 2. 配置 RabbitMQ 交换机和队列 在 application.yml 中配置 RabbitMQ 的交换机、队列和绑定关系。使用 fanout 交换机并为每个消费者组创建一个独立的队列。 spring:rabbitmq:host: localhostport: 5672username: guestpassword: guest# RabbitMQ 配置rabbitmq:listener:simple:acknowledge-mode: manual # 手动确认消息concurrency: 5 # 每个队列的并发消费者数量max-concurrency: 10 # 最大并发消费者数量# 自定义队列和交换机配置rabbitmq:queues:group-a-queue:name: group_a_queuedurable: truegroup-b-queue:name: group_b_queuedurable: trueexchanges:fanout-exchange:name: fanout_exchangetype: fanoutdurable: truebindings:group-a-binding:exchange: fanout_exchangequeue: group_a_queuegroup-b-binding:exchange: fanout_exchangequeue: group_b_queue 3. 创建 RabbitMQ 配置类 创建一个配置类来声明交换机、队列和绑定关系。Spring AMQP 会自动根据配置创建这些资源。 import org.springframework.amqp.core.Binding; import org.springframework.amqp.core.BindingBuilder; import org.springframework.amqp.core.FanoutExchange; import org.springframework.amqp.core.Queue; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;Configuration public class RabbitMQConfig {// 定义扇出交换机Beanpublic FanoutExchange fanoutExchange() {return new FanoutExchange(fanout_exchange, true, false);}// 定义 Group A 队列Beanpublic Queue groupAQueue() {return new Queue(group_a_queue, true);}// 定义 Group B 队列Beanpublic Queue groupBQueue() {return new Queue(group_b_queue, true);}// 绑定 Group A 队列到扇出交换机Beanpublic Binding groupABinding(Queue groupAQueue, FanoutExchange fanoutExchange) {return BindingBuilder.bind(groupAQueue).to(fanoutExchange);}// 绑定 Group B 队列到扇出交换机Beanpublic Binding groupBBinding(Queue groupBQueue, FanoutExchange fanoutExchange) {return BindingBuilder.bind(groupBQueue).to(fanoutExchange);} } 4. 发送消息 创建一个服务类来发送消息到扇出交换机。由于 fanout 交换机不使用路由键它会将消息广播到所有绑定的队列。 import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service;Service public class MessageProducer {private final RabbitTemplate rabbitTemplate;Autowiredpublic MessageProducer(RabbitTemplate rabbitTemplate) {this.rabbitTemplate rabbitTemplate;}// 发送消息到扇出交换机public void sendMessage(String message) {System.out.println(Sending message: message);rabbitTemplate.convertAndSend(fanout_exchange, , message);} } 5. 创建消费者 为每个消费者组创建单独的消费者类。每个消费者组内的多个消费者会竞争性地从队列中消费消息。使用 RabbitListener 注解来监听队列中的消息。 Group A 消费者 import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component;Component public class GroupAConsumer {RabbitListener(queues group_a_queue)public void consumeMessage(String message) {System.out.println(Group A consumer received: message);// 处理 Group A 的逻辑} } Group B 消费者 import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component;Component public class GroupBConsumer {RabbitListener(queues group_b_queue)public void consumeMessage(String message) {System.out.println(Group B consumer received: message);// 处理 Group B 的逻辑} } 6. 启动应用程序并测试 启动 Spring Boot 应用程序后GroupAConsumer 和 GroupBConsumer 会分别监听 group_a_queue 和 group_b_queue。通过以下方式测试消息的发送和消费 import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.CommandLineRunner; import org.springframework.stereotype.Component;Component public class TestRunner implements CommandLineRunner {private final MessageProducer messageProducer;Autowiredpublic TestRunner(MessageProducer messageProducer) {this.messageProducer messageProducer;}Overridepublic void run(String... args) throws Exception {// 发送一条消息messageProducer.sendMessage(This is a broadcast message);} } 7. 运行结果 当你启动应用程序时TestRunner 会发送一条消息到 fanout_exchange。由于 fanout 交换机会将消息广播到所有绑定的队列因此 group_a_queue 和 group_b_queue 都会接收到这条消息。
http://www.dnsts.com.cn/news/10985.html

相关文章:

  • 古镇网站建设制作wordpress 4 xmlrpc
  • 网站怎么做seo_郴州网站建设公司哪个好
  • 长沙网站建设及推广公司福永网站设计
  • 网站建设及seo做画册去什么网站找素材
  • 钟表 东莞网站建设深圳广告公司
  • 手机改ip地址软件免费seo怎么做最佳
  • 科技公司网站推荐网站开发实训要求
  • 重庆网站建设的价格低西安便宜的网站建设
  • 虚拟主机有哪些搜索引擎优化哪些方面
  • 自动搭建网站源码wordpress登录栏
  • 墨星写作网站网络营销文案创作思路有哪些
  • 网站登录界面源码WordPress预览出错
  • 电子商务网站 整站 psd企业网站建设的重要性及意义
  • 电子商务网站建设内容软件程序流程图
  • icp备案网站接入信息ip地址段如何建立公司网站?
  • 个人空间网站建设报告南宁电子商务网站建设
  • 专业的响应式网站建设网站内页怎么做
  • 找个做网站的杭州高端网站设计公司
  • 如何提高网站收录量做网站获流量
  • 北京微网站制作做电子商务网站的意义
  • 制作一个网站的步骤是什么网站程上传
  • 网站建设 响应式 北京空间设计主要做什么
  • asp网站做视频教程图文识别类微信小程序是什么
  • 百姓网网站开发的意义苏州百度推广
  • 重庆免费微网站建设免费的网站平台有哪些
  • 佛山网站建设及优化公司专业做俄语网站建设
  • 网站建设论坛wordpress get_posts
  • 大连开发区网站开发公司wordpress拖拽建站
  • 2021网站建设前景怎么样中国建造师网官网登录入口
  • 苏州网站建设公司科技城wordpress cms 下载