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

app网站开发哪里有舟山网站建设seo

app网站开发哪里有,舟山网站建设seo,wordpress文件夹分类名称,南阳网站seo报价摘要 本文主要讲解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.yutouwan.com/news/415790/

相关文章:

  • 怎么在自己做的网站上发视频教程WordPress怎么修改根目录
  • 电子商务网站建设第三章答案优秀的国外设计网站
  • 一个专门做标题的网站wordpress主题 贴吧
  • 如何给网站刷流量wordpress商业模板破解
  • 网站开发调研问卷世界最新军事新闻最新消息
  • 网站开发转移合同会所网站建设
  • 域名到期对网站影响不允许做企业网站
  • 百度上公司做网站汕头网站制作怎么做
  • 响应式网站概况html5做网页
  • 辽宁智能网站建设价位.耐思尼克官方网站
  • 外贸公司招聘条件短视频seo优化排名
  • 网站建设与维护课难吗appstore下载安卓版
  • 网站做301跳转的好处深圳建设工程交易
  • 茶叶手机网站胶州市城乡建设局网站截图
  • 永久免费自助建网站北京大学廉政建设研究中心网站
  • 举例描述该如何布局网站关键词推广型网站建设机构
  • word可以做招聘网站吗企业信用信息查询公示系统山东
  • 网站免费php空间申请广东网站建设设计服务
  • 网站建设费计入那个科目射洪网站建设工作室
  • 交友最好的网站建设wordpress微信主页
  • 湖南智能网站建设费用网站建站上市公司
  • 建筑网站architect郑州管城建设网站
  • 石家庄网站建设公司排名中国建设银行悦生活网站
  • php源码项目门户网站开发网店装修的主要内容有哪些
  • 潍坊免费自助建站模板1.网站建设分为哪几个阶段
  • 网站怎样做才会被百度收录天津如何做百度的网站推广
  • 没有网站没有推广如何做外贸石家庄网站制作工具
  • 做房地产需要做网站吗网站结构布局
  • 网站app搭建wordpress登陆背景
  • 国外注册域名的网站免费网站免费网站平台