Mac和Linux中Apache RocketMQ的安装和使用(亲测有效,不服来战)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 一、项目需要用到Apache RocketMQ Apache RocketMQ™ is an open source distributed messaging and streaming data platform. 这是阿里开源的一个消息中间件框架。

一、项目需要用到Apache RocketMQ
Apache RocketMQ™ is an open source distributed messaging and streaming data platform.
这是阿里开源的一个消息中间件框架。
官网:官网

二、下面来快速开始
官方的快速开始文档

三、系统要求
The following softwares are assumed installed:
64bit OS, Linux/Unix/Mac is recommended;
64bit JDK 1.8+;
Maven 3.2.x
Git

四、先要去下载安装包
安装包网址

五、点击这个下载
这里写图片描述

六、解压

unzip rocketmq-all-4.2.0-source-release.zip

七、进入到项目目录下

 cd rocketmq-all-4.2.0/

八、执行安装的操作

~/aliSpace/recketmq/rocketmq-all-4.2.014:20:14
$ mvn -Prelease-all -DskipTests clean install -U
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Detecting the operating system and CPU architecture
[INFO] ------------------------------------------------------------------------
[INFO] os.detected.name: osx
[INFO] os.detected.arch: x86_64
[INFO] os.detected.classifier: osx-x86_64
......
[INFO] rocketmq-distribution 4.2.0 ........................ SUCCESS [  4.717 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 28.456 s
[INFO] Finished at: 2018-04-09T14:21:40+08:00
[INFO] Final Memory: 85M/1608M
[INFO] ------------------------------------------------------------------------

九、安装完成后是这个样子

~/aliSpace/recketmq/rocketmq-all-4.2.014:21:41
$ ls
1                        client                   openmessaging
BUILDING                 common                   pom.xml
CONTRIBUTING.md          dev                      remoting
DEPENDENCIES             distribution             srvutil
LICENSE                  example                  store
NOTICE                   filter                   style
PULL_REQUEST_TEMPLATE.md filtersrv                target
README.md                logappender              test
broker                   namesrv                  tools

十、进入到启动文件所在的目录

~/aliSpace/recketmq/rocketmq-all-4.2.014:56:26
$ cd distribution/target/apache-rocketmq
 ~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq14:57:34
$ ls
LICENSE   NOTICE    README.md benchmark bin       conf      lib

十一、启动服务器,查看输出日志

启动服务器
~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:00:25
$ nohup sh bin/mqnamesrv &
查看启动日志
~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:00:44
$ tail -f ~/logs/rocketmqlogs/namesrv.log
2018-04-09 15:00:37 INFO main - tls.server.trustCertPath = null
2018-04-09 15:00:37 INFO main - tls.client.keyPath = null
2018-04-09 15:00:37 INFO main - tls.client.keyPassword = null
2018-04-09 15:00:37 INFO main - tls.client.certPath = null
2018-04-09 15:00:37 INFO main - tls.client.authServer = false
2018-04-09 15:00:37 INFO main - tls.client.trustCertPath = null
2018-04-09 15:00:37 INFO main - Using OpenSSL provider
2018-04-09 15:00:37 INFO main - SSLContext created for server
2018-04-09 15:00:37 INFO NettyEventExecutor - NettyEventExecutor service started
2018-04-09 15:00:37 INFO main - The Name Server boot success. serializeType=JSON
2018-04-09 15:01:37 INFO NSScheduledThread1 - --------------------------------------------------------
2018-04-09 15:01:37 INFO NSScheduledThread1 - configTable SIZE: 0

十二、启动经纪人,查看经纪人的启动日志

启动经纪人人
~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:02:57
$ nohup sh bin/mqbroker -n localhost:9876 &
[1] 2196
appending output to nohup.out     
查看经纪人的启动日志
~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:03:15
$ tail -f ~/logs/rocketmqlogs/broker.log
2018-04-09 15:03:21 INFO main - load /Users/wangdong/store/config/consumerFilter.json OK
2018-04-09 15:03:21 INFO main - load /Users/wangdong/store/config/delayOffset.json OK
2018-04-09 15:03:21 INFO main - Set user specified name server address: localhost:9876
2018-04-09 15:03:21 INFO PullRequestHoldService - PullRequestHoldService service started
2018-04-09 15:03:21 INFO main - register broker to name server localhost:9876 OK
2018-04-09 15:03:21 INFO main - The broker[wdMac.local, 192.168.33.204:10911] boot success. serializeType=JSON and name server is localhost:9876

十三、发送或者接收消息
Before sending/receiving messages, we need to tell clients the location of name servers. RocketMQ provides multiple ways to achieve this. For simplicity, we use environment variable NAMESRV_ADDR
译:在发送/接收消息前,我们需要告诉客户端:消息服务器的地址:端口(本地的话可以用localhost:端口)。RocketMQ提供多种方式来实现它。
1.下面我们以命令行设置NAMESRV_ADDR的方式来实现它。

注意需要进入到mq目录下:

~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:17:31
$ export NAMESRV_ADDR=localhost:9876

2.发送一条消息

~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:26:44
$ sh bin/tools.sh org.apache.rocketmq.example.quickstart.Producer
 SendResult [sendStatus=SEND_OK, msgId= ...

3.接收消息

~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:26:44
$ sh bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer
 ConsumeMessageThread_%d Receive New Messages: [MessageExt...

十四、关闭服务器和经纪人

关闭服务器
~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:25:25
$ sh bin/mqshutdown namesrv
The mqnamesrv(2083) is running...
Send shutdown request to mqnamesrv(2083) OK
关闭经纪人
~/aliSpace/recketmq/rocketmq-all-4.2.0/distribution/target/apache-rocketmq ⌚ 15:29:53
$ sh bin/mqshutdown broker
The mqbroker(2207) is running...
Send shutdown request to mqbroker(2207) OK

好了,一个简单的开始就结束了

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
4月前
|
消息中间件 人工智能 Apache
Apache RocketMQ 中文社区全新升级!
RocketMQ 中文社区升级发布只是起点,我们将持续优化体验细节,推出更多功能和服务,更重要的是提供更多全面、深度、高质量的内容。
578 16
|
3月前
|
消息中间件 监控 数据挖掘
基于RabbitMQ与Apache Flink构建实时分析系统
【8月更文第28天】本文将介绍如何利用RabbitMQ作为数据源,结合Apache Flink进行实时数据分析。我们将构建一个简单的实时分析系统,该系统能够接收来自不同来源的数据,对数据进行实时处理,并将结果输出到另一个队列或存储系统中。
233 2
|
5月前
|
消息中间件 安全 API
《阿里云产品四月刊》—Apache RocketMQ ACL 2.0 全新升级(1)
阿里云瑶池数据库云原生化和一体化产品能力升级,多款产品更新迭代
301 1
《阿里云产品四月刊》—Apache RocketMQ ACL 2.0 全新升级(1)
|
3月前
|
Ubuntu Java 应用服务中间件
如何通过 Apt-Get 在 Ubuntu 14.04 上安装 Apache Tomcat 7
如何通过 Apt-Get 在 Ubuntu 14.04 上安装 Apache Tomcat 7
95 0
|
3月前
|
消息中间件 Ubuntu Java
在Ubuntu 18.04上安装Apache Kafka的方法
在Ubuntu 18.04上安装Apache Kafka的方法
190 0
|
22天前
|
消息中间件 Ubuntu Java
Ubuntu系统上安装Apache Kafka
Ubuntu系统上安装Apache Kafka
|
1月前
|
Ubuntu 网络安全 Apache
Ubuntu下安装Apache2.4.7遇到的问题及解决办法
Ubuntu下安装Apache2.4.7遇到的问题及解决办法
|
4月前
|
消息中间件 安全 API
Apache RocketMQ ACL 2.0 全新升级
RocketMQ 作为一款流行的分布式消息中间件,被广泛应用于各种大型分布式系统和微服务中,承担着异步通信、系统解耦、削峰填谷和消息通知等重要的角色。随着技术的演进和业务规模的扩大,安全相关的挑战日益突出,消息系统的访问控制也变得尤为重要。然而,RocketMQ 现有的 ACL 1.0 版本已经无法满足未来的发展。因此,我们推出了 RocketMQ ACL 2.0 升级版,进一步提升 RocketMQ 数据的安全性。本文将介绍 RocketMQ ACL 2.0 的新特性、工作原理,以及相关的配置和实践。
13645 7
|
3月前
|
Ubuntu 关系型数据库 MySQL
在 Ubuntu 14.04 服务器上使用 Apache 安装 Drupal 的方法
在 Ubuntu 14.04 服务器上使用 Apache 安装 Drupal 的方法
41 0
|
3月前
|
存储 缓存 Ubuntu
如何在 Apache Web 服务器中安装、配置和使用模块
如何在 Apache Web 服务器中安装、配置和使用模块
84 0