1 基础预览

  • 1.1 环境准备
Springboot    1.5.6.RELEAS
Springcloud Dalston.SR2
  • 1.2 交换机类型

交换机是用来发送消息的AMQP实体。交换机拿到一个消息之后将它路由给一个或零个队列。它使用哪种路由算法是由交换机类型和被称作绑定(bindings)的规则所决定的。AMQP 0-9-1的代理提供了四种交换机

Name(交换机类型) Default pre-declared names(预声明的默认名称) 
Direct exchange(直连交换机) (Empty string) and amq.direct 
Fanout exchange(扇型交换机) amq.fanout 
Topic exchange(主题交换机) amq.topic 
Headers exchange(头交换机) amq.match (and amq.headers in RabbitMQ)

  • 1.3 绑定

绑定(Binding)是交换机(exchange)将消息(message)路由给队列(queue)所需遵循的规则。如果要指示交换机“E”将消息路由给队列“Q”,那么“Q”就需要与“E”进行绑定。绑定操作需要定义一个可选的路由键(routing key)属性给某些类型的交换机。路由键的意义在于从发送给交换机的众多消息中选择出某些消息,将其路由给绑定的队列。

打个比方:

队列(queue)是我们想要去的位于纽约的目的地 
交换机(exchange)是JFK机场 
绑定(binding)就是JFK机场到目的地的路线。能够到达目的地的路线可以是一条或者多条 
拥有了交换机这个中间层,很多由发布者直接到队列难以实现的路由方案能够得以实现,并且避免了应用开发者的许多重复劳动。

如果AMQP的消息无法路由到队列(例如,发送到的交换机没有绑定队列),消息会被就地销毁或者返还给发布者。如何处理取决于发布者设置的消息属性。

  • 1.4 ack机制

RabbitMq默认是ack机制:no-ack的方式

执行一个任务可能需要花费几秒钟,你可能会担心如果一个消费者在执行任务过程中挂掉了。一旦RabbitMQ将消息分发给了消费者,就会从内存中删除。在这种情况下,如果正在执行任务的消费者宕机,会丢失正在处理的消息和分发给这个消费者但尚未处理的消息。

实际项目需要手动ack机制 - 见下问实战代码

  • 1.5 消息重复消费

用户在停止查询时,会导致消费者进程被杀死,因此ACK状态码未反馈至MQ,从而消息一直存留在MQ中,当新的消费者启动时会重新消费;

接受消息后-消费消息前,db或者redis nosql检查消息消费状态 - 见下问实战代码

2 配置准备

  • 2.1 pom
<!-- rabbbit.mq -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
  • 2.2 rabbitMQ config
package com.ttd.trustProduct.mq.rabbit;

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.FanoutExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.TopicExchange;
import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; /**
* rabbit 配置
*
* @author wolf
*/
@Configuration
@EnableRabbit
public class RabbitConfiguration { //===============以下是验证topic Exchange的队列==========
@Bean
public Queue productMessage() {
return new Queue("ttd.trust.product");
} @Bean
public Queue allMessages() {
return new Queue("ttd.all");
} @Bean
TopicExchange exchange() {
return new TopicExchange("exchange");
} /**
* 将队列topic.message与exchange绑定,binding_key为topic.message,就是完全匹配
*
* @param queueMessage
* @param exchange
* @return
*/
@Bean
Binding bindingExchangeMessage(Queue productMessage, TopicExchange exchange) {
return BindingBuilder.bind(productMessage).to(exchange).with("ttd.trust.product");
} /**
* 将队列topic.messages与exchange绑定,binding_key为topic.#,模糊匹配
*
* @param queueMessage
* @param exchange
* @return
*/
@Bean
Binding bindingExchangeMessages(Queue allMessages, TopicExchange exchange) {
return BindingBuilder.bind(allMessages).to(exchange).with("ttd.#");
}
//===============以上是验证topic Exchange的队列========== //===============以下是验证Fanout Exchange的队列==========
@Bean
public Queue AMessage() {
return new Queue("fanout.A");
} @Bean
public Queue BMessage() {
return new Queue("fanout.B");
} @Bean
public Queue CMessage() {
return new Queue("fanout.C");
} @Bean
FanoutExchange fanoutExchange() {
return new FanoutExchange("fanoutExchange");
} @Bean
Binding bindingExchangeA(Queue AMessage, FanoutExchange fanoutExchange) {
return BindingBuilder.bind(AMessage).to(fanoutExchange);
} @Bean
Binding bindingExchangeB(Queue BMessage, FanoutExchange fanoutExchange) {
return BindingBuilder.bind(BMessage).to(fanoutExchange);
} @Bean
Binding bindingExchangeC(Queue CMessage, FanoutExchange fanoutExchange) {
return BindingBuilder.bind(CMessage).to(fanoutExchange);
}
//===============以上是验证Fanout Exchange的队列========== @Bean
public Queue helloQueue() {
return new Queue("newhelloQueue");
} }
  • 2.4 数据交换协议
package com.ttd.sdk.common;

import java.io.Serializable;
import java.util.Date;
import java.util.Map; import com.alibaba.fastjson.JSON;
import com.ttd.sdk.util.DateUtil;
import com.ttd.sdk.util.RandomUtils; /**
* 消息体
*
* @author wolf
*
*/
public class MQMessage implements Serializable {
private static final long serialVersionUID = 1L; private Integer productCode; // 生产者代码
private Integer consumerCode; // 消费者代码
private String messageId; // 消息唯一标识
private Integer event; // 消息监听事件
private Integer action; //操作:1加,2减
private Date created; // 消息发送时间
private Map<String, Object> bussinessBody; // 消息体,封装业务数据 private MQMessage() {
super();
} private MQMessage(Integer productCode, Integer consumerCode, String messageId, Integer event, Date created,
Map<String, Object> bussinessBody, Integer action) {
super();
this.productCode = productCode;
this.consumerCode = consumerCode;
this.messageId = messageId;
this.event = event;
this.created = created;
this.bussinessBody = bussinessBody;
this.action = action;
} private MQMessage(Integer productCode, Integer consumerCode, Integer event, Map<String, Object> bussinessBody, Integer action) {
super();
this.productCode = productCode;
this.consumerCode = consumerCode;
this.event = event;
this.bussinessBody = bussinessBody;
this.action = action;
} public static String productMQMessage(Integer productCode, Integer consumerCode, Integer event, Map<String, Object> bussinessBody, Integer action) {
MQMessage mqObj = new MQMessage(productCode, consumerCode, event, bussinessBody, action);
mqObj.setCreated(new Date());
mqObj.setMessageId(generatSeriaeNo()); return JSON.toJSONString(mqObj);
} //生成消息唯一标识
private static String generatSeriaeNo() {
return DateUtil.dateFormat("yyyyMMddHHmmss") + RandomUtils.randomCode(2);
} public Integer getProductCode() {
return productCode;
} public void setProductCode(Integer productCode) {
this.productCode = productCode;
} public Integer getConsumerCode() {
return consumerCode;
} public void setConsumerCode(Integer consumerCode) {
this.consumerCode = consumerCode;
} public String getMessageId() {
return messageId;
} public void setMessageId(String messageId) {
this.messageId = messageId;
} public Integer getEvent() {
return event;
} public void setEvent(Integer event) {
this.event = event;
} public Date getCreated() {
return created;
} public void setCreated(Date created) {
this.created = created;
} public Map<String, Object> getBussinessBody() {
return bussinessBody;
} public void setBussinessBody(Map<String, Object> bussinessBody) {
this.bussinessBody = bussinessBody;
} public Integer getAction() {
return action;
} public void setAction(Integer action) {
this.action = action;
} @Override
public String toString() {
return "MQMessage [productCode=" + productCode + ", consumerCode="
+ consumerCode + ", messageId=" + messageId + ", event="
+ event + ", action=" + action + ", created=" + created
+ ", bussinessBody=" + bussinessBody + "]";
}
}

3 实战

  • 3.1 生产者
生产者与消费者数据协议为json,定义统一数据传输实体。
package com.ttd.trustProduct.mq.rabbit; import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; @Component
public class ProductTopicSender {
@Autowired
private AmqpTemplate rabbitTemplate; private static final Logger logger = LoggerFactory.getLogger(ProductTopicSender.class); public void send(String msg) {
System.out.println("ProductTopicSender : " + msg);
this.rabbitTemplate.convertAndSend("exchange", "ttd.trust.product", msg);
} }
  • 3.2 消费者
package com.ttd.trustProduct.mq.rabbit;

import javax.annotation.Resource;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.amqp.core.AcknowledgeMode;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.ChannelAwareMessageListener;
import org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component; import com.alibaba.fastjson.JSON;
import com.rabbitmq.client.Channel;
import com.ttd.sdk.common.MQMessage;
import com.ttd.sdk.common.enumerate.ActionCodeEnum;
import com.ttd.sdk.common.enumerate.EventCodeEnum;
import com.ttd.trustProduct.domain.LogMqMessage;
import com.ttd.trustProduct.domain.SaleInfo;
import com.ttd.trustProduct.service.LogMqMessageService;
import com.ttd.trustProduct.service.SaleInfoService;
import com.ttd.trustProduct.utils.IntegerUtils; @Component
@RabbitListener(queues = "ttd.trust.product")
public class ProductMessageReceiver {
@Resource private SaleInfoService saleInfoService;
@Resource private LogMqMessageService logMqMessageService;
private final Logger logger = LoggerFactory.getLogger(ProductMessageReceiver.class); @Autowired private ConnectionFactory connectionff; /*
* Map<String, Object> bussiness = Maps.newHashMap();
**公共必填:**
bussiness.put("productId", 11);
bussiness.put("companyId", 100); //B公司id
bussiness.put("isSmallPerson", 1); //1 or 0
bussiness.put("assignType", 1) //'1指定派发,2抢购派发',
**预约事件必填**
bussiness.put("bookNum", 1);
bussiness.put("bookAmount", 100);
**报单事件必填**
bussiness.put("formNum", 1);
bussiness.put("formAmount", 100);
**募集事件必填**
bussiness.put("raiseNum", 1);
bussiness.put("raiseAmount", 100);
**签章事件必填**
bussiness.put("signedNum", 1); //电子签章数
bussiness.put("paperSignedNum", 1);//纸质签章数
**双录事件必填**
bussiness.put("signingNum", 100);
*/
@Bean
public SimpleMessageListenerContainer messageContainer() {
SimpleMessageListenerContainer container = new SimpleMessageListenerContainer(connectionff);
container.setQueueNames("ttd.trust.product");
container.setExposeListenerChannel(true);
container.setMaxConcurrentConsumers(1);
container.setConcurrentConsumers(1);
container.setAcknowledgeMode(AcknowledgeMode.MANUAL); //设置确认模式手工确认
container.setMessageListener(new ChannelAwareMessageListener() { @Override
public void onMessage(Message message, Channel channel) throws Exception {
byte[] body = message.getBody();
String jsonString = new String(body);
logger.info("|============ProductMessageReceiver : " + jsonString); MQMessage msg = JSON.parseObject(jsonString, MQMessage.class); boolean preRet = preEventHandler(msg);
if (preRet == false) {
channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, true);
return ;
} boolean postRet = postEventHandler(msg);
if (postRet == false) {
channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, true);
return ;
} afterEventHandler(msg); channel.basicAck(message.getMessageProperties().getDeliveryTag(), false); //确认消息成功消费
//channel.basicReject(message.getMessageProperties().getDeliveryTag(), false);
}
});
return container;
} /* @RabbitHandler
public void process(String msg) {
System.out.println("|============ProductMessageReceiver : " +msg);
MQMessage message = JSON.parseObject(msg, MQMessage.class); boolean preRet = preEventHandler(message);
if (preRet == false)
return ; boolean postRet = postEventHandler(message);
if (postRet == false)
return ; afterEventHandler(message);
}*/ private void recordLogMQ(MQMessage message, Integer state) {
LogMqMessage log = new LogMqMessage();
log.setMessageId(message.getMessageId());
log.setProductCode(message.getProductCode());
log.setConsumerCode(message.getConsumerCode());
log.setEvent(message.getEvent());
log.setBussinessBody(JSON.toJSONString(message));
log.setState(state); logMqMessageService.insertEntry(log);
} /**
* 消息体检查
* @param message
* @return
*/
private boolean preEventHandler(MQMessage message) {
//不能重复消费
LogMqMessage logMQ = new LogMqMessage();
logMQ.setMessageId(message.getMessageId());
int count = logMqMessageService.selectEntryListCount(logMQ);
System.out.println(count);
if (count > 0) {
return false;
} //消息体格式错误
if (message.getEvent() == null || message.getAction() == null || message.getBussinessBody() == null ||
!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("productId")) ||
!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("companyId")) ||
(Integer) message.getBussinessBody().get("isSmallPerson") == null ) {
recordLogMQ(message, -1);
return false;
} //业务类型检查
//预约事件
if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.BOOK_EVENT.getValue())) {
if (!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("bookNum")) ||
!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("bookAmount"))) {
recordLogMQ(message, -1);
return false;
} //报单事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.FORM_EVENT.getValue())) {
if (!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("formNum")) ||
!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("formAmount"))) {
recordLogMQ(message, -1);
return false;
} //双录事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.RECORD_EVENT.getValue())) {
if (!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("signingNum"))) {
recordLogMQ(message, -1);
return false;
} //签章事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.RECORD_EVENT.getValue())) {
if (!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("signedNum"))
|| !IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("paperSignedNum"))) {
recordLogMQ(message, -1);
return false;
} //募集事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.RECORD_EVENT.getValue())) {
if (!IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("raiseNum")) ||
IntegerUtils.greatThanZero((Integer) message.getBussinessBody().get("raiseAmount"))) {
recordLogMQ(message, -1);
return false;
}
} return true;
} /**
* 业务处理
* @param message
* @return
*/
private boolean postEventHandler(MQMessage message) {
Integer productId = (Integer) message.getBussinessBody().get("productId");
Integer companyId = (Integer) message.getBussinessBody().get("companyId");
Integer isSmallPerson = (Integer) message.getBussinessBody().get("isSmallPerson");
Integer assignType = (Integer) message.getBussinessBody().get("assignType"); //查询
SaleInfo saleInfo = new SaleInfo();
saleInfo.setCompanyId(IntegerUtils.parseLong(companyId));
saleInfo.setProductId(IntegerUtils.parseLong(productId));
saleInfo.setAssignType(assignType);
SaleInfo cond = saleInfoService.selectEntryOne(saleInfo); //预约事件
if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.BOOK_EVENT.getValue())) {
Integer bookNum = (Integer) message.getBussinessBody().get("bookNum");
Integer bookAmount = (Integer) message.getBussinessBody().get("bookAmount"); //insert and plus
if (cond == null && IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
saleInfo.setBookTotalNum(bookNum);
saleInfo.setBookTotalAmount(bookAmount);
if (IntegerUtils.greatThanZero(isSmallPerson)) {
saleInfo.setSmallPersonBookNum(bookNum);
saleInfo.setSmallPersonBookAmount(bookAmount);
}
saleInfoService.insertEntry(saleInfo); //update
} else {
if (IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
cond.setBookTotalNum(cond.getBookTotalNum() + bookNum);
cond.setBookTotalAmount(cond.getBookTotalAmount() + bookAmount);
if (IntegerUtils.greatThanZero(isSmallPerson)) {
cond.setSmallPersonBookNum(cond.getSmallPersonBookNum() + bookNum);
cond.setSmallPersonBookAmount(cond.getSmallPersonBookAmount() + bookAmount);
}
} else {
cond.setBookTotalNum(cond.getBookTotalNum() - bookNum);
cond.setBookTotalAmount(cond.getBookTotalAmount() - bookAmount);
if (IntegerUtils.greatThanZero(isSmallPerson)) {
cond.setSmallPersonBookNum(cond.getSmallPersonBookNum() - bookNum);
cond.setSmallPersonBookAmount(cond.getSmallPersonBookAmount() - bookAmount);
}
}
saleInfoService.updateByKey(cond);
} //报单事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.FORM_EVENT.getValue())) {
Integer formNum = (Integer) message.getBussinessBody().get("formNum");
Integer formAmount = (Integer) message.getBussinessBody().get("formAmount"); //insert and plus
if (cond == null && IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
saleInfo.setFormTotalNum(formNum);
saleInfo.setFormTotalAmount(formAmount);
if (IntegerUtils.greatThanZero(isSmallPerson)) {
saleInfo.setSmallPersonFormNum(formNum);
saleInfo.setSmallPersonFormAmount(formAmount);
}
saleInfoService.insertEntry(saleInfo); //update
} else {
if (IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
cond.setFormTotalNum(cond.getFormTotalNum() + formNum);
cond.setFormTotalAmount(cond.getFormTotalAmount() + formAmount);
if (IntegerUtils.greatThanZero(isSmallPerson)) {
cond.setSmallPersonFormNum(cond.getSmallPersonFormNum() + formNum);
cond.setSmallPersonFormAmount(saleInfo.getSmallPersonFormAmount() + formAmount);
}
} else {
cond.setFormTotalNum(cond.getFormTotalNum() - formNum);
cond.setFormTotalAmount(cond.getFormTotalAmount() - formAmount);
if (IntegerUtils.greatThanZero(isSmallPerson)) {
cond.setSmallPersonFormNum(cond.getSmallPersonFormNum() - formNum);
cond.setSmallPersonFormAmount(cond.getSmallPersonFormAmount() - formAmount);
}
}
saleInfoService.updateByKey(cond);
} //双录事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.RECORD_EVENT.getValue())) {
Integer signingNum = (Integer) message.getBussinessBody().get("signingNum"); //insert and plus
if (cond == null && IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
saleInfo.setSigningContractNum(signingNum);
saleInfoService.insertEntry(saleInfo); //update
} else {
if (IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
cond.setSigningContractNum(cond.getSigningContractNum() + signingNum);
} else {
cond.setSigningContractNum(cond.getSigningContractNum() - signingNum);
}
saleInfoService.updateByKey(cond);
} //签章事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.RECORD_EVENT.getValue())) {
Integer signedNum = (Integer) message.getBussinessBody().get("signedNum");
Integer paperSignedNum = (Integer) message.getBussinessBody().get("paperSignedNum"); //insert and plus
if (cond == null && IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
saleInfo.setSignedContractNum(signedNum);
saleInfo.setPaperSignedContractNum(paperSignedNum);
saleInfoService.insertEntry(saleInfo); //update
} else {
if (IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
cond.setSignedContractNum(cond.getSignedContractNum() + signedNum);
cond.setPaperSignedContractNum(cond.getPaperSignedContractNum() + paperSignedNum);
} else {
cond.setSignedContractNum(cond.getSignedContractNum() - signedNum);
cond.setPaperSignedContractNum(cond.getPaperSignedContractNum() - paperSignedNum);
}
saleInfoService.updateByKey(cond);
} //募集事件
} else if (IntegerUtils.equals(message.getEvent(), EventCodeEnum.RECORD_EVENT.getValue())) {
Integer raiseNum = (Integer) message.getBussinessBody().get("raiseNum");
Integer raiseAmount = (Integer) message.getBussinessBody().get("raiseAmount"); //insert and plus
if (cond == null && IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
saleInfo.setRaiseTotalNum(raiseNum);
saleInfo.setRaiseTotalAmount(raiseAmount);
saleInfoService.insertEntry(saleInfo); //update
} else {
if (IntegerUtils.equals(ActionCodeEnum.PLUS_ACTION.getValue(), message.getAction())) {
cond.setRaiseTotalNum(cond.getRaiseTotalNum() + raiseNum);
cond.setRaiseTotalAmount(cond.getRaiseTotalAmount() + raiseAmount);
} else {
cond.setRaiseTotalNum(cond.getRaiseTotalNum() - raiseNum);
cond.setRaiseTotalAmount(cond.getRaiseTotalAmount() - raiseAmount);
}
saleInfoService.updateByKey(cond);
} } return true;
} /**
* 消息日志处理
* @param message
*/
private void afterEventHandler(MQMessage message) {
recordLogMQ(message, 1);
} }
  • 3.3 单元测试
package com.ttd.test;

import java.util.Map;

import javax.annotation.Resource;

import org.junit.Test;

import com.google.common.collect.Maps;
import com.ttd.sdk.common.MQMessage;
import com.ttd.sdk.common.enumerate.ActionCodeEnum;
import com.ttd.sdk.common.enumerate.EventCodeEnum;
import com.ttd.sdk.common.enumerate.ServiceCodeEnum;
import com.ttd.trustProduct.mq.kafka.MsgProducer;
import com.ttd.trustProduct.mq.rabbit.ProductTopicSender; public class TestMsg extends BaseTestService{ @Resource private MsgProducer producer;
@Resource private ProductTopicSender topicSender;
// @Resource private FanoutSender fanoutSender;
// @Resource private CallBackSender callBackSender;
// @Resource private HelloSender1 hellSender1; //kafka
// @Test
public void testSendMsg() {
String seriNo = System.currentTimeMillis()/1000 + "";
producer.send("edwintest", "{\"seriNo\":" + seriNo + ",\"code\":200, \"msg\":\"发送一条消息,1-topic-8partion-1-replication\"}");
} // topic exchange
@Test
public void testTopicRabbit() throws InterruptedException {
Map<String, Object> bussiness = Maps.newHashMap();
bussiness.put("productId", 15);
bussiness.put("companyId", 100); //B公司id
bussiness.put("isSmallPerson", 1); //1 or 0
bussiness.put("assignType", 1); bussiness.put("bookNum", 1);
bussiness.put("bookAmount", 100);
/*bussiness.put("formNum", 1);
bussiness.put("formAmount", 100);
bussiness.put("raiseNum", 1);
bussiness.put("raiseAmount", 100);
bussiness.put("signedNum", 1);
bussiness.put("signingNum", 100); */ String messageBody = MQMessage.productMQMessage(
ServiceCodeEnum.TTD_TRUST_ORDER.getValue(),
ServiceCodeEnum.TTD_TRUST_PRODUCT.getValue(),
EventCodeEnum.BOOK_EVENT.getValue(),
bussiness,
ActionCodeEnum.PLUS_ACTION.getValue());
topicSender.send(messageBody); }
}

SpringBoot RabbitMQ 实战解决项目中实践的更多相关文章

  1. Hystrix在项目中实践

    Hystrix在项目中实践 https://mp.weixin.qq.com/s/4Fg0COnWRB3rRWfxbJt7gA

  2. Eclipse解决项目中找不到Maven Dependencies

    项目中找不到Maven Dependencies 正常的Maven项目应该是这样的 自己的项目中却没有Maven Dependencies 先做第一步 若项目中还没有出现Maven Dependenc ...

  3. 解决项目中.a文件的冲突

    .a文件是静态文件,有多个.o文件组合而成的,在ios项目开发中,当引用第三方库的时候,时不时的会碰到诸如库冲突.库包含了某些禁用的API等问题,而这些库往往都被打包成了静态库文件(即 .a文件)来使 ...

  4. 针对MSHFlexGrid的一系列通用方法-项目中实践代码分享

    1.给MSHFlexGrid填充数据通用方法 '自定义报表填充程序 fgrid Public Function ShowformfData(Resultset As ADODB.Recordset, ...

  5. 解决项目中EF5.0升级到EF6.0无法安装包的方法

    今天在vs2012上新建了一个mvc4的项目,mvc4中默认的Entity Framework是5.0的版本,如下所示: 或者:,但是项目中有些要用到EF6.0的相关方法,用EF5.0实在繁琐,于是在 ...

  6. 解决项目中找不到Maven Dependencies

    项目中找不到Maven Dependencies 正常的Maven项目应该是这样的 自己的项目中却没有Maven Dependencies,自己百度了, 发现解决不了,最后发现在.classpath和 ...

  7. 开源物联网框架ServerSuperIO(SSIO),项目中实践应用介绍

    一.项目背景 我们是传统行业,但是我们有一颗不传统的心.企业用户遍布国内和国外,面对行业,要建设行业级的(大)数据平台.一提到大数据平台,大家往往想到Hadoop.Spark.Nosql.分布式等等, ...

  8. 使用mysql的SUBSTRING_INDEX函数解决项目中编码非重复问题的实现方案!

    一 SUBSTRING_INDEX函数介绍 作用:按关键字截取字符串 substring_index(str,delim,count) 说明:substring_index(被截取字段,关键字,关键字 ...

  9. Springboot Maven 多模块项目中 @Service跨模块引用失败的问题

    子模块中引用另一个子模块中的Service, @Autowired失败. 添加了模块之间的依赖没解决. 组以后在启动类上加上 @SpringBootApplication(scanBasePackag ...

  10. 使用Spring CROS解决项目中的跨域问题

    CROS(Cross-Origin Resource Sharing) 用于解决浏览器中跨域请求的问题.简单的Get请求可以使用JSONP来解决,而对于其它复杂的请求则需要后端应用的支持CROS.Sp ...

随机推荐

  1. 在Ubuntu中安装Samba文件服务

    点击蓝字 关注我们 First Frost 在Ubuntu中安装Samba文件服务 Samba是一个能让Linux系统应用Microsoft网络通讯协议的软件,而SMB是Server Message ...

  2. [网络]HTTPS下服务器与浏览器的通信:HTTPS背后的加密算法 | TLS := SSL [转载]

    全文转载自: HTTPS背后的加密算法 - 博客园 1 概述: 基本原理/过程 当你在浏览器的地址栏上输入https开头的网址后,浏览器和服务器之间会在接下来的几百毫秒内进行大量的通信.InfoQ的这 ...

  3. LeeCode 91双周赛复盘

    T1: 不同的平均值数目 思路:排序 + 双指针 + 哈希存储 public int distinctAverages(int[] nums) { Arrays.sort(nums); Set< ...

  4. NTP 4.2.6p5版本导致多个系统安全漏洞

    问题描述:通过漏洞扫描发现NTP 4.2.6p5版本导致多个系统漏洞,需要升级版本更高的ntp,一般刚开始都是yum直接装ntp包,现在需要重新卸载安装源码包 下载链接:http://distfile ...

  5. win10启动docker报错,错误码 0xffffffff

    一.注册表修复(如果有就不用管) 在\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\WinSock2\Parameters\AppId_Ca ...

  6. 计算机常用的快捷键以及常用的Dos命令

    计算机的常用快捷键有哪些? 今天我重温了Java基础的课程,计算机的快捷键大家肯定不陌生.   计算机的常用快捷键 ctrl+c 复制 ctrl+v 粘贴 ctrl+s 保存 ctrl+x 剪切 ct ...

  7. [OpenCV-Python] 23 图像变换

    文章目录 OpenCV-Python:IV OpenCV中的图像处理 23 图像变换 23.1 傅里叶变换 23.1.1 Numpy 中的傅里叶变换 23.1.2 OpenCV 中的傅里叶变换 23. ...

  8. (原创第一篇,踩坑无数得来的,对Ai自动化测试框架很有帮助)appium自动化测试时遇到不能使用element定位的在用坐标点击之后获取焦点如何输入文本

    现在开发的前端界面使用vue或者更牛逼技术,导致使用appium或者uiautomator2做自动化测试时不能识别到元素,无法使用传统的id,name或者xpath,这时我们需要使用坐标点击文本框.有 ...

  9. Solon 统一的返回结果调整

    使用 "统一的渲染控制" 可以对输出做统一的控制外...还可以借助路由拦截器 RouterInterceptor ,对 mvc 返回结果做提交确认机制(即可修改)进行控制(相对来讲 ...

  10. 【Vue3】引入组件Failed to resolve component: MyButton If this is a native custom element

    引入组件时页面上并没有出现组件的影子,其他元素正常,初步确定是组件引入部分语法出了问题,打开开发者工具看到控制台报出错误代码: Failed to resolve component: MyButto ...