一、背景

中间件

由于业务的不同、技术的发展、硬件和软件的选择有所差别,导致了异构组件或应用并存的局面。要使这些异构的组件协同工作,一个有效的方式就是提供一个允许它们进行通信的层,该层即为中间件

在概念上,中间件位于应用程序层与平台层(操作系统和底层网络服务)之间。

MOM

全称:Message-Oriented Middleware 中文:面向消息的中间件。

MOM通信模型:
ActiveMQ介绍

MOM模型中的四个基本元素:消息传递提供者目的地客户端(发送方或接收方)、消息
发送方客户端将消息发送到消息提供者维护的目的地,这些消息一直被保留直到接收方客户端将消息取出。

JMS

全称:Java Message Service 中文:Java消息服务。

JMS是Java的一套API标准,最初的目的是为了使应用程序能够访问现有的MOM系统(客户端通过JMS访问消息提供者);后来被许多现有的MOM供应商采用,并实现为MOM系统。
基于JMS实现的MOM,又被称为JMS Provider。

ActiveMQ

Apache出品,完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现

它有很多功能、特色,所以它的详细信息很复杂。但是基于这一刻,我们只需要知道两件事:(1) 它是MOM;(2) 它是JMS的一个实现

ActiveMQ介绍

ActiveMQ使用java写的,所以天然跨平台,windows,各种类Unix系统都可运行,只需要下载对应的分发包即可。

二、ActiveMQ安装启动

1、打开浏览器,访问官网 

2、下载最新的版本,当前最新版本,根据ActiveMQ需要安装的操作系统选择性下载对应的版本,这里我选择Windows版本,然后点击下载ZIP包

3、下载完成以后,将zip文件解压到D盘下,解压后的目录结构如下图所示:

ActiveMQ介绍

4、在启动ActiveMQ前,首先要确保服务器上已经安装和配置好JDK,并且JDK的版本要满足ActiveMQ的要求

cmd  java -version

5、接下来我们进入到D:\apache-activemq-5.15.5\bin,如下图所示:

ActiveMQ介绍

6、根据服务器上操作系统的版本,选择进入到win32还是win64,这里选择进入win64目录,然后双击activemq.bat,这时activemq就启动起来了,成功启动以后打印的日志如下图所示:

ActiveMQ介绍

也可以安装为服务启动,执行bin>win64目录下面的InstallService.bat就可以了。

7、打开浏览器,输入http://localhost:8161/admin/ ,弹出一个windows安全提示框,提示输入activemq的用户名和密码,如下图所示:

ActiveMQ介绍

8、接下来我们打开D:\apache-activemq-5.15.5\conf这个目录,找到jetty-realm.properties文件(该文件保存着用户名和密码信息)

找到文件的末尾,格式是 用户名密码,用户角色 ,如下图所示:
ActiveMQ介绍

10、角色信息的定义放在D:\apache-activemq-5.15.5\conf下的jetty.xml文件中,如下图所示:

ActiveMQ介绍

11、 我们知道了角色定义的位置,角色对应的用户名和密码后,我们就可以使用默认的用户名admin和默认的密码admin来登录系统,如下图所示:

ActiveMQ介绍

12、 登录成功以后,就可以看到activemq的主页了,如下图所示:

ActiveMQ介绍

三、后台管理页面

Queues是队列方式消息。Topics是主题方式消息。Subscribers是消息订阅监控查询。Connections可以查看链接数,分别可以查看xmpp、ssl、stomp、openwire、ws和网络链接。Network是网络链接数监控。Send可以发送消息数据。

 

ActiveMQ介绍

 

Numbers of Pending Messages: 待处理的消息数量

Messages Enqueued:在排队的消息

Messages Denqueued:已出队列的消息

ActiveMQ介绍

Send中可以手动发数据到队列

ActiveMQ介绍

注:队列名称是区分大小写的

 

四、启动报错

1、cmd中启动时看到错误:Failed to start Apache ActiveMQ......

修改conf->activemq.xml 配置文件

ActiveMQ介绍
<transportConnectors>
            <!-- DOS protection, limit concurrent connections to 1000 and frame size to 100MB -->
            <transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>
            <transportConnector name="amqp" uri="amqp://0.0.0.0:5672?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>
            <transportConnector name="stomp" uri="stomp://0.0.0.0:61613?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>
            <transportConnector name="mqtt" uri="mqtt://0.0.0.0:1883?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>
            <transportConnector name="ws" uri="ws://0.0.0.0:61614?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>
        </transportConnectors>
View Code

相关文章:

  • 2021-05-08
  • 2021-09-15
  • 2021-07-10
  • 2022-01-22
  • 2022-12-23
猜你喜欢
  • 2021-10-04
  • 2021-11-08
  • 2021-09-02
相关资源
相似解决方案