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

2023-10-09 05:20

本文主要是介绍Mac和Linux中Apache RocketMQ的安装和使用(亲测有效,不服来战),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、项目需要用到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.ProducerSendResult [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.ConsumerConsumeMessageThread_%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

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

这篇关于Mac和Linux中Apache RocketMQ的安装和使用(亲测有效,不服来战)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/170647

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u