1.JMS

  Java消息服务(Java Message Service)即JMS,是一个Java平台中关于面向消息中间件的API,用于两个程序之间,或分布式系统中发送消息,进行异步通信。

  JMS包括队列与主题两种模式,一种是点对点的Queue,还有一个是发布订阅的Topic方式。区别在于:
  (1)对于Queue模式,一个发布者发布消息,下面的接收者按队列顺序接收,比如发布了10个消息,两个接收者A,B那就是A,B总共会收到10条消息,不重复。
  (2)对于Topic模式,一个发布者发布消息,有两个接收者A,B来订阅,那么发布了10条消息,A,B各收到10条消息。

2.消息中间件

  消息中间件有很多的用途和优点:
  (1) 将数据从一个应用程序传送到另一个应用程序,或者从软件的一个模块传送到另外一个模块;
  (2)负责建立网络通信的通道,进行数据的可靠传送;
  (3)保证数据不重发,不丢失 ;
  (4)能够实现跨平台操作,能够为不同操作系统上的软件集成技工数据传送服务。

3.ActiveMQ

  ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

4.ActiveMQ安装

  (1)官方网址:http://activemq.apache.org/,下载对应的程序,如下图所示。

  

  (2)解压到本地,在apache-activemq-5.15.0\bin\win64的目录下选择InstallService.bat启动服务,这样下次只要到系统服务里去启动与关闭,如下图所示。

  

  (3)至此,activemq的服务已经启动。

5.Demo项目结构

6.代码实现生产者消费者模式

  (1)配置依赖项

    在pom.xml里添加依赖jar包

   <dependencies>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.15.0</version>
</dependency>
</dependencies>

  (2)实现生产者(队列模式)

package com.snail.queue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*; /**
* 生产者(队列模式)
* Create by zhangviv
* 2017-08-25 14:06
**/
public class AppProducer {
private static final String url = "tcp://localhost:61616";
private static final String queueName = "queue-test"; public static void main(String[] args) throws JMSException {
//1.创建ConnectionFactory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url); //2.创建连接
Connection connection = connectionFactory.createConnection(); //3.启动连接
connection.start(); //4.创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //5.创建一个目标
Destination destination = session.createQueue(queueName); //6.创建一个生产者
MessageProducer producer = session.createProducer(destination); for (int i = 0; i < 100; i++) {
//7.创建消息
TextMessage textMessage = session.createTextMessage("test" + i);
producer.send(textMessage);
System.out.println("发送消息:" + textMessage.getText());
} //8.关闭连接
connection.close();
}
}

  (3)实现消费者(队列模式)

package com.snail.queue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*; /**
* 消费者(队列模式)
* Create by zhangviv
* 2017-08-25 14:12
**/
public class AppConsumer {
private static final String url="tcp://localhost:61616";
private static final String queueName="queue-test";
public static void main(String[] args) throws JMSException {
//1.创建ConnectionFactory
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url); //2.创建连接
Connection connection = connectionFactory.createConnection(); //3.启动连接
connection.start(); //4.创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //5.创建一个目标
Destination destination = session.createQueue(queueName); //6.创建一个消费者
MessageConsumer consumer=session.createConsumer(destination); //7.创建一个监听器
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
TextMessage textMessage= (TextMessage) message;
try {
System.out.println("接收消息:"+textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}); }
}

  (4)ActiveMQ客户端查看队列模式

  

  (5)实现生产者(主题模式)

package com.snail.topic;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*; /**
* 生产者(主题模式)
* Create by zhangviv
* 2017-08-25 14:06
**/
public class TopicProducer {
private static final String url = "tcp://localhost:61616";
private static final String topicName = "topic-test"; public static void main(String[] args) throws JMSException {
//1.创建ConnectionFactory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url); //2.创建连接
Connection connection = connectionFactory.createConnection(); //3.启动连接
connection.start(); //4.创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //5.创建一个目标
Destination destination = session.createTopic(topicName); //6.创建一个生产者
MessageProducer producer = session.createProducer(destination); for (int i = 0; i < 100; i++) {
//7.创建消息
TextMessage textMessage = session.createTextMessage("test" + i);
producer.send(textMessage);
System.out.println("发送消息:" + textMessage.getText());
} //8.关闭连接
connection.close();
}
}

  (6)实现消费者模式(主题模式)

package com.snail.topic;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*; /**
* 消费者(主题模式)
* Create by zhangviv
* 2017-08-25 14:12
**/
public class TopicConsumer {
private static final String url="tcp://localhost:61616";
private static final String topicName="topic-test";
public static void main(String[] args) throws JMSException {
//1.创建ConnectionFactory
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url); //2.创建连接
Connection connection = connectionFactory.createConnection(); //3.启动连接
connection.start(); //4.创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //5.创建一个目标
Destination destination = session.createTopic(topicName); //6.创建一个消费者
MessageConsumer consumer=session.createConsumer(destination); //7.创建一个监听器
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
TextMessage textMessage= (TextMessage) message;
try {
System.out.println("接收消息:"+textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}); }
}

  (7)ActiveMQ客户端查看主题模式

  

基于JMS的ActiveMQ搭建与实现的更多相关文章

  1. Azure上搭建ActiveMQ集群-基于ZooKeeper配置ActiveMQ高可用性集群

    ActiveMQ从5.9.0版本开始,集群实现方式取消了传统的Master-Slave方式,增加了基于ZooKeeper+LevelDB的实现方式. 本文主要介绍了在Windows环境下配置基于Zoo ...

  2. ActiveMQ基于JMS的pub/sub传播机制

    原文地址:[ActiveMQ实战]基于JMS的pub/sub传播机制 发布订阅模型 就像订阅报纸,我们可以选择一份或者多份报纸.比如:北京日报.人民日报.这些报纸就相当于发布订阅模型中的topic.如 ...

  3. ActiveMQ此例简单介绍基于docker的activemq安装与集群搭建

    ActiveMQ拓展连接 此例简单介绍基于Docker的activemq安装与集群搭建 一 :安装 1.获取activemq镜像 docker pull webcenter/activemq 2.启动 ...

  4. 基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送

    前言 写了一个简单的JMS例子,之所以使用JNDI 是出于通用性考虑,该例子使用JMS规范提供的通用接口,没有使用具体JMS提供者的接口,这样可以保证我们编写的程序适用于任何一种JMS实现(Activ ...

  5. 深入浅出JMS(三)--ActiveMQ简单的HelloWorld实例

    第一篇博文深入浅出JMS(一)–JMS基本概念,我们介绍了JMS的两种消息模型:点对点和发布订阅模型,以及消息被消费的两个方式:同步和异步,JMS编程模型的对象,最后说了JMS的优点. 第二篇博文深入 ...

  6. MQ、JMS以及ActiveMQ

    MQ简介: MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过写和检索出入列队的针对应用程序的数据(消息)来通信,而无需专用连接来链接它们.消息传 ...

  7. MQ、JMS以及ActiveMQ 关系的理解

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt127 Best-text mb-10代码 ms 的一个标准或者说是一个协议. ...

  8. jms和activemq

    一.什么是JMS JMS是java message service的缩写即java消息服务,是java定义的消息中间件(MOM)的技术规范(类似玉JDBC).用于程序之间的异步通信,如果两个应用程序需 ...

  9. spring集成JMS访问ActiveMQ

    首先我们搭建一个spring-mvc项目,项目可以参考:spring-mvc 学习笔记 步骤: 在pom.xml中加上需要的包 修改web.xml,增加IOC容器 spring配置文件applicat ...

随机推荐

  1. nginx 反向代理 apache 服务

    反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时 ...

  2. JSP标准标签库JSTL

    1.什么是JSTL? JSP标准标签库(JSP Standard Tag Library) 2.JSTL标准标签库中的常用标签 JSTL是JSP页面的标签库,实质上是一段Java代码.我们常用的是它的 ...

  3. web项目传classes目录项目正常,打包成jar不能运行。

    笔者最近使用tomcat9,由于工作洁癖,盯上了tomcat启动日志里的"No TLD files were found in"字样,如下 15-Sep-2017 02:19:09 ...

  4. C#控制台进度条(Programming Progress bar in C# Consle application)

    以下代码从Stack Overflow,觉得以后会用到就收藏一下,我是辛勤的搬运工,咿呀咿呀哟- 1.showing percentage in .net console application(在. ...

  5. 转:从框架看PHP的五种境界及各自的薪资待遇(仅限于二三线城市,一线除外)

    在撰写此文前首先必须申明的是本人不鄙视任何一种框架,也无意于挑起PHP框架间的战争,更没有贬低某个框架使用者的用意,本文纯粹个人的看法.你可以认为我无知也好,或者装逼也好,请不要试着在任何情况下,随便 ...

  6. OpenSource.iOS.ProtobufWithObjective-C

    2. 在iOS(Mac OS X)中使用protobuf 2.0 构建protoc A) 下载最新的protobuf版本 B) 依据README中的步骤依次进行 2.1 添加protobuf到工程中 ...

  7. Codeforces 599C. Day at the Beach 模拟

    Day at the Beach time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  8. msys2 命令行添加镜像地址

    sed -i "1iServer = https://mirrors.tuna.tsinghua.edu.cn/msys2/mingw/i686" /etc/pacman.d/mi ...

  9. 2018.10.13 bzoj1834: [ZJOI2010]network 网络扩容(最大流+费用流)

    传送门 网络流水题啊. 第一问直接放心跑最大流(本来还以为有什么tricktricktrick). 第二问就直接把原来的边(u,v,c,w)(u,v,c,w)(u,v,c,w)变成(u,v,c,0)( ...

  10. 2018.09.21 codeforces1051D. Bicolorings(线性dp)

    传送门 sb线性DP. f[i][j][0/1/2/3]f[i][j][0/1/2/3]f[i][j][0/1/2/3]表示前i列j个连通块且第i列状态为00/01/10/11时的方案总数. 这个显然 ...