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

网站建设项目验收付款厦门市建设执业资格管理中心网站

网站建设项目验收付款,厦门市建设执业资格管理中心网站,贵金属交易平台,asp建站程序摘要 本文主要讲解mall整合RabbitMQ实现延迟消息的过程#xff0c;以发送延迟消息取消超时订单为例。RabbitMQ是一个被广泛使用的开源消息队列。它是轻量级且易于部署的#xff0c;它能支持多种消息协议。RabbitMQ可以部署在分布式和联合配置中#xff0c;以满足高规模、高可…摘要 本文主要讲解mall整合RabbitMQ实现延迟消息的过程以发送延迟消息取消超时订单为例。RabbitMQ是一个被广泛使用的开源消息队列。它是轻量级且易于部署的它能支持多种消息协议。RabbitMQ可以部署在分布式和联合配置中以满足高规模、高可用性的需求。 项目使用框架介绍 RabbitMQ RabbitMQ是一个被广泛使用的开源消息队列。它是轻量级且易于部署的它能支持多种消息协议。RabbitMQ可以部署在分布式和联合配置中以满足高规模、高可用性的需求。 RabbitMQ的安装和使用 安装Erlang下载地址erlang.org/download/ot… 安装RabbitMQ下载地址dl.bintray.com/rabbitmq/al… 安装完成后进入RabbitMQ安装目录下的sbin目录 在地址栏输入cmd并回车启动命令行然后输入以下命令启动管理功能rabbitmq-plugins enable rabbitmq_management 复制代码 访问地址查看是否安装成功http://localhost:15672/ 输入账号密码并登录guest guest 创建帐号并设置其角色为管理员mall mall 创建一个新的虚拟host为/mall 点击mall用户进入用户配置页面 给mall用户配置该虚拟host的权限 至此RabbitMQ的安装和配置完成。RabbitMQ的消息模型 标志中文名英文名描述P生产者Producer消息的发送者可以将消息发送到交换机C消费者Consumer消息的接收者从队列中获取消息进行消费X交换机Exchange接收生产者发送的消息并根据路由键发送给指定队列Q队列Queue存储从交换机发来的消息type交换机类型typedirect表示直接根据路由键orange/black发送消息Lombok Lombok为Java语言添加了非常有趣的附加功能你可以不用再为实体类手写getter,setter等方法通过一个注解即可拥有。 注意需要安装idea的Lombok插件并在项目中的pom文件中添加依赖。 业务场景说明 用于解决用户下单以后订单超时如何取消订单的问题。 用户进行下单操作会有锁定商品库存、使用优惠券、积分一系列的操作生成订单获取订单的id获取到设置的订单超时时间假设设置的为60分钟不支付取消订单按订单超时时间发送一个延迟消息给RabbitMQ让它在订单超时后触发取消订单的操作如果用户没有支付进行取消订单操作释放锁定商品库存、返还优惠券、返回积分一系列操作。整合RabbitMQ实现延迟消息 在pom.xml中添加相关依赖 !--消息队列相关依赖-- dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-amqp/artifactId /dependency !--lombok依赖-- dependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactIdoptionaltrue/optional /dependency 复制代码修改SpringBoot配置文件 修改application.yml文件在spring节点下添加Mongodb相关配置。 rabbitmq:host: localhost # rabbitmq的连接地址port: 5672 # rabbitmq的连接端口号virtual-host: /mall # rabbitmq的虚拟hostusername: mall # rabbitmq的用户名password: mall # rabbitmq的密码publisher-confirms: true #如果对异步消息需要回调必须设置为true 复制代码添加消息队列的枚举配置类QueueEnum 用于延迟消息队列及处理取消订单消息队列的常量定义包括交换机名称、队列名称、路由键名称。 package com.macro.mall.tiny.dto;import lombok.Getter;/*** 消息队列枚举配置* Created by macro on 2018/9/14.*/ Getter public enum QueueEnum {/*** 消息通知队列*/QUEUE_ORDER_CANCEL(mall.order.direct, mall.order.cancel, mall.order.cancel),/*** 消息通知ttl队列*/QUEUE_TTL_ORDER_CANCEL(mall.order.direct.ttl, mall.order.cancel.ttl, mall.order.cancel.ttl);/*** 交换名称*/private String exchange;/*** 队列名称*/private String name;/*** 路由键*/private String routeKey;QueueEnum(String exchange, String name, String routeKey) {this.exchange exchange;this.name name;this.routeKey routeKey;} }复制代码添加RabbitMQ的配置 用于配置交换机、队列及队列与交换机的绑定关系。 package com.macro.mall.tiny.config;import com.macro.mall.tiny.dto.QueueEnum; import org.springframework.amqp.core.*; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;/*** 消息队列配置* Created by macro on 2018/9/14.*/ Configuration public class RabbitMqConfig {/*** 订单消息实际消费队列所绑定的交换机*/BeanDirectExchange orderDirect() {return (DirectExchange) ExchangeBuilder.directExchange(QueueEnum.QUEUE_ORDER_CANCEL.getExchange()).durable(true).build();}/*** 订单延迟队列队列所绑定的交换机*/BeanDirectExchange orderTtlDirect() {return (DirectExchange) ExchangeBuilder.directExchange(QueueEnum.QUEUE_TTL_ORDER_CANCEL.getExchange()).durable(true).build();}/*** 订单实际消费队列*/Beanpublic Queue orderQueue() {return new Queue(QueueEnum.QUEUE_ORDER_CANCEL.getName());}/*** 订单延迟队列死信队列*/Beanpublic Queue orderTtlQueue() {return QueueBuilder.durable(QueueEnum.QUEUE_TTL_ORDER_CANCEL.getName()).withArgument(x-dead-letter-exchange, QueueEnum.QUEUE_ORDER_CANCEL.getExchange())//到期后转发的交换机.withArgument(x-dead-letter-routing-key, QueueEnum.QUEUE_ORDER_CANCEL.getRouteKey())//到期后转发的路由键.build();}/*** 将订单队列绑定到交换机*/BeanBinding orderBinding(DirectExchange orderDirect,Queue orderQueue){return BindingBuilder.bind(orderQueue).to(orderDirect).with(QueueEnum.QUEUE_ORDER_CANCEL.getRouteKey());}/*** 将订单延迟队列绑定到交换机*/BeanBinding orderTtlBinding(DirectExchange orderTtlDirect,Queue orderTtlQueue){return BindingBuilder.bind(orderTtlQueue).to(orderTtlDirect).with(QueueEnum.QUEUE_TTL_ORDER_CANCEL.getRouteKey());}} 复制代码在RabbitMQ管理页面可以看到以下交换机和队列 交换机及队列说明 mall.order.direct取消订单消息队列所绑定的交换机:绑定的队列为mall.order.cancel一旦有消息以mall.order.cancel为路由键发过来会发送到此队列。mall.order.direct.ttl订单延迟消息队列所绑定的交换机:绑定的队列为mall.order.cancel.ttl一旦有消息以mall.order.cancel.ttl为路由键发送过来会转发到此队列并在此队列保存一定时间等到超时后会自动将消息发送到mall.order.cancel取消订单消息消费队列。添加延迟消息的发送者CancelOrderSender 用于向订单延迟消息队列mall.order.cancel.ttl里发送消息。 package com.macro.mall.tiny.component;import com.macro.mall.tiny.dto.QueueEnum; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.amqp.AmqpException; import org.springframework.amqp.core.AmqpTemplate; import org.springframework.amqp.core.Message; import org.springframework.amqp.core.MessagePostProcessor; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component;/*** 取消订单消息的发出者* Created by macro on 2018/9/14.*/ Component public class CancelOrderSender {private static Logger LOGGER LoggerFactory.getLogger(CancelOrderSender.class);Autowiredprivate AmqpTemplate amqpTemplate;public void sendMessage(Long orderId,final long delayTimes){//给延迟队列发送消息amqpTemplate.convertAndSend(QueueEnum.QUEUE_TTL_ORDER_CANCEL.getExchange(), QueueEnum.QUEUE_TTL_ORDER_CANCEL.getRouteKey(), orderId, new MessagePostProcessor() {Overridepublic Message postProcessMessage(Message message) throws AmqpException {//给消息设置延迟毫秒值message.getMessageProperties().setExpiration(String.valueOf(delayTimes));return message;}});LOGGER.info(send delay message orderId:{},orderId);} }复制代码添加取消订单消息的接收者CancelOrderReceiver 用于从取消订单的消息队列mall.order.cancel里接收消息。 package com.macro.mall.tiny.component;import com.macro.mall.tiny.service.OmsPortalOrderService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.amqp.rabbit.annotation.RabbitHandler; import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component;/*** 取消订单消息的处理者* Created by macro on 2018/9/14.*/ Component RabbitListener(queues mall.order.cancel) public class CancelOrderReceiver {private static Logger LOGGER LoggerFactory.getLogger(CancelOrderReceiver.class);Autowiredprivate OmsPortalOrderService portalOrderService;RabbitHandlerpublic void handle(Long orderId){LOGGER.info(receive delay message orderId:{},orderId);portalOrderService.cancelOrder(orderId);} }复制代码添加OmsPortalOrderService接口 package com.macro.mall.tiny.service;import com.macro.mall.tiny.common.api.CommonResult; import com.macro.mall.tiny.dto.OrderParam; import org.springframework.transaction.annotation.Transactional;/*** 前台订单管理Service* Created by macro on 2018/8/30.*/ public interface OmsPortalOrderService {/*** 根据提交信息生成订单*/TransactionalCommonResult generateOrder(OrderParam orderParam);/*** 取消单个超时订单*/Transactionalvoid cancelOrder(Long orderId); }复制代码添加OmsPortalOrderService的实现类OmsPortalOrderServiceImpl package com.macro.mall.tiny.service.impl;import com.macro.mall.tiny.common.api.CommonResult; import com.macro.mall.tiny.component.CancelOrderSender; import com.macro.mall.tiny.dto.OrderParam; import com.macro.mall.tiny.service.OmsPortalOrderService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service;/*** 前台订单管理Service* Created by macro on 2018/8/30.*/ Service public class OmsPortalOrderServiceImpl implements OmsPortalOrderService {private static Logger LOGGER LoggerFactory.getLogger(OmsPortalOrderServiceImpl.class);Autowiredprivate CancelOrderSender cancelOrderSender;Overridepublic CommonResult generateOrder(OrderParam orderParam) {//todo 执行一系类下单操作具体参考mall项目LOGGER.info(process generateOrder);//下单完成后开启一个延迟消息用于当用户没有付款时取消订单orderId应该在下单后生成sendDelayMessageCancelOrder(11L);return CommonResult.success(null, 下单成功);}Overridepublic void cancelOrder(Long orderId) {//todo 执行一系类取消订单操作具体参考mall项目LOGGER.info(process cancelOrder orderId:{},orderId);}private void sendDelayMessageCancelOrder(Long orderId) {//获取订单超时时间假设为60分钟long delayTimes 30 * 1000;//发送延迟消息cancelOrderSender.sendMessage(orderId, delayTimes);}}复制代码添加OmsPortalOrderController定义接口 package com.macro.mall.tiny.controller;import com.macro.mall.tiny.dto.OrderParam; import com.macro.mall.tiny.service.OmsPortalOrderService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.ResponseBody;/*** 订单管理Controller* Created by macro on 2018/8/30.*/ Controller Api(tags OmsPortalOrderController, description 订单管理) RequestMapping(/order) public class OmsPortalOrderController {Autowiredprivate OmsPortalOrderService portalOrderService;ApiOperation(根据购物车信息生成订单)RequestMapping(value /generateOrder, method RequestMethod.POST)ResponseBodypublic Object generateOrder(RequestBody OrderParam orderParam) {return portalOrderService.generateOrder(orderParam);} }复制代码进行接口测试 调用下单接口 注意已经将延迟消息时间设置为30秒 项目源码地址 github.com/macrozheng/… 公众号 mall项目全套学习教程连载中关注公众号第一时间获取。 转载于:https://juejin.im/post/5cff98986fb9a07ed36ea139
http://www.zqtcl.cn/news/813826/

相关文章:

  • 月熊志网站福州建网站 做网页
  • 不同的网站有不同的风格宁波设计网站公司
  • 学校网站制作平台电子政务门户网站建设代码
  • 产品推广的网站怎么做网站标题与关键词
  • 青蛙网站建设wordpress修改logo
  • 网站套餐方案引擎搜索对人类记忆的影响
  • 滨州市滨城区建设局网站扎金花网站怎么做
  • 网站开发中视屏怎样编辑到网页上常州建站公司模板
  • 视频涉台互联网网站怎么做1cpu0.5g服务器用来做网站
  • 营销型网站设计官网怎么做网站优化 sit
  • 怎样获得做网站的客户免费企业网站程序上传
  • 新闻排版设计用什么软件网站seo诊断分析
  • 手机网站端域名怎样做解析一诺摄影设计
  • 网站开发行业竞争大吗郑州百度推广代运营公司
  • mvc4做网站五设计一个公司网站多少钱
  • 在什么网站可以做外贸出口劳保鞋北京 代理前置审批 网站备案
  • 邢台建设企业网站房地产宣传推广方案
  • 建设机械网站案例分析餐饮vi设计开题报告范文
  • 做本地生活网站深圳建设工程信息网站
  • C2C电商网站做博客的网站有哪些
  • 住房和城乡建设部网站 事故安微省建设厅田网站
  • 百度一下你就知道官页淘宝seo搜索引擎优化
  • 网站平台维护phpwind做的网站
  • 网站怎么做移动适配怎么样才算是一个网站页面
  • 做pc端网站策划百度网站建立
  • 高级网站开发技术青岛网站建设方案服务
  • 深圳公司网站建设设房地产网址大全
  • 怎么里ip做网站女生学广告学后悔死了
  • 做西餐网站wordpress 作者栏
  • 创建了网站安卓做视频网站