RocketMq灰皮书(二)------本地部署启动MQ

Windows10本地部署RocketMQ

在上一篇文章中,我们对rocket的几个基本概念进行了介绍,也了解了业内几大消息中间件的区别.在本篇博文中,我们进行RocketMQ的本地部署.



1. 下载安装

首先我们可以去RocketMQ的官网去下载源码: 官网点这里

打开官网可以看到很精美的概述,我们需要了解的地方有2个,都在上图中标记了出来:

  1. Documentation 关于rocket使用的文档介绍
  2. Blog 社区的更新博文

简单的来说,如果你想了解早期的mq的更新文档,可以去Blog页面,它大概是这样的:

Blog页面,按照时间显示了每次MQ相关的更新发布公告,类似于LOL官网日常公告.-_-||

我们看到图中有两种文章:

  1. Release Notes - Apache RocketMQ Spring - Version 2.2.0
  2. Release Notes - Apache RocketMQ - Version 4.8.0
Apache RocketMQ Spring

作为一名合格的Java开发(摸鱼)工程师,我们看一眼就知道,Apache RocketMQ Spring版本代表的是RocketMQ整合Spring框架提供的发行包,点进去具体看到有个Quick Start ,再点进去会跳转到github基友社区,并且我们看到了其提供的基于SpringBootmaven依赖:

<!--add dependency in pom.xml-->
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>${RELEASE.VERSION}</version>
</dependency>

因此,我们可以很方便的在项目中集成RocketMQ进行开发,后面我们的demo会使用这个依赖快速实现.

Apache RocketMQ

说白了,上面的那个rocketmq-spring-boot-starter只是用来合Spring的,真正的RocketMQ其实是Apache RocketMQ里面介绍的东西. 他里面也很清楚地介绍了如何下载并启动RocketMQ

图中上面介绍了RocketMQ快速搭建的步骤,点击快速开始按照步骤即可,下方是其下载链接,其中Source是源代码,Binary是二进制发行版.

这次我们只是为了在本地运行起来,然后简单的写个demo,就直接使用Binary版本即可,点击下载,

然后我们打开Quick Start,看一下相关的启动介绍.


2. 环境准备

Quick Start页面,我们发现RocketMQ的详细文章也有中文版,这样看来当前国内很多公司之所以使用RocketMQ来作为消息中间件不是没有原因的.

RocketMQ的运行环境有以下规定:

  • 64位的系统内核

    不管你是用Linux还是Windows

  • 64位的JDK 1.8+

  • Maven3.2.x

    maven版本也有要求

  • Git

  • 4g+ free disk for Broker server

    这里需要注意了,RocketMQ运行Broker server需要至少4G的空闲磁盘,我们需要关注的不是这占用的磁盘空间,而是后面的Broker server! 在上篇文章中我们说过,每个运行在机器上的RocketMQ称为Broker,当时说的broker就是这里的Broker server

根据以上的环境要求,我们可以检查一下各自的环境是否符合,我这里用的maven版本是3.3.9

而在Quick Start页面中,也详细介绍了再Linux系统和Windows系统下不同的启动方式,我们可以按照步骤依次进行,不得不说这官方文档写的非常详细了.


3. 配置环境变量&运行RocketMQ
  1. 解压我们下载好的RocketMQ的压缩包,在这里我是放在了D盘下

  2. 配置环境变量

    ROCKETMQ_HOME="D:\rocketmq"
    NAMESRV_ADDR="localhost:9876"

  3. 启动Name Server

    在这里我们又看到一个新概念Name Server,暂且不去管它,我们先运行起来.

    进入MQ解压后的目录,即:ROCKETMQ_HOME/bin目录,按住Shift键后鼠标右键即可打开PowerShell命令窗口,运行Name Server的启动命令:

    .\mqnamesrv.cmd

    可以看到启动成功了

    注意此时不能关闭命令行窗口,关闭以后会直接关闭Name Server

  4. 启动Broker

    用同样的方式打开PowerShell窗口,运行命令:

    .\mqbroker.cmd -n localhost:9876 autoCreateTopicEnable=true

    -n 指定broker连接的nameServer的地址和端口号

    autoCreateTopicEnable参数见名知意,打开自动创建Topic

    启动成功如下:

    同样不能关闭此窗口

到这里,我们本地的RocketMQ启动完成


4. 安装rocketmq-console验证运行情况

按照上面的步骤,我们在本地成功启动了RocketMQ,那么我们怎么验证呢?

RocketMQ提供了强大的后台管理组件来管理发送到MQ的消息,这个组件就是rocketmq-console

a. rocketmq-externals

在了解rocketmq-console之前,我们先来说一下rocketmq-externals,除了rocketmq本身之外,rocketmq有个改进改进方案,其中包括了很多扩展的项目,比如rocketmq的Go版本的客户端,Python版本的客户端,集成Flink的插件等,这些扩展的项目全部整合在rocketmq-externals项目中,而我们的rocketmq-console就是其中之一.

b. rocketmq-console

rocketmq-console是使用springboot设计的rocketMq的后台系统,有了它,我们可以很方便的在Web页面上管理RocketMQ的消息,topic等,接下来我们来安装运行rocketmq-console.

  • 首先我们下载rocketmq-externals的源码到本地,地址是: https://github.com/apache/rocketmq-externals.git,下载完成后IDE打开,可以看到里面有很多的项目

  • 修改rocketmq-consoleapplication.rpoperties配置文件

    #指定连接的nameServer的地址和端口号
    rocketmq.config.namesrvAddr=127.0.0.1:9876
  • 启动rocketmq-console

    直接通过maven命令编译打包rocketmq-console项目,这样会打出来一个jar包在target目录下,然后直接用java命令运行该jar包就可以了

    在这里我们就直接通过IDEA运行,不用那么麻烦

    找到主启动类,运行run方法即可,等待启动成功我们就可以再浏览器打开后台页面了,默认的启动地址是http://localhost:8080

    有关rocketmq-console的详细使用,这里就不说了,需要了解的可以查阅官方手册,地址如下:手册


结语:

在这里,之所以在本地部署一次,其实是为了后续的demo使用mq,其二是了解MQ的启动过程和每一个组件,也能在后面帮助我们了解其运行原理和架构原理.

个人公众号<橙耘自留地>日前已经开通,后续博主发布的文章都会一并更新到公众号,如有需要,自行查阅.

关于橙耘自留地,是我个人聚焦互联网技术栈学习分享的一个平台,创立之初是因为目前业内各种技术课程资料层次不齐,褒贬不一,有时候一门课花费高价买入,其实内含草包,有时偶尔低价得之,却又大有干货.因此我会根据大家的意见和评价,选择不同的技术栈去学习,一为提升我自己的技术,二为大家梳理出质量比较好的课程,以作参考.同时,相关的学习心得也会一并更新到博客和公众号.

RocketMq灰皮书(二)------本地部署启动MQ的更多相关文章

  1. RocketMq灰皮书(三)------MQ使用

    RocketMq灰皮书(三)------MQ使用 在使用MQ之前,我们回顾一下前两篇博文的内容. 我们大致了解了RocketMQ的四个概念,分别是:Producer,Consumer,Message和 ...

  2. RocketMq灰皮书(一)------选型&RocketMQ名词

    RocketMq灰皮书(一)------选型&RocketMQ名词 一. MQ选型对比 目前业内常用的MQ框架有一下几种: Kafka RabbitMQ RocketMQ 除此之外,还有Act ...

  3. Kubernetes 学习笔记(二):本地部署一个 kubernetes 集群

    前言 前面用到过的 minikube 只是一个单节点的 k8s 集群,这对于学习而言是不够的.我们需要有一个多节点集群,才能用到各种调度/监控功能.而且单节点只能是一个加引号的"集群&quo ...

  4. WIN8+VS2013编写发布WCF之二(部署)

    上文简介了如何建立WCF工程并且调试,下面说一下如何部署. 本文将陆陆续续讲述三种部署方式,随着项目的进展将不断补全. 声明: 用管理员身份打开VS2013,发布前请将程序的.net版本改成与服务器相 ...

  5. RocketMQ 简单梳理 及 集群部署笔记【转】

    一.RocketMQ 基础知识介绍Apache RocketMQ是阿里开源的一款高性能.高吞吐量.队列模型的消息中间件的分布式消息中间件. 上图是一个典型的消息中间件收发消息的模型,RocketMQ也 ...

  6. RocketMQ 简单梳理 及 集群部署笔记

    一.RocketMQ 基础知识介绍Apache RocketMQ是阿里开源的一款高性能.高吞吐量.队列模型的消息中间件的分布式消息中间件. 上图是一个典型的消息中间件收发消息的模型,RocketMQ也 ...

  7. WIN8+VS2013编写发布WCF、一(编写)、二(部署)、三(调用)

    原文://http://www.cnblogs.com/tntboom/p/4348483.html 引言:上学期因为写服务器用WCF,所以连查资料再瞎调试勉强成功了,但是这学期又到了用WCF的时候, ...

  8. virtual judge 本地部署方案

    这是一种将自己的电脑当作服务器来部署一个vj的方法,我也是参考前辈们的做法稍作了改动,如果在服务器上部署的话需要在细节上稍作改动: 一.什么是Virtual Judge? vj的工作原理什么?  vj ...

  9. 分布式监控CAT服务端的本地部署

    一.CAT简介 CAT(Central Application Tracking),是美团点评基于 Java 开发的一套开源的分布式实时监控系统.美团点评基础架构部希望在基础存储.高性能通信.大规模在 ...

随机推荐

  1. D - Seek the Name, Seek the Fame

    The little cat is so famous, that many couples tramp over hill and dale to Byteland, and asked the l ...

  2. Codeforces Round #664 (Div. 2) C. Boboniu and Bit Operations

    传送门:cf1395C 题意 c[i]=a[i]&b[j],b[j]是b数组中任意一个,求c[1] | c[2] | ... | c[n]最小值. 题解 经典的二进制枚举答案,因为a和b的最大 ...

  3. 利用github+hexo搭建的博客

    用github+hexo新建了一个博客,欢迎来访,如果想要搭建类似框架的博客,可以联系我. 新博客地址:只为自由书写的博客

  4. WIN7使用msg命令发送消息心得

    昨天搞了一下午+一晚上,终于捣鼓出了一些奇奇怪怪的操作,成功发送了消息. 应实验要求,博主有幸在家里搞到了两台win7,其他的系统是不是这么操作就不太清楚了. 一开始实验指导书上是用net send发 ...

  5. Codeforces Round #646 (Div. 2) C. Game On Leaves(树上博弈)

    题目链接:https://codeforces.com/contest/1363/problem/C 题意 有一棵 $n$ 个结点的树,每次只能取叶子结点,判断谁能最先取到结点 $x$ . 题解 除非 ...

  6. 用数组模拟STL中的srack(栈)和queue(队列)

    我们在理解stack和queue的基础上可以用数组来代替这两个容器,因为STL中的stack和queue有可能会导致程序运行起来非常的慢,爆TLE,所以我们使用数组来模拟他们,不仅可以更快,还可以让代 ...

  7. 7.PowerShell DSC之模式

    DSC两种模式 DSC有两种模式,Push模式和Pull模式 Push模式 基本流程 写配置--编译生成mof--推送到目标服务器,由目标服务器LCM执行mof并进行指定的配置 优点 架构简单.成本低 ...

  8. HTTP笔记1--Web及网络基础

    web页面如何呈现? 客户端:通过发送请求获取服务器资源的 Web 浏览器 web是建立在 HTTP 协议上通信的   WWW(万维网/web)的构建技术 把 SGML(StandardGeneral ...

  9. 梨子带你刷burp练兵场(burp Academy) - 服务器篇 - Sql注入 - SQL injection UNION attack, determining the number of columns returned by the query

    目录 SQL injection UNION attack, determining the number of columns returned by the query SQL injection ...

  10. System.Windows.Forms.Help

    在开发过程中,基本都需要实现帮助功能,而一般帮助功能就是打开一个帮助文档,System.Windows.Forms提供了Help类用于打开帮助文档,挺方便的. Help类提供的方法如下:   Name ...