rocketmq事务消息(rocketmq 发送失败一般怎么处理)

2025-04-19 11:00:01 0

rocketmq事务消息(rocketmq 发送失败一般怎么处理)

本文目录

rocketmq 发送失败一般怎么处理

一:RocketMQ简介RocketMQ是一款分布式、队列模型的消息中间件,具有以下特点:1.能够保证严格的消息顺序2.提供丰富的消息拉取模式3.高效的订阅者水平扩展能力4.实时的消息订阅机制5.亿级消息堆积能力二:安装RocketMQ下载源码首先我们从githup上获取RocketMQ的源码,目前最新的版本为3.5.8,下载地址为: 或者 wget /alibaba/RocketMQ/archive/v3.5.8.tar.gz。请注意:此时我们下载的是源码,直接解压时不能用的,所以我们需要编译之后才能使用。编译源码在进行编译源码之前我们需要安装JDK。如果你已经安装过了,请跳过这里。如果你还没有安装过JDK,请参考这篇文章(Linux环境下安装JDK)。然后我们还需要安装一下Maven。Maven的安装还是比较简单,只需要去官方上下载的安装吧,然后直接解压,再配置一下环境变量就OK。接下来我们把刚才下载来的RockeMQ的源码解压到/usr/local/rockemq-source文件夹中。在源码中有一个Install.sh。如图所示:。运行sh install.sh。在编译完成之后,我们只要target目录下的alibaba-rocketmq这个文件夹中内容,把alibaba-rocketmq文件夹中的内容移动到/usr/local/rocketmq中。如果你不想编译的话,可以从这里下载编译之后的rocketmq。(rocketmq3.5.8)。配置环境变量接下来我们需要配置一下环境变量。在终端中输入以下命令:vi /etc/profile ,在文件的末尾中添加如下两句话:export rocketmq=/usr/local/rocketmq export PATH=$PATH:$rocketmq/bin。接下来我们使配置的换将变量生效:source /etc/profile.三:启动RocketMQ接下来我们启动一下刚才编译的RocketMQ.在启动之前我们需要修改一下RocketMQ启动的内存大小(如果你的系统内存比较大的话,请忽略)。我们进入到/usr/local/rocketmq/bin中,在终端中输入以下命令修改mqnamesrv的内存大小:vi runserver.sh.修改为如图的内容:,接下来修改broker的内存大小:vi runbroker.sh:启动mqnameserver进入到/usr/local/rocketmq/bin中输入以下命令:nohup sh mqnamesrv 》 ~/logs/rocketmqlogs/namesrv.log 2》&1 &。注意最后的这个 & 不要少。启动mqbroker进入到/usr/local/rocketmq/bin中输入以下命令:nohup sh mqbroker -n localhost:9876 autoCreateTopicEnable=true 》 ~/logs/rocketmqlogs/broker.log 2》&1 &。注意:localhost可以换成你刚才启动mqnamesrv的IP。autoCreateTopicEnable=true 这句话不要少了。最后的 & 也不要少了。我们可以通过 ps aux | grep java命令来查看启动的情况。到此,rocketmq的安装完毕。四:RocketMQ的小例子producer: view plain copypackage com.zkn.newlearn.rocketmq; import com.alibaba.rocketmq.client.exception.MQBrokerException; import com.alibaba.rocketmq.client.exception.MQClientException; import com.alibaba.rocketmq.client.producer.DefaultMQProducer; import com.alibaba.rocketmq.client.producer.SendResult; import com.alibaba.rocketmq.common.message.Message; import com.alibaba.rocketmq.remoting.exception.RemotingException; import java.util.concurrent.TimeUnit; /** * Created by zkn on 2016/10/27. */ public class ProducerTest01 { public static void main(String args) { /** * 一个应用创建一个Producer,由应用来维护此对象,可以设置为全局对象或者单例《br》 * 注意:ProducerGroupName需要由应用来保证唯一《br》 * ProducerGroup这个概念发送普通的消息时,作用不大,但是发送分布式事务消息时,比较关键, * 因为服务器会回查这个Group下的任意一个Producer */ DefaultMQProducer producer = new DefaultMQProducer(“ProducerGroupName“); //producer.setNamesrvAddr(“192.168.180.1:9876“); producer.setNamesrvAddr(“192.168.180.133:9876“); producer.setInstanceName(“Producer“); /** * Producer对象在使用之前必须要调用start初始化,初始化一次即可《br》 * 注意:切记不可以在每次发送消息时,都调用start方法 */ try { producer.start(); } catch (MQClientException e) { e.printStackTrace(); } for (int i = 0; i 《 100; i++) { try { /** * 下面这段代码表明一个Producer对象可以发送多个topic,多个tag的消息。 * 注意:send方法是同步调用,只要不抛异常就标识成功。但是发送成功也可会有多种状态,《br》 * 例如消息写入Master成功,但是Slave不成功,这种情况消息属于成功,但是对于个别应用如果对消息可靠性要求极高,《br》 * 需要对这种情况做处理。另外,消息可能会存在发送失败的情况,失败重试由应用来处理。 */ { Message msg = new Message(“TopicTest1“,// topic “TagA“,// tag “OrderID001“,// key (“Hello MetaQ“).getBytes());// body SendResult sendResult = producer.send(msg); System.out.println(sendResult); } { Message msg = new Message(“TopicTest2“, “TagB“, “OrderID001“, (“Hello MetaQ TagB“.getBytes())); SendResult sendResult = producer.send(msg); System.out.println(sendResult); } { Message msg = new Message(“TopicTest3“, “TagC“, “OrderID001“, (“Hello MetaQ TagC“).getBytes()); SendResult sendResult = producer.send(msg); System.out.println(sendResult); } TimeUnit.MILLISECONDS.sleep(1000); } catch (MQClientException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } catch (RemotingException e) { e.printStackTrace(); } catch (MQBrokerException e) { e.printStackTrace(); } } /** * 应用退出时,要调用shutdown来清理资源,关闭网络连接,从MetaQ服务器上注销自己 * 注意:我们建议应用在JBOSS、Tomcat等容器的退出销毁方法里调用shutdown方法 */ producer.shutdown(); } }

怎么指定rocketmq的jdk

一:RocketMQ简介RocketMQ是一款分布式、队列模型的消息中间件,具有以下特点:1.能够保证严格的消息顺序2.提供丰富的消息拉取模式3.高效的订阅者水平扩展能力4.实时的消息订阅机制5.亿级消息堆积能力二:安装RocketMQ下载源码首先我们从githup上获取RocketMQ的源码,目前最新的版本为3.5.8,下载地址为:或者wget/alibaba/RocketMQ/archive/v3.5.8.tar.gz。请注意:此时我们下载的是源码,直接解压时不能用的,所以我们需要编译之后才能使用。编译源码在进行编译源码之前我们需要安装JDK。如果你已经安装过了,请跳过这里。如果你还没有安装过JDK,请参考这篇文章(Linux环境下安装JDK)。然后我们还需要安装一下Maven。Maven的安装还是比较简单,只需要去官方上下载的安装吧,然后直接解压,再配置一下环境变量就OK。接下来我们把刚才下载来的RockeMQ的源码解压到/usr/local/rockemq-source文件夹中。在源码中有一个Install.sh。如图所示:。运行shinstall.sh。在编译完成之后,我们只要target目录下的alibaba-rocketmq这个文件夹中内容,把alibaba-rocketmq文件夹中的内容移动到/usr/local/rocketmq中。如果你不想编译的话,可以从这里下载编译之后的rocketmq。(rocketmq3.5.8)。配置环境变量接下来我们需要配置一下环境变量。在终端中输入以下命令:vi/etc/profile,在文件的末尾中添加如下两句话:exportrocketmq=/usr/local/rocketmqexportPATH=$PATH:$rocketmq/bin。接下来我们使配置的换将变量生效:source/etc/profile.三:启动RocketMQ接下来我们启动一下刚才编译的RocketMQ.在启动之前我们需要修改一下RocketMQ启动的内存大小(如果你的系统内存比较大的话,请忽略)。我们进入到/usr/local/rocketmq/bin中,在终端中输入以下命令修改mqnamesrv的内存大小:virunserver.sh.修改为如图的内容:,接下来修改broker的内存大小:virunbroker.sh:启动mqnameserver进入到/usr/local/rocketmq/bin中输入以下命令:nohupshmqnamesrv》~/logs/rocketmqlogs/namesrv.log2》&1&。注意最后的这个&不要少。启动mqbroker进入到/usr/local/rocketmq/bin中输入以下命令:nohupshmqbroker-nlocalhost:9876autoCreateTopicEnable=true》~/logs/rocketmqlogs/broker.log2》&1&。注意:localhost可以换成你刚才启动mqnamesrv的IP。autoCreateTopicEnable=true这句话不要少了。最后的&也不要少了。我们可以通过psaux|grepjava命令来查看启动的情况。到此,rocketmq的安装完毕。四:RocketMQ的小例子producer:viewplaincopypackagecom.zkn.newlearn.rocketmq;importcom.alibaba.rocketmq.client.exception.MQBrokerException;importcom.alibaba.rocketmq.client.exception.MQClientException;importcom.alibaba.rocketmq.client.producer.DefaultMQProducer;importcom.alibaba.rocketmq.client.producer.SendResult;importcom.alibaba.rocketmq.common.message.Message;importcom.alibaba.rocketmq.remoting.exception.RemotingException;importjava.util.concurrent.TimeUnit;/***Createdbyzknon2016/10/27.*/publicclassProducerTest01{publicstaticvoidmain(Stringargs){/***一个应用创建一个Producer,由应用来维护此对象,可以设置为全局对象或者单例*注意:ProducerGroupName需要由应用来保证唯一*ProducerGroup这个概念发送普通的消息时,作用不大,但是发送分布式事务消息时,比较关键,*因为服务器会回查这个Group下的任意一个Producer*/DefaultMQProducerproducer=newDefaultMQProducer(“ProducerGroupName“);//producer.setNamesrvAddr(“192.168.180.1:9876“);producer.setNamesrvAddr(“192.168.180.133:9876“);producer.setInstanceName(“Producer“);/***Producer对象在使用之前必须要调用start初始化,初始化一次即可*注意:切记不可以在每次发送消息时,都调用start方法*/try{producer.start();}catch(MQClientExceptione){e.printStackTrace();}for(inti=0;i《100;i++){try{/***下面这段代码表明一个Producer对象可以发送多个topic,多个tag的消息。*注意:send方法是同步调用,只要不抛异常就标识成功。但是发送成功也可会有多种状态,*例如消息写入Master成功,但是Slave不成功,这种情况消息属于成功,但是对于个别应用如果对消息可靠性要求极高,*需要对这种情况做处理。另外,消息可能会存在发送失败的情况,失败重试由应用来处理。*/{Messagemsg=newMessage(“TopicTest1“,//topic“TagA“,//tag“OrderID001“,//key(“HelloMetaQ“).getBytes());//bodySendResultsendResult=producer.send(msg);System.out.println(sendResult);}{Messagemsg=newMessage(“TopicTest2“,“TagB“,“OrderID001“,(“HelloMetaQTagB“.getBytes()));SendResultsendResult=producer.send(msg);System.out.println(sendResult);}{Messagemsg=newMessage(“TopicTest3“,“TagC“,“OrderID001“,(“HelloMetaQTagC“).getBytes());SendResultsendResult=producer.send(msg);System.out.println(sendResult);}TimeUnit.MILLISECONDS.sleep(1000);}catch(MQClientExceptione){e.printStackTrace();}catch(InterruptedExceptione){e.printStackTrace();}catch(RemotingExceptione){e.printStackTrace();}catch(MQBrokerExceptione){e.printStackTrace();}}/***应用退出时,要调用shutdown来清理资源,关闭网络连接,从MetaQ服务器上注销自己*注意:我们建议应用在JBOSS、Tomcat等容器的退出销毁方法里调用shutdown方法*/producer.shutdown();}}

如何查rocketmq 每日量

通过rocketmq控制台查看。除了控制台查看,还可以通过主机地址进行查看,具体步骤如下:1、首先登陆nameserver主机地址。2、执行以下命令(shmqadminconsumerProgress-gconsumeGroupNameeg:shmqadminconsumerProgress-gtest)查看。3、出来的结果BrokerOffset为生产的条数,ConsumerOffset为消费的条数,Diff为堆积的条数。RocketMQ是阿里巴巴开源的分布式消息中间件,支持事务消息、顺序消息、批量消息、定时消息、消息回溯等。它里面有几个区别于标准消息中件间的概念,如Group、Topic、Queue等。系统组成则由Producer、Consumer、Broker、NameServer等。

rocketmq事务消息(rocketmq 发送失败一般怎么处理)

本文编辑:admin
下一篇:没有内容了

更多文章:


md5解密原理(关于md5的原理!哪位大哥说一下,不要从网上随便拖一段文字过来哦!)

md5解密原理(关于md5的原理!哪位大哥说一下,不要从网上随便拖一段文字过来哦!)

本文目录关于md5的原理!哪位大哥说一下,不要从网上随便拖一段文字过来哦!md5不是用来校验下载来的软件的完整性的吗md5码为什么可以破解帐号密码md5是什么东西MD5的算法原理md5解密,谁会md5为什么不能解密关于md5的原理!哪位大哥

2025年2月9日 16:10

网站源代码在线获取(怎样获得网站源代码)

网站源代码在线获取(怎样获得网站源代码)

本文目录怎样获得网站源代码一个网页源代码怎么获取php获取网页源码内容有哪些办法如何获取网页的源代码如何获取网页代码怎样获得网站源代码朋友,仔细看了你的问题,我想你这个问题在你个人解决起来会比较麻烦,看起来你对网站技术还不是很了解,但我想你

2025年3月26日 17:20

正版linux系统官网(中国官方现在正力推LINUX操作系统以取代WINDAOWS桌面系统,是真的吗如何看)

正版linux系统官网(中国官方现在正力推LINUX操作系统以取代WINDAOWS桌面系统,是真的吗如何看)

本文目录中国官方现在正力推LINUX操作系统以取代WINDAOWS桌面系统,是真的吗如何看Linux系统和Windows系统本质上的区别是什么中国官方现在正力推LINUX操作系统以取代WINDAOWS桌面系统,是真的吗如何看官方是否采用Li

2025年3月18日 15:40

java类加载器(在java中,什么是类加载器子系统)

java类加载器(在java中,什么是类加载器子系统)

本文目录在java中,什么是类加载器子系统java什么时候bootstrp类加载器会无法加载在java中,什么是类加载器子系统java中的类要加载到jvm中才能使用,那么把java类加载到jvm中的工具,就是类加载器。java内置3种类加载

2025年3月18日 08:00

《鬼刀》作者是谁呢?鬼刀作者是谁有哪些作品

《鬼刀》作者是谁呢?鬼刀作者是谁有哪些作品

本文目录《鬼刀》作者是谁呢鬼刀作者是谁有哪些作品《鬼刀》是什么呀《鬼刀》为什么不更新了《鬼刀》 作者是谁鬼刀是鬼灭之刃吗《lol》鬼刀是什么鬼刀是一个什么样的人鬼刀小说叫什么名字《鬼刀》作者是谁呢《鬼刀》作者是王凌。王凌是江苏苏州人,毕业于

2025年3月23日 20:40

电脑哪个键是中英文切换?电脑英文要怎么转换成中文版本

电脑哪个键是中英文切换?电脑英文要怎么转换成中文版本

本文目录电脑哪个键是中英文切换电脑英文要怎么转换成中文版本英文怎么中文转换电脑如何把中文版转换成英文版的电脑中英文转换按键有什么可以把中文翻译成英文的软件在Word文档里怎样转换中英文电脑打字如何快速实现中英文转换电脑哪个键是中英文切换  

2025年2月10日 03:10

william 的昵称是不是 bill/willy?关于“willy“这个词的一些疑问

william 的昵称是不是 bill/willy?关于“willy“这个词的一些疑问

本文目录william 的昵称是不是 bill/willy关于“willy“这个词的一些疑问willy-nilly 一词的由来william 的昵称是不是 bill/willyWilliam威廉来源:法国。涵意:一位强而有力的战士或保护者。

2025年3月1日 11:20

百度站长是什么?下载站的站长进

百度站长是什么?下载站的站长进

本文目录百度站长是什么下载站的站长进百度站长是什么百度站长平台:是全球最大的面向中文互联网管理者、移动开发者、创业者的搜索流量管理的官方平台。提供有助于搜索引擎抓取收录的提交和分析工具, SEO的优化建议等;面向移动开发者提供百度官方的AP

2025年2月19日 17:30

java有新地址吗(成都java培训-盛课盟即将乔迁新地址)

java有新地址吗(成都java培训-盛课盟即将乔迁新地址)

本文目录成都java培训-盛课盟即将乔迁新地址现在java的最新版本是那个或者那个版本现在用得比较多希望能给个下载地址java中怎么输出String的地址如何复制一个String,然后用不同的地址保存呢成都java培训-盛课盟即将乔迁新地址

2025年3月16日 04:10

嵌入式系统是什么(嵌入式到底是干什么的啊)

嵌入式系统是什么(嵌入式到底是干什么的啊)

本文目录嵌入式到底是干什么的啊“嵌入式”是什么意思嵌入式系统到底是什么嵌入式到底是干什么的啊嵌入式即嵌入式系统,用于控制、监视或者辅助操作机器和设备的装置。它是一个控制程序存储在ROM中的嵌入式处理器控制板,是一种专用的计算机系统。所有带有

2025年3月8日 23:10

寂然爸爸怎么判的?崎不染与寂然发生了什么

寂然爸爸怎么判的?崎不染与寂然发生了什么

本文目录寂然爸爸怎么判的崎不染与寂然发生了什么寂然父亲开审后被判刑了吗寂然爸爸怎么判的没有消息,起诉与否都不知道。寂然很早的时候就透露过,自己有一个不靠谱的父亲。在21号直播的时候,直接闯进直播间,现场很混乱,寂然无奈之下只好选择报警。从他

2025年3月10日 00:40

xposed官网下载(Vivo+V2049A+安装xposed框架)

xposed官网下载(Vivo+V2049A+安装xposed框架)

本文目录Vivo+V2049A+安装xposed框架xposed小米手机怎么安装在哪里下载xposed框架官方系统怎样安装xposed框架xposed2.6.1版本怎么下载Vivo+V2049A+安装xposed框架摘要XPosed框架是A

2025年3月17日 05:40

american怎么读(American怎么读)

american怎么读(American怎么读)

本文目录American怎么读american怎么读america是哪个国家怎么读美国的英语怎么读American怎么读(1)英  (2)美 1、意思:n. 美国人,美洲人;美国英语adj. 美国的,美洲的;地道美国式的2、短语:Ameri

2025年3月22日 15:30

jsp编译后是什么文件(jsp页面经过转译后将创建一个什么文件)

jsp编译后是什么文件(jsp页面经过转译后将创建一个什么文件)

本文目录jsp页面经过转译后将创建一个什么文件怎样查看Jsp编译后生成的Java文件Jsp文件运行时先被预编译为什么文件;jsp文件编译成java文件后保存在哪个文件夹在一个网站程序中.jsp文件和.java文件分别是做什么的.jsp 是什

2025年3月29日 02:20

vue框架官网(Vue到底是怎样个框架)

vue框架官网(Vue到底是怎样个框架)

本文目录Vue到底是怎样个框架vue框架官网悬浮头部怎么做为什么 vue 官网 不用自己的框架vue框架是什么taro/mpvue/wepy/uni-app这些开发框架哪个好Vue到底是怎样个框架vue是一款有好的、多用途且高性能的Java

2025年2月11日 19:30

correspondence怎么读音(Correspondence怎么读)

correspondence怎么读音(Correspondence怎么读)

本文目录Correspondence怎么读给英文是什么Correspondence怎么读correspondence通感复数:correspondences;考瑞撕破扽次给英文是什么你好!give 英She stretched her ar

2025年3月16日 18:00

荦荦大端什么意思?什么是车用连杆大端

荦荦大端什么意思?什么是车用连杆大端

本文目录荦荦大端什么意思什么是车用连杆大端大端两忘捕风捉影 是什么意思ARM里的大端格式和小端格式分别是什么意思呀大端是哪个朝代大端模式和小端模式大端朝是什么朝代举其大端是什么啥意思荦荦大端什么意思荦荦大端是一个汉语成语,读音为luò lu

2025年3月19日 04:10

visible的动词(怎么加able)

visible的动词(怎么加able)

本文目录怎么加ablevisible的所有形式是什么怎么加able形容词后缀-able与-ible是同义后缀,加在动词后,使动词变为形容词,其意义相当于情态动词 can +此动词被动式。所以在语义上有被动意义。例如: The results

2025年2月26日 03:10

Umi是骗人的吗?优学派umix9通讯版为什么下架了

Umi是骗人的吗?优学派umix9通讯版为什么下架了

本文目录Umi是骗人的吗优学派umix9通讯版为什么下架了umi软件怎么注销登录Umi是骗人的吗umi软件是一款非常优质的交友软件,软件上可以给大家带来全新的交友模式,你可以随时在线聊天互动。umi软件现在随着我们社会的发展,越来越多的男生

2025年4月19日 05:20

dell官网电话(戴尔售后电话,)

dell官网电话(戴尔售后电话,)

本文目录戴尔售后电话,如何拨打dell的客服电话戴尔客服电话是多少戴尔客服电话400请问戴尔客服电话是什么dell售后服务电话戴尔电脑的服务电话戴尔售后电话,1、戴尔灵越、Monitor显示器用户售后电话:800-858-2969。2、戴尔

2025年3月8日 06:30

近期文章

本站热文

harbor,port,pier的区别?谁能解释“harbour“(港口)与“pier“(码头)的区别
2025-02-22 17:40:03 浏览:20
ibatis foreach(ibatis 批量update操作)
2025-02-10 23:40:06 浏览:7
endless rain(endless rain表达什么情感)
2025-02-14 06:00:02 浏览:7
标签列表

热门搜索