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

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

mac安装redis全过程

《mac安装redis全过程》文章内容主要介绍了如何从官网下载指定版本的Redis,以及如何在自定义目录下安装和启动Redis,还提到了如何修改Redis的密码和配置文件,以及使用RedisInsig... 目录MAC安装Redis安装启动redis 配置redis 常用命令总结mac安装redis官网下

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Apache Tomcat服务器版本号隐藏的几种方法

《ApacheTomcat服务器版本号隐藏的几种方法》本文主要介绍了ApacheTomcat服务器版本号隐藏的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1. 隐藏HTTP响应头中的Server信息编辑 server.XML 文件2. 修China编程改错误