mq配置文件(Spring)

主要是顺序消息的配置,以及多实例的配置(需要在控制台配置p/c)

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd">
<!--MQ生产者相关开始-->
<bean id="producer" class="com.aliyun.openservices.ons.api.bean.ProducerBean"
init-method="start" destroy-method="shutdown">
<property name="properties">
<map>
<entry key="ProducerId" value="${ProducerId}"/> <!-- PID,请替换 -->
<entry key="AccessKey" value="${AccessKey}"/> <!-- ACCESS_KEY,请替换 -->
<entry key="SecretKey" value="${SecretKey}"/> <!-- SECRET_KEY,请替换 -->
<entry key="ONSAddr" value="${ONSAddr}"/>
</map>
</property>
</bean>
<!--顺序消息-->
<bean id="mqOrderProducer" class="com.rqbao.mq.listenter.MQOrderProducer"
init-method="start" destroy-method="shutdown">
<constructor-arg name="producerProperties">
<props>
<prop key="ProducerId">${OrderProducerId}</prop>
<prop key="AccessKey">${AccessKey}</prop>
<prop key="SecretKey">${SecretKey}</prop>
<prop key="ONSAddr">${ONSAddr}</prop>
<prop key="ORDER_TOPIC">${ORDER_TOPIC}</prop>
<prop key="TAG">1111</prop>
</props>
</constructor-arg>
</bean>
<!--MQ生产者相关结束--> <!--MQ消费者相关开始-->
<bean id="consumer" class="com.aliyun.openservices.ons.api.bean.ConsumerBean"
init-method="start" destroy-method="shutdown">
<property name="properties">
<map>
<entry key="ConsumerId" value="${OrderConsumerId}"/> <!-- CID,请替换 -->
<entry key="AccessKey" value="${AccessKey}"/> <!-- ACCESS_KEY,请替换 -->
<entry key="SecretKey" value="${SecretKey}"/><!-- SECRET_KEY,请替换 -->
<entry key="ONSAddr" value="${ONSAddr}"/>
</map>
</property> <property name="subscriptionTable">
<map>
<entry value-ref="messageListener">
<key>
<bean class="com.aliyun.openservices.ons.api.bean.Subscription">
<property name="topic" value="${topic}"/> <!-- Topic,请替换 -->
<property name="expression" value="*"/><!-- MessageType名: 多个messageType 用 “||”分割 -->
</bean>
</key>
</entry>
</map> </property>
</bean>
<!--顺序消息-->
<bean id="consumerOrder" class="com.rqbao.mq.listenter.MQOrderConsumer"
init-method="start" destroy-method="shutdown">
<constructor-arg name="consumerProperties">
<props>
<prop key="ConsumerId">${ConsumerId}</prop>
<prop key="AccessKey">${AccessKey}</prop>
<prop key="SecretKey">${SecretKey}</prop>
<prop key="ONSAddr">${ONSAddr}</prop>
<prop key="ORDER_TOPIC">${ORDER_TOPIC}</prop>
<prop key="TAG">1111</prop>
</props>
</constructor-arg>
</bean>
<!-- 消息处理器 -->
<bean id="messageListener" class="com.rqbao.mq.listenter.MQListener"/>
<!--顺序--> <!--MQ消费者相关结束-->
</beans>

顺序生产者

 package com.rqbao.mq.listenter;

import com.aliyun.openservices.ons.api.ONSFactory;
import com.aliyun.openservices.ons.api.order.OrderProducer; import java.util.Properties; /**
* Created by ricky on 2017/7/2.
*/
public class MQOrderProducer {
private Properties producerProperties = new Properties();
private OrderProducer producer; public MQOrderProducer(Properties producerProperties) {
this.producerProperties = producerProperties;
producer = ONSFactory.createOrderProducer(producerProperties);
}
public OrderProducer getOrderProducer(){
return producer;
}
public void start(){
new MQOrderProducer(producerProperties);
producer.start();
}
public void shutdown(){
producer.shutdown();
} public Properties getProducerProperties() {
return producerProperties;
} public void setProducerProperties(Properties producerProperties) {
this.producerProperties = producerProperties;
} public OrderProducer getProducer() {
return producer;
} public void setProducer(OrderProducer producer) {
this.producer = producer;
}
}

顺序消费者

package com.rqbao.mq.listenter;

import com.aliyun.openservices.ons.api.Message;
import com.aliyun.openservices.ons.api.ONSFactory;
import com.aliyun.openservices.ons.api.order.ConsumeOrderContext;
import com.aliyun.openservices.ons.api.order.MessageOrderListener;
import com.aliyun.openservices.ons.api.order.OrderAction;
import com.aliyun.openservices.ons.api.order.OrderConsumer; import java.util.Properties; /**
* Created by ricky on 2017/7/2.
*/
public class MQOrderConsumer {
private Properties consumerProperties = new Properties();
private OrderConsumer consumer; public MQOrderConsumer(Properties consumerProperties) {
this.consumerProperties = consumerProperties;
consumer = ONSFactory.createOrderedConsumer(consumerProperties);
consumer.subscribe(consumerProperties.get("ORDER_TOPIC").toString(), consumerProperties.get("TAG").toString(), new MessageOrderListener() {
@Override
public OrderAction consume(final Message message, final ConsumeOrderContext context) {
System.out.println(message);
return OrderAction.Success;
}
});
}
public void start(){
new MQOrderProducer(consumerProperties);
consumer.start();
}
public void shutdown(){
consumer.shutdown();
} public Properties getConsumerProperties() {
return consumerProperties;
} public void setConsumerProperties(Properties consumerProperties) {
this.consumerProperties = consumerProperties;
} public OrderConsumer getConsumer() {
return consumer;
} public void setConsumer(OrderConsumer consumer) {
this.consumer = consumer;
}
}

参数文件

#ALiMQ相关参数
#入钥
AccessKey=XXXXXX
#秘钥
SecretKey=XXXXXXX
#阿里云MQ线上地址
#PropertyKeyConst.ONSAddr 请根据不同Region进行配置
#公网测试: http://onsaddr-internet.aliyun.com/rocketmq/nsaddr4client-internet
#公有云生产: http://onsaddr-internal.aliyun.com:8080/rocketmq/nsaddr4client-internal
#杭州金融云: http://jbponsaddr-internal.aliyun.com:8080/rocketmq/nsaddr4client-internal
#深圳金融云: http://mq4finance-sz.addr.aliyun.com:8080/rocketmq/nsaddr4client-internal
ONSAddr=http://onsaddr-internet.aliyun.com/rocketmq/nsaddr4client-internet
#主题
topic=RICKY_CGBUSINESS_LOCAL
ORDER_TOPIC=RICKY_CGBUSINESS_TEST
#生产者Id
ProducerId=PID_RICKYCG_LOCAL
OrderProducerId=PID_RICKYCG_TEST
#消费者
ConsumerId=CID_RICKYCG_LOCAL
OrderConsumerId=CID_RICKYCG_TEST

顺序消息生产

import com.aliyun.openservices.ons.api.Message;
import com.aliyun.openservices.ons.api.SendResult;
import com.aliyun.openservices.ons.api.order.OrderProducer;
import com.rqbao.mq.common.config.Global;
import org.apache.log4j.Logger;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import java.util.Date;
import java.util.UUID; /**
* Created by ricky on 2017/6/8.
*MQ消息生产功能,可能附加一些其他功能
*/
@Service
public class MQOrderService implements InitializingBean{
private static final Logger logger = Logger.getLogger(MQOrderService.class);
@Autowired
MQOrderProducer mqOrderProducer; /**
* 发送顺序MQ消息
* @param TAG 业务tag tag将使用CGUTILS中的存管接口变量
* @param msg 需传递对应接口需要参数,格式待考究
* delayTime 延迟时间 3000--->3s
* @return
*/
public String sendOrderMQMsg(String TAG,String msg){
OrderProducer producer=mqOrderProducer.getOrderProducer();
Message message = new Message(Global.getConfig("ORDER_TOPIC"), TAG,msg.getBytes());
// 设置代表消息的业务关键属性,请尽可能全局唯一。
String orderId = "rqb_" + UUID.randomUUID().toString().replaceAll("-","");
message.setKey(orderId);
// 分区顺序消息中区分不同分区的关键字段,sharding key于普通消息的key是完全不同的概念。
// 全局顺序消息,该字段可以设置为任意非空字符串。
String shardingKey = String.valueOf(orderId);
SendResult sendResult = producer.send(message, shardingKey);
if (sendResult != null) {
System.out.println(new Date() + " Send mq message success! Topic is:" + Global.getConfig("topic") + "msgId is: " + sendResult.getMessageId());
}
return sendResult.toString();
}
@Override
public void afterPropertiesSet() throws Exception { }
}

顺序消息消费

具体在MQOrderConsumer中写消费处理

关于延时和定时消息

依据官方说明,延时消息必须是无序的topic,切记。

可参阅官方文档

问题

MQ存在重复消费的问题,我这里的解决方案是进行MQ消息记录,比如消息有tag再加上body中相关的业务id,联合组成唯一索引,避免重复消费问题。

附demo地址:

http://git.oschina.net/bgt0314/alimq_demo

原文:https://blog.csdn.net/u014042066/article/details/74170723

AliWareMQ的更多相关文章

  1. 》》3D轮播

    * { margin: 0; padding: 0; } .slide { position: absolute; top: calc(50% - 150px); left: calc(50% - 3 ...

  2. RocketMQ 使用情况梳理

    个人梳理有限:欢迎大家 丰富此文档 2018年 12 月 RocketMQ 版本  不适用于 新版关系请勿参考目前规划原则:          topic 创建基于业务  消费者基于模块 多对多关系 ...

随机推荐

  1. 编码 - 调整 gitbash 文本字符集

    概述 gitbash 设置 文本字符集 背景 最近被 编码 的事情搞得乱七八糟 有点没头绪, 所以碰到 编码相关 的东西, 都想看上一看 环境 os win10.1903 git 2.20.1 1. ...

  2. VS2017连接MySQL数据库

    vs默认无法直接连接mysql,需要我们自己配置环境. 1.下载mysql-installer-community-8.0.18.0.msi 下载地址:https://dev.mysql.com/do ...

  3. 安卓模拟器genymotion 安装使用

    下载:https://www.genymotion.com/download/ 安装前先注册: https://www.runoob.com/w3cnote/android-tutorial-geny ...

  4. element 表格里的input点击回车聚焦下个input

    <template> <card> <el-table ref="singleTable" :data="tableData" h ...

  5. c数据结构 -- 栈与队列

    栈和队列 ·栈和队列是两种常用的.重要的数据结构 ·栈和队列是限定插入和删除只能在表的“端点”进行的线性表 栈 只能在队尾插入,只能在队尾删除 -- 后进后出 表尾称为栈顶:表头称为栈底 插入元素到栈 ...

  6. JavaScript 开胃菜

    注释 单行注释:// 快捷键: CTRL + / 多行注释: /* 内容 */ 快捷键: ctrl + shift + / 变量 申明变量 var name; 赋值 name = 'peach'; 初 ...

  7. 第三十二篇 玩转数据结构——AVL树(AVL Tree)

          1.. 平衡二叉树 平衡二叉树要求,对于任意一个节点,左子树和右子树的高度差不能超过1. 平衡二叉树的高度和节点数量之间的关系也是O(logn) 为二叉树标注节点高度并计算平衡因子 AVL ...

  8. redis5.0.7安装及配置集群

    1.安装环境linux系统,时间2020年2月 2.官网下载https://redis.io/ 3.解压 tar -zxvf redis-5.0.7.tar.gz 4.配置文件 //创建etc文件夹, ...

  9. dubbo学习(一)认识

    部分图片和表述来自dubbo官网 dubbo 概述 背景 这是一个服务端架构发展的路径图 下面我们介绍后面两种,dubbo 正是处于RPC 范畴内的使用. 分布式服务架构 当垂直应用越来越多,应用之间 ...

  10. RPC 学习(一)认识

    文章部分描述来自参考资料 RPC 什么是RPC     RPC(Remote Procedure Call)-远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议. ...