ActiveMQ Pub/Sub版的HelloWorld
1. pom.xml
这个和上一篇是一样的:
- <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0</modelVersion>
- <groupId>org.ygy</groupId>
- <artifactId>activemq</artifactId>
- <version>0.0.1-SNAPSHOT</version>
- <packaging>jar</packaging>
- <name>activemq</name>
- <url>http://maven.apache.org</url>
- <properties>
- <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
- </properties>
- <dependencies>
- <dependency>
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>4.10</version>
- <scope>test</scope>
- </dependency>
- <!-- activemq,学习中 -->
- <dependency>
- <groupId>org.apache.activemq</groupId>
- <artifactId>activemq-core</artifactId>
- <version>5.7.0</version>
- </dependency>
- <dependency>
- <groupId>org.slf4j</groupId>
- <artifactId>slf4j-api</artifactId>
- <version>1.5.6</version>
- </dependency>
- <dependency>
- <groupId>org.slf4j</groupId>
- <artifactId>slf4j-log4j12</artifactId>
- <version>1.5.6</version>
- </dependency>
- </dependencies>
- </project>
2. Pub/Sub版的HelloWorld
生产者:
- package org.ygy.mq.lesson01;
- import javax.jms.Connection;
- import javax.jms.ConnectionFactory;
- import javax.jms.DeliveryMode;
- import javax.jms.Destination;
- import javax.jms.JMSException;
- import javax.jms.MessageProducer;
- import javax.jms.Session;
- import javax.jms.TextMessage;
- import org.apache.activemq.ActiveMQConnectionFactory;
- import org.ygy.mq.constants.MQConstants;
- public class HelloTopicProducer {
- public void send(String msg) {
- // 生产者的主要流程
- Connection connection = null;
- try {
- // 1.初始化connection工厂,使用默认的URL
- // failover://tcp://localhost:61616
- ConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
- // 2.创建Connection
- connection = connectionFactory.createConnection();
- // 3.打开连接
- connection.start();
- // 4.创建Session,(是否支持事务)
- Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
- // 5.创建消息目标
- Destination destination_send = session.createTopic(MQConstants.DESTINATION_SEND);
- // 6.创建生产者
- MessageProducer producer = session.createProducer(destination_send);
- // 7.配置消息是否持久化
- /*
- * DeliverMode有2种方式:
- *
- * public interface DeliveryMode { static final int NON_PERSISTENT =
- * 1;//不持久化:服务器重启之后,消息销毁
- *
- * static final int PERSISTENT = 2;//持久化:服务器重启之后,该消息仍存在 }
- */
- producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
- // 8.初始化要发送的消息
- TextMessage message = session.createTextMessage(msg);
- // 9.发送消息
- producer.send(message);
- connection.close();
- } catch (JMSException e) {
- e.printStackTrace();
- }
- }
- public static void main(String[] args) {
- new HelloTopicProducer().send("我来试一试发布/订阅...");
- }
- }
消费者:
- package org.ygy.mq.lesson01;
- import javax.jms.Connection;
- import javax.jms.ConnectionFactory;
- import javax.jms.Destination;
- import javax.jms.JMSException;
- import javax.jms.Message;
- import javax.jms.MessageConsumer;
- import javax.jms.MessageListener;
- import javax.jms.Session;
- import javax.jms.TextMessage;
- import org.apache.activemq.ActiveMQConnectionFactory;
- import org.ygy.mq.constants.MQConstants;
- public class HelloTopicConsumer implements MessageListener {
- @Override
- public void onMessage(Message message) {
- if (message instanceof TextMessage) {
- TextMessage txtMsg = (TextMessage) message;
- try {
- System.out.println("哈,我接收到了消息:" + txtMsg.getText());
- } catch (JMSException e) {
- e.printStackTrace();
- }
- }
- }
- public void receive() {
- // 消费者的主要流程
- Connection connection = null;
- try {
- // 1.初始化connection工厂
- ConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
- // 2.创建Connection
- connection = connectionFactory.createConnection();
- // 3.打开连接
- connection.start();
- // 4.创建session
- Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
- // 5.创建消息目标
- Destination destination = session.createTopic(MQConstants.DESTINATION_SEND);
- // 6.创建消费者
- MessageConsumer consumer = session.createConsumer(destination);
- // 7.配置监听
- consumer.setMessageListener(new HelloTopicConsumer());
- } catch (JMSException e) {
- e.printStackTrace();
- }
- }
- public static void main(String[] args) {
- new HelloTopicConsumer().receive();
- }
- }
3.测试
访问网页:http://localhost:8161/admin/topics.jsp
单击那个Topics连接。
这里显示的是服务器上的主题,这些显示的都没有用,可以都删掉。
Name:主题的名称
Number Of Consumers:正在运行的消费者
Message Enqueued:进入消息队列的
Message Dequeued:出消息队列的
Operations:操作
下面就可以开始运行程序了,
注意顺序:先运行消费者:
这里会产生好几个主题,我们只看我们自己用的那个,(其实,其他几个是干嘛的,暂时还不清楚,以后再研究吧.....)
我们的消费者一直在运行
接下来,运行生产者:
控制台会输出:
再一次,刷新界面:
消费者还在运行,只生产了一条消息,而且已经被消费了。
ActiveMQ Pub/Sub版的HelloWorld的更多相关文章
- ActiveMQ P2P版的HelloWorld
1.2 JMS应用程序接口 ConnectionFactory: 用户用来创建到JMS提供者的连接的被管对象.JMS客户通过可移植的接口访问连接,这样当下层的实现改变时,代码不需要进行修改. 管理员 ...
- Mina入门:mina版之HelloWorld
一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式切入Mina入门学习了. 二,搭建项目结构与解决项目依赖 ...
- Mina入门:mina版之HelloWorld[z]
Mina入门:mina版之HelloWorld [z] 一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式 ...
- ActiveMQ 入门Nodejs版
ActiveMQ 入门下载与安装 官方下载地址 解压,运行bin/win[32|64]/activemq[.bat] 启动服务 环境信息 控制台: http://localhost:8161 默认端口 ...
- 初学tornado之MVC版helloworld
作者:the5fire | 标签: MVC tornado | 发布:2012-08-06 2:41 p.m. 文接上篇,看我一个简单的helloworld,虽然觉得这个框架着实精小,但是实际开发 ...
- ActiveMQ 了解
Active MQ 是JMS的一个具体实现,所以首先要对JMS有所了解. 1. JMS: 定义:Java消息服务(Java Message Service),是Sun是提出来的为J2EE提 ...
- FreeMarker使用小记(HelloWorld)
FreeMarker是开源的模板框架.对于它的介绍网上已经很多了.详情可参考主页:http://www.freemarker.org/ 现在我们就开始我们的FreeMarker版的Hello Worl ...
- Scala入门:从HelloWorld开始【源码及编译】
最近在学习Scala语言,虽然还没有完全学通, 但是隐约可以体会到Scala的简洁和强大. 它既能让程序员使用函数式编程, 也提供了全面的面向对象编程. 在刚刚开始读<Scala编程>的时 ...
- ActiveMQ安装与持久化消息
activityMQ官网:http://activemq.apache.org/ 有windows版与linux版 windows版启动 在bin目录下双击activemq.bat linux版的安 ...
随机推荐
- 【Android开发那点破事】打开APP加载页面实现
今天的破事呢就说说APP加载页面的实现.一般情况下,当APP打开的时候,我们需要做很多事情,比如检查网络连接啊,初始化一些配置啊等等.我们可以让这些事情在APP完全打开之前做完,然后呢在打开的过程中显 ...
- ORM操作mysql
创建表和添加数据 import sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import ...
- XML语法随记
1.特殊字符的转义 & ---- & < ---- < > ---- > " ---- " ' ----- &ap ...
- Asp .Net core 2 学习笔记(1) —— Starup
这个系列的初衷是便于自己总结与回顾,把笔记本上面的东西转移到这里,态度不由得谨慎许多,下面是我参考的资源: ASP.NET Core 中文文档目录 官方文档 记在这里的东西我会不断的完善丰满,对于文章 ...
- 改变PowerDesigner数据模型字体大小
一 改变左侧菜单字体大小Tools----->General------->Fonts-------->根据item选项的不同改变字体的大小 二 改变数据模型Table的字体大小To ...
- Spring AOP 源码分析 - 创建代理对象
1.简介 在上一篇文章中,我分析了 Spring 是如何为目标 bean 筛选合适的通知器的.现在通知器选好了,接下来就要通过代理的方式将通知器(Advisor)所持有的通知(Advice)织入到 b ...
- Spring IOC 容器源码分析 - 获取单例 bean
1. 简介 为了写 Spring IOC 容器源码分析系列的文章,我特地写了一篇 Spring IOC 容器的导读文章.在导读一文中,我介绍了 Spring 的一些特性以及阅读 Spring 源码的一 ...
- BZOJ 2200--[Usaco2011 Jan]道路和航线(最短路&拓扑排序)
2200: [Usaco2011 Jan]道路和航线 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 1128 Solved: 414[Submit] ...
- spring cloud学习(二) 调用服务
spring-cloud调用服务有两种方式,一种是Ribbon+RestTemplate, 另外一种是Feign. Ribbon是一个基于HTTP和TCP客户端的负载均衡器,其实feign也使用了ri ...
- haproxy监测页面参数简释
Queue Cur: current queued requests //当前的队列请求数量Max:max queued requests //最大的队列请求数量Limit: ...