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

中国建设银行邵阳分行网站广西桂林公司

中国建设银行邵阳分行网站,广西桂林公司,聊城网站开发培训,怎么把别人网站源码弄出来一、什么是可靠消息投递?—— 消息队列的“防丢宝典” 可靠消息投递 是指通过消息队列(如 RocketMQ)确保消息在生产、传输、消费过程中不丢失、不重复、有序到达。其核心目标是在分布式系统中保障数据最终一致性,常用于订单处理、…
一、什么是可靠消息投递?—— 消息队列的“防丢宝典”

可靠消息投递 是指通过消息队列(如 RocketMQ)确保消息在生产、传输、消费过程中不丢失、不重复、有序到达。其核心目标是在分布式系统中保障数据最终一致性,常用于订单处理、支付回调、日志同步等关键业务。

核心角色
生产者(Producer):发送消息的客户端。
消费者(Consumer):接收并处理消息的客户端。
Broker:消息存储和转发的中间服务器(如 RocketMQ 的节点)。
Name Server:存储 Broker 元数据(如路由信息)。

通俗比喻
想象快递公司(RocketMQ)如何保证包裹(消息)安全送达:

  1. 下单(生产者发送消息)→
  2. 分拣中心(Broker 存储)→
  3. 派送(消费者接收)→
  4. 签收反馈(确认消息已处理)。

二、RocketMQ原理:如何实现可靠投递?
1. 核心架构与流程

在这里插入图片描述

2. 关键机制

持久化存储
CommitLog:所有消息顺序写入单一文件,确保顺序性和原子性。
ConsumeQueue:消费者组消费进度记录,支持断点续传。
多副本机制
• Broker 默认同步复制消息到其他节点,防止单点故障。
ACK确认机制
• 消费者拉取消息后发送确认,Broker 删除已确认消息。
重试与死信队列
• 消费失败时自动重试,多次失败后转入死信队列(DLQ)人工处理。

3. 图解:消息投递流程
[生产者] → 发送消息 → [Name Server] → 路由到 Broker → 存入 CommitLog  ↓  [消费者组] ← 拉取消息 ← [Broker]  ↓  [消费者] → 处理消息 → 发送 ACK → [Broker] → 删除消息  

三、适用场景:哪些业务需要可靠消息投递?
  1. 订单创建
    • 扣减库存 → 生成订单 → 发送物流通知。
    • 失败需回滚(如扣款失败则恢复库存)。
  2. 支付回调
    • 支付成功后通知订单服务,需确保通知至少一次。
  3. 日志同步
    • 微服务间异步记录操作日志,保证最终一致性。
  4. 事件驱动架构
    • 用户注册 → 发送欢迎邮件 → 更新用户状态。

反例
实时性要求极高:如股票交易(需毫秒级响应)。
简单请求响应:如HTTP API调用,无需异步解耦。


四、实战:Spring Boot + RocketMQ 快速上手
1. 环境准备

下载 RocketMQ:访问官网下载最新版(以 2.11.0 为例),解压后启动:

# 启动 Name Server
sh bin/mqnamesrv# 启动 Broker(默认端口 9876)
sh bin/mqbroker -n localhost:9876
2. 添加依赖

pom.xml 中添加 RocketMQ 和 Spring Boot 集成依赖:

<dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version>2.11.0</version>
</dependency>
3. 配置文件

application.yml 中配置 RocketMQ 生产者和消费者:

rocketmq:producer:name-server: localhost:9876default-topic: order_topicconsumer:name-server: localhost:9876default-topic: order_topicconsumer-group: order_consumer_group
4. 生产者代码(发送消息)
@Service
public class OrderService {@Autowiredprivate RocketMQTemplate rocketMQTemplate;public void createOrder(Order order) {// 1. 扣减库存(本地事务)inventoryService.deduct(order.getSkuId());// 2. 发送消息到 RocketMQ(异步解耦)rocketMQTemplate.convertAndSend("order_topic", order);}
}
5. 消费者代码(处理消息)
@Service
public class OrderConsumer {@Autowiredprivate OrderDAO orderDAO;@RocketMQListener(topics = "order_topic",consumerGroup = "order_consumer_group")public void listen(Order order) {// 3. 生成订单(本地事务)orderDAO.insert(order);// 4. 发送物流通知(外部服务调用)logisticsService.sendLogistics(order.getId());}
}
6. 测试与验证

正常流程
• 订单创建 → 消息发送 → 订单入库 → 物流通知。
失败场景
• 物流服务宕机 → 消息重试3次后进入DLQ → 运维手动处理。


五、常见问题与解决
1. 消息丢失

问题:Broker宕机导致未持久化消息丢失。
解决方案
启用持久化:配置 storePathCommitLogstorePathConsumeQueue 到磁盘。
多副本:设置 brokerRoleSYNC_MASTER,启用自动同步。

2. 消息重复消费

问题:消费者重启后重复处理旧消息。
解决方案
消费者组:通过 consumer-group 确保每个消息只被一个消费者处理。
Offset管理:RocketMQ 自动记录消费进度,重启后从断点续传。

3. 消息顺序性不一致

问题:高并发下消息乱序到达。
解决方案
顺序消息:设置 messageModel=ORDER,保证同一队列消息有序。
分片处理:将不同业务消息分到不同 Topic。

4. 消息延迟高

问题:网络拥堵或 Broker 负载过高导致消息堆积。
解决方案
批量消费:调整 pullBatchSize 提高吞吐量。
扩容 Broker:增加 Broker 节点分散负载。


六、RocketMQ vs 其他消息队列
对比维度RocketMQKafkaRabbitMQ
核心场景高可靠、顺序消息高吞吐、日志流复杂路由、灵活协议
存储引擎CommitLog + ConsumeQueuePartition + OffsetExchange + Queue
消息顺序支持顺序消息分区有序,跨分区无序严格顺序(通过Exchange)
持久化支持同步/异步持久化支持持久化支持持久化
社区生态中文文档完善,国内常用国际化,云原生支持社区活跃,多语言支持

七、总结与行动建议
  1. 掌握基础:通过示例代码理解生产者-消费者模型和ACK机制。
  2. 生产环境优化
    持久化配置:确保 commitLogconsumeQueue 持久化到磁盘。
    监控报警:通过 RocketMQ 控制台监控消息堆积和消费延迟。
  3. 进阶方向
    事务消息:结合本地事务实现强一致性(如订单扣款+消息发送)。
    延迟消息:实现定时任务(如30分钟后重试失败订单)。
    死信队列:自定义 DLQ 处理策略(如短信通知人工介入)。
  4. 避坑指南
    避免单 Topic:按业务类型分 Topic,防止耦合。
    合理设置重试次数:避免无限重试导致Broker压力过大。

最后思考
RocketMQ 是分布式系统中可靠的“消息管道”,尤其适合需要高一致性和顺序性的场景。对于金融、电商等对数据准确性要求极高的业务,它是不可或缺的中间件。掌握其核心原理和运维技巧,能有效提升系统的高可用性和稳定性。

http://www.dtcms.com/wzjs/805901.html

相关文章:

  • 将电脑做的网站放到外网三合一网站建设什么意思
  • 网站制作的地方游戏加盟公司
  • 免费建设手机网站哪个网站微博做的最好
  • 网站项目设计流程案例简单网站设计网站
  • 基本信息型营销网站有哪些网站优化方式有哪些
  • 求人做网站沈阳网站公司哪个好
  • 网站设计需求表南宫做网站
  • 那个视频网站好网站开发基本要求
  • 快速搭建网站后台网站服务器知识
  • pc端网站布局关于网站开发人员的薪资
  • 推荐网站建设服务器网站菜单实现原理
  • 昆山网站公司哪家好小说类网站程序
  • 魔兽wordpress广东网络seo推广
  • 定制网站制作wordpress加音乐
  • flask做的网站 网址网店运营在哪里学比较好些
  • 前程无忧网深圳网站建设类岗位有一个网站 人物模型可以做各种动作
  • 驻马店网站建设熊掌号图片转链接生成器网站
  • 济南网站制作多少钱组建公司网络方案
  • 上海市企业服务云网站百度网站评价
  • 怎么制作网站布局微信兼职网站开发
  • 健身房网站建设案例外贸网站推广营销
  • 网上注册公司什么网站玛丽与魔女之花网页设计教程
  • 政协门户网站建设英迈寰球网站建设
  • 山西网站建设情况汇总seo推广软件费用
  • 哪个网站有做电箱电柜的图纸各主流网站做景区宣传
  • 丹徒网站建设包括哪些1元域名免备案
  • 网站关键词排名如何提升制作网站网页
  • 网站开发 分类编码电脑上字体怎么到wordpress
  • 建筑业招聘网站西安网站设计开发
  • 做家政建网站wordpress 4.8正式版