电商项目之订单模块

RabbitMQ

1.使用RabbitMQ的原因

1.异步处理

        我们用来模拟一下注册流程

        (1)我们使用消息队列

                用户注册===》注册信息写入数据库(耗时50ms)===》发送注册邮件(耗时50ms)===》发送注册短信(耗时50ms)

                总体耗时150ms

        (2)我们使用消息队列+异步消息

                                                                                        ===》发送注册邮件(耗时50ms)

        用户注册===》注册信息写入数据库(耗时50ms)

                                                                                        ===》发送注册短信(耗时50ms)

                总体耗时是写入数据库加上后面操作的最长时间(耗时100ms)

        (3)我们使用消息队列+异步消息+消息中间件

        

                                                                                                                          ===》发送注册邮件

        用户注册===》注册信息写入数据库(耗时50ms)===》写入消息队列(耗时5ms)

                                                                                                                          ===》发送注册短信

        只需要发送给消息队列的中间件,就能快速给我一个反馈,后面的由消息中间件慢慢处理

        总体耗时55ms

2.应用解耦

        模拟订单与库存流程

        (1)不使用消息中间件

                订单模块===》库存模块

                只要我们库存模块进行升级,订单模块就要相应的修改

        (2)使用消息中间件

                订单模块===》消息中间件===》库存模块

                订单模块发送消息到消息中间件,库存模块进行订阅消息中间件的消息,自己进行分析,如何消费,如何处理,跟订单模块没有特别大的关系,这样可以解耦合

3.流量控制

        用户请求===》消息队列===》秒杀业务处理

                秒杀场景,大量的用户请求进来,我们将用户请求的信息放到消息中间件里面,快速返回用户请求完成,后续由秒杀业务模块处理,哪怕一秒处理一个消息,也不会造成大量用户请求进来导致宕机。

2.概述

1.大多应用中,可通过消息服务中间件来提升系统异步通信、扩展解耦能力

2.消息服务中两个重要概念

                (1)消息代理:当消息发送者发送消息以后,由消息代理接管,消息代理保证消息传递到指定目的地

                (2)目的地

                      (1)队列:点对点消息通信

                      (2)主题:发布/订阅消息通信

3.消息队列主要有种形式的目的地

        (1)队列:点对点消息通信

        (2)主题:发布、订阅消息通信

4.点对点式

        消息发送者发送消息,消息代理将其放入一个队列中,消息接收者从队列中获取信息内容,消息读取后被移出队列

        消息只有唯一的发送者和接收者,但并不是说只能有一个接收者

5.发布订阅式

        发送者(发布者)发送消息到主题,多个接收者(订阅者)监听(订阅)这个主题,那么就会在消息到达时同时收到消息

6.JMS(Java Message Service)JAVA信息服务

        基于JVM消息代理的规范。ActiveMQ、HornetMQ是JMS实现

7.AMQP(Advanced Message Queuing Protocol)

        高级消息队列协议,也是一个消息代理的规范,兼容JMS

        RabbitMQ是AMQP的实现

3.RabbitMQ官网

        Networking and RabbitMQ — RabbitMQ

4.消息确认机制——可靠抵达

        保证消息不丢失,可靠抵达,可以使用事务消息,性能下降250倍,为此引入确认机制

        (1)消费者(publisher)->服务器(Broker)   confirmCallback        确认模式

        (2)交换机(Exchange)->队列(Queue)     returnCallback        未投递到queue退回模式

        (3)队列(Queue)->消费者(Consumer)                ack机制

        

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值