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

免费企业网站报价php 创建网站开发

免费企业网站报价,php 创建网站开发,网站空间报价单,大数据和网站建设📋目录 🎯 RabbitMQ基础概念 什么是RabbitMQ? 核心概念详解 1. 队列(Queue) 2. 交换机(Exchange) 3. 绑定(Binding) 🛠️ 环境搭建 1. 安装RabbitMQ Windows安装 Docker安装(推荐) 2. 访问管理界面 🚀 SpringBoot集成RabbitMQ 1. 添加依赖 2. 配…

📋目录

🎯 RabbitMQ基础概念

什么是RabbitMQ?

核心概念详解

1. 队列(Queue)

2. 交换机(Exchange)

3. 绑定(Binding)

🛠️ 环境搭建

1. 安装RabbitMQ

Windows安装

Docker安装(推荐)

2. 访问管理界面

🚀 SpringBoot集成RabbitMQ

1. 添加依赖

2. 配置文件

⚙️ 基础配置

1. RabbitMQ配置类

📨 简单队列模式

1. 队列配置

2. 生产者

3. 消费者

👥 工作队列模式

1. 配置类

2. 生产者

3. 消费者

📡 发布订阅模式

1. 配置类

2. 生产者

3. 消费者

🎯 路由模式

1. 配置类

2. 生产者

3. 消费者

🏷️ 主题模式

1. 配置类

2. 生产者

3. 消费者

✅ 消息确认机制

1. 生产者确认

2. 消费者确认

💼 实际项目应用

1. 订单处理系统

2. 延迟队列实现

🔧 常见问题解决

1. 消息丢失问题

2. 消息重复消费问题

3. 性能优化

4. 监控和日志

📚 总结

使用建议

最佳实践


🎯 RabbitMQ基础概念

什么是RabbitMQ?

RabbitMQ是一个开源的消息队列中间件,就像一个邮局一样:

  • 生产者(Producer):发送邮件的人
  • 队列(Queue):邮箱,存放邮件的地方
  • 消费者(Consumer):收邮件的人
  • 交换机(Exchange):邮局的分拣中心,决定邮件发到哪个邮箱

核心概念详解

1. 队列(Queue)
队列就像一个容器,消息在这里排队等待被处理
[消息1] [消息2] [消息3] → 消费者取走处理
2. 交换机(Exchange)

交换机有4种类型:

  • Direct(直连):根据路由键精确匹配
  • Fanout(扇出):广播到所有绑定的队列
  • Topic(主题):根据路由键模式匹配
  • Headers:根据消息头匹配(较少使用)
3. 绑定(Binding)

绑定是交换机和队列之间的连接规则


🛠️ 环境搭建

1. 安装RabbitMQ

Windows安装
# 使用Chocolatey安装
choco install rabbitmq# 启动RabbitMQ服务
rabbitmq-server
Docker安装(推荐)
# 拉取并运行RabbitMQ容器
docker run -d --name rabbitmq \-p 5672:5672 \-p 15672:15672 \-e RABBITMQ_DEFAULT_USER=admin \-e RABBITMQ_DEFAULT_PASS=123456 \rabbitmq:3-management

2. 访问管理界面

  • 地址:http://localhost:15672
  • 用户名:admin
  • 密码:123456

🚀 SpringBoot集成RabbitMQ

1. 添加依赖

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>
</dependencies>

2. 配置文件

# application.yml
spring:rabbitmq:host: localhostport: 5672username: adminpassword: 123456virtual-host: /# 发送者开启确认模式publisher-confirms: true# 发送者开启return确认机制publisher-returns: true# 设置消费者手动确认listener:simple:acknowledge-mode: manual# 限制每次只处理一个消息prefetch: 1

⚙️ 基础配置

1. RabbitMQ配置类

@Configuration
@EnableRabbit
public class RabbitConfig {/*** 创建RabbitTemplate,用于发送消息*/@Beanpublic RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {RabbitTemplate template = new RabbitTemplate(connectionFactory);// 设置消息转换器(可选)template.setMessageConverter(new Jackson2JsonMessageConverter());// 设置发送确认回调template.setConfirmCallback((correlationData, ack, cause) -> {if (ack) {System.out.println("消息发送成功");} else {System.out.println("消息发送失败:" + cause);}});return template;}
}

📨 简单队列模式

这是最基本的模式:一个生产者发送消息到队列,一个消费者接收消息。

1. 队列配置

@Configuration
public class SimpleQueueConfig {public static final String SIMPLE_QUEUE = "simple.queue";/*** 声明简单队列*/@Beanpublic Queue simpleQueue() {return QueueBuilder.durable(SIMPLE_QUEUE).build();}
}

2. 生产者

@RestController
@RequestMapping("/simple")
public class SimpleProducer {@Autowiredprivate RabbitTemplate rabbitTemplate;@PostMapping("/send")public String sendMessage(@RequestParam String message) {// 发送消息到队列rabbitTemplate.convertAndSend(SimpleQueueConfig.SIMPLE_QUEUE, message);return "消息发送成功:" + message;}
}

3. 消费者

@Component
public class SimpleConsumer {/*** 监听简单队列*/@RabbitListener(queues = SimpleQueueConfig.SIMPLE_QUEUE)public void receiveMessage(String message, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag) {try {System.out.println("接收到消息:" + message);// 模拟业务处理Thread.sleep(1000);// 手动确认消息channel.basicAck(deliveryTag, false);} catch (Exception e) {try {// 处理失败,拒绝消息并重新入队channel.basicNack(deliveryTag, false, true);} catch (IOException ex) {ex.printStackTrace();}}}
}

👥 工作队列模式

多个消费者共同处理一个队列中的消息,实现任务分发。

1. 配置类

@Configuration
public class WorkQueueConfig {public static final String WORK_QUEUE = "work.queue";@Beanpublic Queue workQueue() {return QueueBuilder.durable(WORK_QUEUE).build();}
}

2. 生产者

@RestController
@RequestMapping("/work")
public class WorkProducer {@Autowiredprivate RabbitTemplate rabbitTemplate;@PostMapping("/send")public String sendWork(@RequestParam String task) {for (int i = 1; i <= 10; i++) {String message = task + " - 任务" + i;rabbitTemplate.convertAndSend(WorkQueueConfig.WORK_QUEUE, message);}return "批量任务发送完成";}
}

3. 消费者

@Component
public class WorkConsumer {/*** 工作者1*/@RabbitListener(queues = WorkQueueConfig.WORK_QUEUE)public void worker1(String message, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag) {try {System.out.println("工作者1处理:" + message);Thread.sleep(2000); // 模拟较慢的处理channel.basicAck(deliveryTag, false);} catch (Exception e) {handleError(channel, deliveryTag);}}
http://www.dtcms.com/wzjs/557762.html

相关文章:

  • php网站导航微信网站是怎么做的
  • 新产品营销策划网站关键词优化wang
  • 适合新手模仿的网站网站投放广告教程
  • 网站流程表注册电子邮箱免费注册
  • 网站后台怎么控制自己建网站 知乎
  • 仿wordpress主题深圳网络seo优化
  • 模板网站优服务器网络配置
  • 公共资源中心网站建设ol游戏大全排行榜
  • 网站卖了对方做违法吗昆明seo博客南网站建设
  • 怎么做卖车网站广告产品
  • 建设保障房网站首页贵司不断优化网站建设
  • 网站 建设 欢迎你wordpress 去掉发布者
  • 120平办公室装修设计自动app优化下载
  • 手表网站有哪个比较好全国住房城乡建设厅网站
  • php网站后台怎么进慧聪网的网站建设策略
  • 网站技术支持什么意思西安北郊做网站
  • 建设网站基本步骤网站建设哪家好首推万维科技
  • 总结网站推广策划思路的内容重庆公章备案查询网站
  • 行情网免费网站大全活动推广
  • 俄文网站策划石家庄网络公司排名
  • 宁波网站推广制作公司多语言网站如何做
  • 有没有专业做二手老车的网站网站换服务器
  • 星巴克网站建设方案0453牡丹江信息网二手房买卖
  • 营销网站如何建设静态网站没有后台
  • 网站开发说明书如何做网站 写代码
  • 怎么用手机做网站教程烟台网站建站
  • 顺德网站优化做空包网站合法吗
  • 郑州网站设计汉狮网络wordpress怎么实现注册登录
  • 网站做留言板百度ai开放平台
  • 专业做网站开发重庆企业免费建站