RocketMQ快速实战之单机启动

废话不多说,直接上干货!!!

1、下载RocketMQ4.7.1版本

RocketMQ运行版本下载地址:https://www.apache.org/dyn/closer.cgi?path=rocketmq/4.7.1/rocketmq-all-4.7.1-bin-release.zip

2、快速安装RocketMQ 

2.1、准备一台CentOS7的linux机器,我的linux版本如下: 

2.2、用root用户创建一个用户,并给它创建一个工作目录,用来运行自己的程序。

#useradd kunlin

#passwd kunlin

#mkdir /app

#chown kunlin:kunlin /app

2.3、如果没有安装JDK,要先安装JDK,我安装的是JDK1.8,可以自行去Oracle官网上下载 。用kunlin用户解压到/app/jdk1.8目录下。

2.4、配置环境变量。使用vi ~/.bash_profile编辑文件,加入以下内容:

export JAVA_HOME=/app/jdk1.8/
PATH=$JAVA_HOME/bin:$PATH:$HOME/.local/bin:$HOME/bin
export PATH

2.5、编辑完成后,执行source ~/.bash_profile让环境变量生效。输入java -version能查看到以下内容表明JDK安装成功了。 

 2.6、把下载的rocketmq-all-4.7.1-bin-release.zip在本地完成解压,并上传到/app/rocketmq目录。然后把rocketmq的bin目录也配置到环境变量当中。vi ~/.bash_profile,加入以下内容,并执行source ~/.bash_profile让环境变量生效:

export JAVA_HOME=/app/jdk1.8/
export ROCKETMQ_HOME=/app/rocketmq/rocketmq-all-4.7.1-bin-release
PATH=$ROCKETMQ_HOME/bin:$JAVA_HOME/bin:$PATH:$HOME/.local/bin:$HOME/bin
export PATH

 这样RocketMQ就安装完成了,下面赶紧运行起来吧!

3、快速运行RocketMQ

3.1、启动 NameServer

启动NameServer非常简单, 在$ROCKETMQ_HOME/bin目录下有个mqadminsrv。直接执行这个脚本就可以启动RocketMQ的NameServer服务。

但是要注意,RocketMQ默认预设的JVM内存是4G,这是RocketMQ给我们的最佳配置。但是通常我们用虚拟机的话都用不到4G内存,所以需要调整下JVM内存大小。修改的方式是直接修改runserver.sh。 用vi runserver.sh编辑这个脚本,在脚本中找到这一行调整内存大小为512M。

JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

然后我们用静默启动的方式启动NameServer服务:nohup bin/mqnamesrv &

启动完成后,在nohup.out里看到这一条关键日志就是启动成功了。并且使用jps指令可以看到有一个 NamesrvStartup进程。 

3.2 启动Broker 

启动Broker的脚本是runbroker.sh。Broker的默认预设内存是8G,启动前,如果内存不够,同样需要调整下JVM内存。vi runbroker.sh,找到这一行,进行内存调整 :

JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m"

然后我们需要找到$ROCKETMQ_HOME/conf/broker.conf,vi指令进行编辑,在最下面加入一个配置:autoCreateTopicEnable=true

然后也以静默启动的方式启动runbroker.sh:nohup sh ./mqbroker -n localhost:9876 &

启动完成后,同样是检查nohup.out日志,有这一条关键日志就标识启动成功了。 并且jps指令可以 看到一个BrokerStartup进程。

3.3 命令行快速验证 

在RocketMQ的安装包中,提供了一个tools.sh工具可以用来在命令行快速验证RocketMQ服务。我们重新开启一个命令窗口进入RocketMQ的安装目录。

首先需要配置一个环境变量NAMESRV_ADDR指向我们启动的NameServer服务:

export NAMESRV_ADDR='localhost:9876'

然后启动消息生产者发送消息:默认会发1000条消息:

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

我们可以看到发送消息的日志,上面部分就是我们发送的消息的内容,后面两句标识消息生产者正常关闭:

然后启动消息消费者接收消息:

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

启动后,可以看到消费到的消息:

日志中MessageExt后的整个内容就是一条完整的RocketMQ消息。我们要对这个消息的结构有个 大概的了解,其中比较关键的属性有:brokerName,queueId,msgId,topic,cluster,tags,body, transactionId,后面会对这个消息进行深入的理解。

这个Consume指令并不会结束,他会继续挂起,等待消费其他的消息。我们可以使用CTRL+C停止该进程。

3.4 关闭RocketMQ服务

# 1.关闭NameServer

sh bin/mqshutdown namesrv

# 2.关闭Broker

sh bin/mqshutdown broker

总结:以上就是RocketMQ单机启动的过程,后面会继续更新RocketMQ集群架构搭建!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RocketMQ是一个开源的分布式消息中间件,具有高吞吐量、高可用性和可伸缩性的特点。它是由阿里巴巴集团开发和维护的,被广泛应用于大规模分布式系统中。 在实战中,使用RocketMQ可以实现消息的可靠传输和异步通信,适用于各种场景,如订单处理、日志收集、实时数据同步等。以下是一些RocketMQ实战应用场景和操作步骤: 1. 安装和配置RocketMQ:首先需要下载和安装RocketMQ,然后进行相关的配置,包括名称服务器(NameServer)和消息代理(Broker)的配置。 2. 创建Topic和Producer:在RocketMQ中,消息通过Topic进行分类,Producer负责发送消息到指定的Topic。可以使用命令行工具或者编程方式创建Topic和Producer。 3. 创建Consumer和订阅Topic:Consumer负责订阅指定的Topic,并处理接收到的消息。可以使用命令行工具或者编程方式创建Consumer,并订阅感兴趣的Topic。 4. 发送和接收消息:通过Producer发送消息到指定的Topic,Consumer订阅该Topic并接收消息进行处理。可以使用RocketMQ提供的API进行消息的发送和接收操作。 5. 实现消息的可靠性传输:RocketMQ可以保证消息的可靠性传输,即使在发送或接收过程中出现异常,也能够保证消息不丢失。可以通过配置参数和使用事务消息等方式来实现可靠性传输。 6. 监控和管理RocketMQRocketMQ提供了一系列的监控和管理工具,可以对消息的发送和接收进行监控,以及管理Topic和Consumer等。 以上是RocketMQ的简单实战应用场景和操作步骤,希望对你有所帮助。详细的使用方法和更多高级功能可以参考RocketMQ的官方文档和示例代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值