rocketmq删除topic_RocketMq 快速入门教程

今年是不平凡的一年,对于每个个体都是。不论我们在哪儿,经历了什么,向前走总没错。虽然方向也很重要,但是不要在一个地方停太久,You young

编者荐语:RocketMQ 逐渐成为最主流的消息队列,学习 RocketMQ 是每个攻城狮要做的事

  • 一、消息中间件

    • 什么是消息系统

  • 二、RocketMq简介

    • 发展

    • 概念术语

    • 架构组成

  • 三、安装 RocketMq

    • 系统环境

    • 安装部署 RocketMQ

    • RocketMq插件(可视化)

  • 四、配置 RocketMq

    • 启动RocketMQ

    • 验证启动是否成功

    • 生产环境 ACL 权限认证

  • 五、RocketMq 集群

    • RocketMq 集群、拓展阅读

  • 六、SpringBoot 集成 RocketMq

  • 七、SpringMVC 架构中使用 Demo

  • 参考

一、消息中间件

什么是消息系统

简单来说:消息被发送到队列中。“消息队列”(Message Queue)是在消息的传输过程中保存消息的容器。

  • 拓展阅读

消息队列作为高并发系统的核心组件之一,能够帮助业务系统解构提升开发效率和系统稳定性。主要具有以下优势:

削峰填谷(主要解决瞬时写压力大于应用服务能力导致消息丢失、系统奔溃等问题) 系统解耦(解决不同重要程度、不同能力级别系统之间依赖导致一死全死) 提升性能(当存在一对多调用时,可以发一条消息给消息系统,让消息系统通知相关系统) 蓄流压测(线上有些链路不好压测,可以通过堆积一定量消息再放开来压测) 目前主流的MQ主要是Rocketmq、kafka、Rabbitmq,Rocketmq相比于Rabbitmq、kafka具有主要优势特性有:

• 支持事务型消息(消息发送和DB操作保持两方的最终一致性,rabbitmq和kafka不支持) • 支持结合rocketmq的多个系统之间数据最终一致性(多方事务,二方事务是前提) • 支持18个级别的延迟消息(rabbitmq和kafka不支持) • 支持指定次数和时间间隔的失败消息重发(kafka不支持,rabbitmq需要手动确认) • 支持consumer端tag过滤,减少不必要的网络传输(rabbitmq和kafka不支持) • 支持重复消费(rabbitmq不支持,kafka支持)

二、RocketMq简介

官网地址:http://rocketmq.apache.org/

发展

阿里巴巴消息中间件起源于2001年的五彩石项目,Notify 在这期间应运而生,用于交易核心消息的流转。

至2010年,B2B开始大规模使用ActiveMQ作为消息内核,随着阿里业务的快速发展,急需一款支持顺序消息,拥有海量消息堆积能力的消息中间件,MetaQ 1.0在2011年诞生。

到2012年,MetaQ已经发展到了MetaQ 3.0,并抽象出了通用的消息引擎RocketMQ。随后,将RocketMQ进行了开源,阿里的消息中间件正式走入了公众的视野。

到2015年,RocketMQ已经经历了多年双十一的洗礼,在可用性、可靠性以及稳定性等方面都有出色的表现。与此同时,云计算大行其道,阿里消息中间件基于RocketMQ推出了Aliware MQ 1.0,开始为阿里云上成千上万家企业提供消息服务。

到今年,MetaQ在2016年双十一承载了万亿级消息的流转,跨越了一个新的里程碑,同时RocketMQ进入Apache 孵化。

RocketMQ可以保证严格的消息顺序

概念术语

Producer Group

标识发送同一类消息的Producer,通常发送逻辑一致。发送普通消息的时候,仅标识使用,并无特别用处。若事务消息,如果某条发送某条消息的producer-A宕机,使得事务消息一直处于PREPARED状态并超时,则broker会回查同一个group的其 他producer,确认这条消息应该commit还是rollback。但开源版本并不支持事务消息。

Consumer Group

标识一类Consumer的集合名称,这类Consumer通常消费一类消息,且消费逻辑一致。同一个Consumer Group下的各个实例将共同消费topic的消息,起到负载均衡的作用。

消费进度以Consumer Group为粒度管理,不同Consumer Group之间消费进度彼此不受影响,即消息A被Consumer Group1消费过,也会再给Consumer Group2消费。

注:RocketMQ要求同一个Consumer Group的消费者必须要拥有相同的注册信息,即必须要听一样的topic(并且tag也一样)。

Topic

标识一类消息的逻辑名字,消息的逻辑管理单位。无论消息生产还是消费,都需要指定Topic。

Tag

RocketMQ支持给在发送的时候给topic打tag,同一个topic的消息虽然逻辑管理是一样的。但是消费topic1的时候,如果你订阅的时候指定的是tagA,那么tagB的消息将不会投递。

Message Queue

简称Queue或Q。消息物理管理单位。一个Topic将有若干个Q。若Topic同时创建在不通的Broker,则不同的broker上都有若干Q,消息将物理地存储落在不同Broker结点上,具有水平扩展的能力。

无论生产者还是消费者,实际的生产和消费都是针对Q级别。例如Producer发送消息的时候,会预先选择(默认轮询)好该Topic下面的某一条Q地发送;Consumer消费的时候也会负载均衡地分配若干个Q,只拉取对应Q的消息。

每一条message queue均对应一个文件,这个文件存储了实际消息的索引信息。并且即使文件被删除,也能通过实际纯粹的消息文件(commit log)恢复回来。

Offset

RocketMQ中,有很多offset的概念。但通常我们只关心暴露到客户端的offset。一般我们不特指的话,就是指逻辑Message Queue下面的offset。

注:逻辑offset的概念在RocketMQ中字面意思实际上和真正的意思有一定差别,这点在设计上显得有点混乱。祥见下面的解释。

可以认为一条逻辑的message queue是无限长的数组。一条消息进来下标就会涨1,而这个数组的下标就是offset。

max offset

字面上可以理解为这是标识message queue中的max offset表示消息的最大offset。但是从源码上看,这个offset实际上是最新消息的offset+1,即:下一条消息的offset。

min offset:

标识现存在的最小offset。而由于消息存储一段时间后,消费会被物理地从磁盘删除,message queue的min offset也就对应增长。这意味着比min offset要小的那些消息已经不在broker上了,无法被消费。

consumer offset

字面上,可以理解为标记Consumer Group在一条逻辑Message Queue上,消息消费到哪里即消费进度。但从源码上看,这个数值是消费过的最新消费的消息offset+1,即实际上表示的是下次拉取的offset位置。

消费者拉取消息的时候需要指定offset,broker不主动推送消息, offset的消息返回给客户端。

consumer刚启动的时候会获取持久化的consumer offset,用以决定从哪里开始消费,consumer以此发起第一次请求。

每次消息消费成功后,这个offset在会先更新到内存,而后定时持久化。在集群消费模式下,会同步持久化到broker,而在广播模式下,则会持久化到本地文件。

架构组成

a5c88ab583dbae3a7503209eb2b35415.png
RocketMQ集群部署

三、安装 RocketMq

系统环境

JDK8 Windows10

安装部署 RocketMQ

  1. 下载

地址:http://rocketmq.apache.org/release_notes/release-notes-4.3.0/rocketmq-all-4.3.0-bin-release.zip

选择 Binary 进行下载

  1. 解压

  2. 环境变量配置

必须配置

变量名:ROCKETMQ_HOME 变量值(绝对路径):D:\rocketMq\rocketmq-all-4.3.0-bin-release

环境变量 Path 中也配置:%ROCKETMQ_HOME%\bin

RocketMq插件(可视化)

选择性安装

  1. 下载

git clone https://github.com/apache/rocketmq-externals.git

  1. 解压

  2. 修改配置

server.contextPath=
server.port=8088
#spring.application.index=true
spring.application.name=rocketmq-console
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true
logging.config=classpath:logback.xml
#if this value is empty,use env value rocketmq.config.namesrvAddr NAMESRV_ADDR | now, you can set it in ops page.default localhost:9876
rocketmq.config.namesrvAddr=127.0.0.1:9876
#if you use rocketmq version < 3.5.8, rocketmq.config.isVIPChannel should be false.default true
rocketmq.config.isVIPChannel=
#rocketmq-console's data path:dashboard/monitor
rocketmq.config.dataPath=/tmp/rocketmq-console/data
#set it false if you don't want use dashboard.default true
rocketmq.config.enableDashBoardCollect=true
  1. 编译

cd  \rocketmq-externals\rocketmq-console

mvn clean package -Dmaven.test.skip=true

  1. 启动

cd  \rocketmq-externals\rocketmq-console\target

java -jar rocketmq-console-ng-2.0.0.jar

  1. 启动成功

浏览器访问:http://127.0.0.1:8088

四、配置 RocketMq

启动RocketMQ

默认配置启动

  • 启动

启动NAMESERVER:

Cmd命令框执行进入至‘MQ文件夹\bin’下,然后执行‘start mqnamesrv.cmd’,启动NAMESERVER。成功后会弹出提示框,此框勿关闭。

启动BROKER:

Cmd命令框执行进入至‘MQ文件夹\bin’下,然后执行‘start mqbroker.cmd -n 127.0.0.1:9876 autoCreateTopicEnable=true’,启动BROKER。成功后会弹出提示框,此框勿关闭。

验证启动是否成功

验证生产消息正常

执行如下命令:

export NAMESRV_ADDR=localhost:9876 sh bin/tools.sh org.apache.rocketmq.example.quickstart.Producer

能看到类似如下输出:

SendResult [sendStatus=SEND_OK, msgId=C0A82BC5F36C511D50C05B41...

验证消费消息正常

执行如下命令:

sh bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer

能看到类似如下输出:

ConsumeMessageThread_4 Receive New Messages: [MessageExt [queueId=3, stor....

其他命令

RocketMQ 自带的连接工具是 maadmin ,执行 mqadmin.cmd 就可以查看有哪些命令参数可用。

$ mqadmin.cmd
The most commonly used mqadmin commands are:
   updateTopic          Update or create topic
   deleteTopic          Delete topic from broker and NameServer.
   updateSubGroup       Update or create subscription group
   deleteSubGroup       Delete subscription group from broker.
   updateBrokerConfig   Update broker's config
   updateTopicPerm      Update topic perm
   topicRoute           Examine topic route info
   topicStatus          Examine topic Status info
   topicClusterList     get cluster info for topic
   brokerStatus         Fetch broker runtime status data
   queryMsgById         Query Message by Id
   queryMsgByKey        Query Message by Key
   queryMsgByUniqueKey  Query Message by Unique key
   queryMsgByOffset     Query Message by offset
   queryMsgByUniqueKey  Query Message by Unique key
   printMsg             Print Message Detail
   printMsgByQueue      Print Message Detail
   sendMsgStatus        send msg to broker.
   brokerConsumeStats   Fetch broker consume stats data
   producerConnection   Query producer's socket connection and client version
   consumerConnection   Query consumer's socket connection, client version and subscription
   consumerProgress     Query consumers's progress, speed
   consumerStatus       Query consumer's internal data structure
   cloneGroupOffset     clone offset from other group.
   clusterList          List all of clusters
   topicList            Fetch all topic list from name server
   updateKvConfig       Create or update KV config.
   deleteKvConfig       Delete KV config.
   wipeWritePerm        Wipe write perm of broker in all name server
   resetOffsetByTime    Reset consumer offset by timestamp(without client restart).
   updateOrderConf      Create or update or delete order conf
   cleanExpiredCQ       Clean expired ConsumeQueue on broker.
   cleanUnusedTopic     Clean unused topic on broker.
   startMonitoring      Start Monitoring
   statsAll             Topic and Consumer tps stats
   allocateMQ           Allocate MQ
   checkMsgSendRT       check message send response time
   clusterRT            List All clusters Message Send RT
   getNamesrvConfig     Get configs of name server.
   updateNamesrvConfig  Update configs of name server.
   getBrokerConfig      Get broker config by cluster or special broker!
   queryCq              Query cq command.
   sendMessage          Send a message
   consumeMessage       Consume message
See 'mqadmin help <command>' for more information on a specific command.
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=128m; support was removed in 8.0
Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=128m; support was removed in 8.0

启动成功后先简单执行一个命令(在 linux 上去掉 .cmd 即可)

  • 查询 topic 列表

mqadmin.cmd topicList -n '127.0.0.1:9876'

生产环境 ACL 权限认证

修改配置

使用默认配置,像上一节我们就可以启动成功。但是在生产环境中,我们一定要加权限认证

  1. 打开 aclEnable 开关

    在文件 conf/broker.conf 新增 aclEnable=true

  2. 新建文件 conf/plain_acl.yml,填入如下文本

globalWhiteRemoteAddresses:

accounts:
- accessKey: RocketMQ
  secretKey: 12345678
  whiteRemoteAddress:
  admin: false
  defaultTopicPerm: DENY
  defaultGroupPerm: SUB
  topicPerms:
  - TopicTest=PUB
  groupPerms:
  # the group should convert to retry topic
  - oms_consumer_group=DENY

- accessKey: admin
  secretKey: 12345678
  whiteRemoteAddress:
  # if it is admin, it could access all resources
  admin: true 
  1. 重启 RocketMQ

start mqnamesrv.cmd

start mqbroker.cmd -n 127.0.0.1:9876 autoCreateTopicEnable=true

名词介绍

globalWhiteRemoteAddresses

全局白名单,其类型为数组,即支持多个配置。其支持的配置格式如下:

空 表示不设置白名单,该条规则默认返回false。“” 表示全部匹配,该条规则直接返回true,将会阻断其他规则的判断,请慎重使用。192.168.0.{100,101} 多地址配置模式,ip地址的最后一组,使用{},大括号中多个ip地址,用英文逗号(,)隔开。192.168.1.100,192.168.2.100 直接使用,分隔,配置多个ip地址。192.168..或192.168.100-200.10-20 每个IP段使用 "" 或"-"表示范围。

accounts

配置用户信息,该类型为数组类型。拥有accessKey、secretKey、whiteRemoteAddress、admin、defaultTopicPerm、defaultGroupPerm、topicPerms、groupPerms子元素。

  1. accessKey 登录用户名,长度必须大于6个字符。

  2. secretKey 登录密码。长度必须大于6个字符。

  3. whiteRemoteAddress 用户级别的IP地址白名单。其类型为一个字符串,其配置规则与globalWhiteRemoteAddresses,但只能配置一条规则。

  4. admin boolean类型,设置是否是admin。如下权限只有admin=true时才有权限执行。

UPDATE_AND_CREATE_TOPIC 更新或创建主题。UPDATE_BROKER_CONFIG 更新Broker配置。DELETE_TOPIC_IN_BROKER 删除主题。UPDATE_AND_CREATE_SUBSCRIPTIONGROUP 更新或创建订阅组信息。DELETE_SUBSCRIPTIONGROUP 删除订阅组信息。5. defaultTopicPerm 默认topic权限。该值默认为DENY(拒绝)。

  1. defaultGroupPerm 默认消费组权限,该值默认为DENY(拒绝),建议值为SUB。

  2. topicPerms 设置topic的权限。其类型为数组,其可选择值在下节介绍。

  3. groupPerms 设置消费组的权限。其类型为数组,其可选择值在下节介绍。可以为每一消费组配置不一样的权限。

五、RocketMq 集群

RocketMq 集群、拓展阅读

参考:https://www.jianshu.com/p/2838890f3284ad1d1e880e128e7811bf06e257b63402.png

六、SpringBoot 集成 RocketMq

代码会同步到 GitHub,回复github领取

七、SpringMVC 架构中使用 Demo

参考

安装部署参考博客:https://www.imooc.com/article/290089

完整中文参考文章:http://www.itmuch.com/books/rocketmq/operation.html

阿里文档参考:https://help.aliyun.com/document_detail/29533.html

我是pub哥,Java服务端工程师,对大数据懂一点,三观要正。我们下期再见

财经相关:

最近几天白酒、半导体、新能源都在上涨,应该有很多被洗人,投资建议,有持仓的韭菜,下跌再抛出。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574833.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android京东首页轮播代码,仿京东商品详情轮播图

好久没有更新啦,今天来搞一个京东的轮播:直接上效果8月-16-2016 09-38-10.gif8月-16-2016 09-37-17.gif如果想真实体验可以去京东APP体验一下.描述一下效果,向左滑动时,右边的图片从底下出来 而且是一半的位置同理向右滑动也是 .那么怎么实现呢先搞一个collectionview 做一个不…

对数据库连接池的理解

对数据库连接池的理解&#xff1a; java操作数据库需要使用JDBC来进行操作&#xff0c;每次操作需要获取和数据库的一个连接&#xff0c;并在连接中进行操作。但是&#xff0c;频繁的打开链接&#xff0c;关闭连接势必对系统性能造成消耗。所以&#xff0c;把获取连接与对连接的…

群晖如何建php网站_群晖建博客详细教程

群晖NAS功能强大&#xff0c;除了大家都知道的存储文件&#xff0c;代替各种公有云以外&#xff0c;还可以当成一个网站服务器来使用。配合DDNS和国际域名&#xff0c;可以实现与在网上购买的专业虚拟主机一样的功能&#xff0c;甚至更强大&#xff0c;因为空间无限大&#xff…

android 触摸防抖,一种触摸屏防抖优化方法、系统及触摸屏终端与流程

本发明涉及触摸屏技术领域&#xff0c;尤其涉及一种触摸屏防抖优化方法、系统及触摸屏终端。背景技术&#xff1a;随着电子信息产业的快速发展&#xff0c;触摸屏作为具有人机交互功能的智能产品&#xff0c;应用面极为广泛&#xff0c;但其存在着较多的触摸抖动问题。现有的去…

C#.NET 大型企业信息化系统集成快速开发平台 4.2 版本 - 基于数据库资源的多语言实现...

以前的开发平台里&#xff0c;是用xml语言包实现了多语言功能&#xff0c;现在新的平台里进行了调整&#xff0c;把多语言包资源放在数据库表里实现了。 我们系统预留了多语言的配置全局变量、可以通过配置这个参数达到切换多语言的目的 我们在选项管理里增加一个多语言选择的选…

手机投屏不是全屏怎么办_手机投屏怎么满屏

手机投屏是很多小伙伴们都喜欢玩的&#xff0c;不少小伙伴们小伙伴们在使用手机投屏的时候发现不能满屏&#xff0c;想要知道方法的小伙伴们&#xff0c;就让小编给大家详细的讲讲满屏方法吧。手机投屏怎么满屏1、手机具有投屏的功能。目前大多数手机都已经具备发无线投屏的功能…

android开发ui插件下载,TKUISDK-ANDROID

更新记录4.3.4(2021-04-29)1、修改请求权限在进入教室后 需删除之前版本的请求权限代码,并添加 权限请求回调代码 详见文档进入教室 2.4.1.12 新增旁听生身份3 新增大班课红包功能4 修复已知bug4.3.0(2021-04-01)1、一对一教室pad端“视频居左/居右”可拖拽改变课件区、视频区比…

C语言第一节 C语言程序与开发工具

开发工具的选择 可以用来写代码的工具&#xff1a;记事本、UltraEdit、Vim、Xcode等 选择Xcode的原因&#xff1a;苹果官方提供的开发利器、简化开发过程、有高亮显示功能 使用Xcode新建一个C程序的源代码文件&#xff08;拓展名为.c或者.C&#xff09; 打开Xcode 新建文件 选择…

android 关机闹钟 实现,安卓关机闹钟:你所不知道的关机闹钟的背后

可以通过其他方式实现关机闹钟事实上大家也大可不必抱怨Android手机或者是iPhone的固执做法&#xff0c;因为目前在Android手机当中&#xff0c;全新的“明”系列摩托罗拉A1680就已经支持关机闹钟了&#xff0c;这就更加说明了该功能和系统无关。而苹果iPhone也可以通过一些非常…

flux读取不到数据_初学flux的疑问?无法添加数据到DOM

我初学flux,照着网上的代码&#xff0c;尝试学习写了一个简单的添加数据表页面&#xff0c;如图&#xff1a;我想实现的功能是在下方表单填写数据之后点击提交可以实时的在上方表格添加一条数据&#xff0c;现在碰到的问题是我点击提交毫无反应也没有报错。我的架构是这个样子的…

列表视图

列表视图 分类&#xff1a; SharePoint入门2014-10-14 00:10 298人阅读 评论(0) 收藏 举报SharePointlist view使用View&#xff0c;可以按照特定的要求和条件展示List/Library里面的条目。View可以做一下设定来显示数据&#xff1a; 1. 显示哪些属性(column) 2. 属性…

android 线程 界面,android开发教程之子线程中更新界面

每个Handler对象与创建它的线程相关联&#xff0c;并且每个Handler对象只能与一个线程相关联。Handler一般有两种用途&#xff1a;1)执行计划任务&#xff0c;你可以再预定的实现执行某些任务&#xff0c;可以模拟定时器。2)线程间通信。在Android的应用启动时&#xff0c;会创…

vue怎么让接口带上cookie_在Vue中如何使用Cookie操作实例

大家好&#xff0c;由于公司忙着赶项目&#xff0c;导致有段时间没有发布新文章了。今天我想跟大家谈谈Cookie的使用。同样&#xff0c;这个Cookie的使用方法是我从公司的项目中抽出来的&#xff0c;为了能让大家看懂&#xff0c;我会尽量写详细点。废话少说&#xff0c;我们直…

python 简历处理_按照这个方式学Python,老板把垃圾桶里的简历舔回来:月薪50000...

对于Python相信很多人都不陌生&#xff0c;相较于Excel、Tableau、PowerBI等普通的数据分析工具来说&#xff0c;Python的优势显然要大很多。Python有很多优点&#xff0c;如果你能很好的运用到工作中&#xff0c;会发现工作效率大大提升&#xff0c;涨薪也是再正常不过的事情。…

鸿蒙系统下载 绿色,PGWARE PcMedik

pcmedik&#xff0c;一款可以优化你的电脑&#xff0c;让pc发挥更大的性能&#xff0c;大大减少死机的事件。pcmedik操作简单&#xff0c;其优化过程只需三个步骤&#xff1a;①选择一个本机当前正在使用的操作系统。②选择本机使用的cpu类型。③点击&#xff3b;优化&#xff…

attr和prop区别

今天写了个小程序&#xff0c;获取input[checked]属性&#xff0c;$(#check1).attr(checked)&#xff0c;结果返回undefined&#xff0c;查询了一番&#xff0c; 如果是具有true和false两个属性值的属性 如checked selected 或者disabled获取该属性值要用prop()返回boolean值&a…

html5视频抓取,js和HTML5基于过滤器从摄像头中捕获视频的方法

这篇文章主要介绍了jsHTML5基于过滤器从摄像头中捕获视频的方法,涉及javascript基于html5元素操作多媒体的使用技巧,需要的朋友可以参考下本文实例讲述了jsHTML5基于过滤器从摄像头中捕获视频的方法。分享给大家供大家参考。具体如下&#xff1a;index.html页面&#xff1a;Nat…

Android Audio Play Out Channel

1: 7嘴8舌 扬声器, 耳机, 和听筒 就是通过: audiomanager.setmode(AudioManager.MODE_IN_COMMUNICATION)audiomanager.setSpeakerhponeOn(boolean value).这两个来设置.不过有的好像不支持的. 米手机上切换 扬声器和听筒不能切换 Android AudioTrack音频播放分析 音频资源在播…

c html转换成word,C#实现HTML转WORD及WORD转PDF的方法

本文实例讲述了C#实现HTML转WORD及WORD转PDF的方法。分享给大家供大家参考。具体如下&#xff1a;功能&#xff1a;实现HTML转WORD&#xff0c;WORD转PDF具体代码如下&#xff1a;using System;using System.Collections.Generic;using System.ComponentModel;using System.Dat…

bootstrap下拉框分页_【Bootstrap】 bootstrap-select2下拉菜单插件

这次开发了个小TRS系统&#xff0c;虽然是很小&#xff0c;但是作为初心者&#xff0c;第一次用到了很多看起来洋气使用起来有相对简单的各种前端(主要是和bootstrap配合使用)组件。包括bootstrap-select2&#xff0c;bootstrap-datetimepicker&#xff0c;bootstrap-fileinput…