1. pom.xml

这个和上一篇是一样的:

  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4. <groupId>org.ygy</groupId>
  5. <artifactId>activemq</artifactId>
  6. <version>0.0.1-SNAPSHOT</version>
  7. <packaging>jar</packaging>
  8. <name>activemq</name>
  9. <url>http://maven.apache.org</url>
  10. <properties>
  11. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  12. </properties>
  13. <dependencies>
  14. <dependency>
  15. <groupId>junit</groupId>
  16. <artifactId>junit</artifactId>
  17. <version>4.10</version>
  18. <scope>test</scope>
  19. </dependency>
  20. <!-- activemq,学习中 -->
  21. <dependency>
  22. <groupId>org.apache.activemq</groupId>
  23. <artifactId>activemq-core</artifactId>
  24. <version>5.7.0</version>
  25. </dependency>
  26. <dependency>
  27. <groupId>org.slf4j</groupId>
  28. <artifactId>slf4j-api</artifactId>
  29. <version>1.5.6</version>
  30. </dependency>
  31. <dependency>
  32. <groupId>org.slf4j</groupId>
  33. <artifactId>slf4j-log4j12</artifactId>
  34. <version>1.5.6</version>
  35. </dependency>
  36. </dependencies>
  37. </project>

2. Pub/Sub版的HelloWorld

生产者:

  1. package org.ygy.mq.lesson01;
  2. import javax.jms.Connection;
  3. import javax.jms.ConnectionFactory;
  4. import javax.jms.DeliveryMode;
  5. import javax.jms.Destination;
  6. import javax.jms.JMSException;
  7. import javax.jms.MessageProducer;
  8. import javax.jms.Session;
  9. import javax.jms.TextMessage;
  10. import org.apache.activemq.ActiveMQConnectionFactory;
  11. import org.ygy.mq.constants.MQConstants;
  12. public class HelloTopicProducer {
  13. public void send(String msg) {
  14. // 生产者的主要流程
  15. Connection connection = null;
  16. try {
  17. // 1.初始化connection工厂,使用默认的URL
  18. // failover://tcp://localhost:61616
  19. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
  20. // 2.创建Connection
  21. connection = connectionFactory.createConnection();
  22. // 3.打开连接
  23. connection.start();
  24. // 4.创建Session,(是否支持事务)
  25. Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
  26. // 5.创建消息目标
  27. Destination destination_send = session.createTopic(MQConstants.DESTINATION_SEND);
  28. // 6.创建生产者
  29. MessageProducer producer = session.createProducer(destination_send);
  30. // 7.配置消息是否持久化
  31. /*
  32. * DeliverMode有2种方式:
  33. *
  34. * public interface DeliveryMode { static final int NON_PERSISTENT =
  35. * 1;//不持久化:服务器重启之后,消息销毁
  36. *
  37. * static final int PERSISTENT = 2;//持久化:服务器重启之后,该消息仍存在 }
  38. */
  39. producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
  40. // 8.初始化要发送的消息
  41. TextMessage message = session.createTextMessage(msg);
  42. // 9.发送消息
  43. producer.send(message);
  44. connection.close();
  45. } catch (JMSException e) {
  46. e.printStackTrace();
  47. }
  48. }
  49. public static void main(String[] args) {
  50. new HelloTopicProducer().send("我来试一试发布/订阅...");
  51. }
  52. }

消费者:

  1. package org.ygy.mq.lesson01;
  2. import javax.jms.Connection;
  3. import javax.jms.ConnectionFactory;
  4. import javax.jms.Destination;
  5. import javax.jms.JMSException;
  6. import javax.jms.Message;
  7. import javax.jms.MessageConsumer;
  8. import javax.jms.MessageListener;
  9. import javax.jms.Session;
  10. import javax.jms.TextMessage;
  11. import org.apache.activemq.ActiveMQConnectionFactory;
  12. import org.ygy.mq.constants.MQConstants;
  13. public class HelloTopicConsumer implements MessageListener {
  14. @Override
  15. public void onMessage(Message message) {
  16. if (message instanceof TextMessage) {
  17. TextMessage txtMsg = (TextMessage) message;
  18. try {
  19. System.out.println("哈,我接收到了消息:" + txtMsg.getText());
  20. } catch (JMSException e) {
  21. e.printStackTrace();
  22. }
  23. }
  24. }
  25. public void receive() {
  26. // 消费者的主要流程
  27. Connection connection = null;
  28. try {
  29. // 1.初始化connection工厂
  30. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory();
  31. // 2.创建Connection
  32. connection = connectionFactory.createConnection();
  33. // 3.打开连接
  34. connection.start();
  35. // 4.创建session
  36. Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
  37. // 5.创建消息目标
  38. Destination destination = session.createTopic(MQConstants.DESTINATION_SEND);
  39. // 6.创建消费者
  40. MessageConsumer consumer = session.createConsumer(destination);
  41. // 7.配置监听
  42. consumer.setMessageListener(new HelloTopicConsumer());
  43. } catch (JMSException e) {
  44. e.printStackTrace();
  45. }
  46. }
  47. public static void main(String[] args) {
  48. new HelloTopicConsumer().receive();
  49. }
  50. }

3.测试

访问网页:http://localhost:8161/admin/topics.jsp

单击那个Topics连接。

这里显示的是服务器上的主题,这些显示的都没有用,可以都删掉。

Name:主题的名称

Number Of Consumers:正在运行的消费者

Message Enqueued:进入消息队列的

Message Dequeued:出消息队列的

Operations:操作

下面就可以开始运行程序了,

注意顺序:先运行消费者:

这里会产生好几个主题,我们只看我们自己用的那个,(其实,其他几个是干嘛的,暂时还不清楚,以后再研究吧.....)

我们的消费者一直在运行

接下来,运行生产者:

控制台会输出:

再一次,刷新界面:

消费者还在运行,只生产了一条消息,而且已经被消费了。

ActiveMQ Pub/Sub版的HelloWorld的更多相关文章

  1. ActiveMQ P2P版的HelloWorld

    1.2 JMS应用程序接口 ConnectionFactory: 用户用来创建到JMS提供者的连接的被管对象.JMS客户通过可移植的接口访问连接,这样当下层的实现改变时,代码不需要进行修改. 管理员 ...

  2. Mina入门:mina版之HelloWorld

    一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式切入Mina入门学习了. 二,搭建项目结构与解决项目依赖 ...

  3. Mina入门:mina版之HelloWorld[z]

    Mina入门:mina版之HelloWorld [z] 一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式 ...

  4. ActiveMQ 入门Nodejs版

    ActiveMQ 入门下载与安装 官方下载地址 解压,运行bin/win[32|64]/activemq[.bat] 启动服务 环境信息 控制台: http://localhost:8161 默认端口 ...

  5. 初学tornado之MVC版helloworld

    作者:the5fire | 标签: MVC  tornado  | 发布:2012-08-06 2:41 p.m. 文接上篇,看我一个简单的helloworld,虽然觉得这个框架着实精小,但是实际开发 ...

  6. ActiveMQ 了解

    Active MQ 是JMS的一个具体实现,所以首先要对JMS有所了解. 1.       JMS: 定义:Java消息服务(Java Message Service),是Sun是提出来的为J2EE提 ...

  7. FreeMarker使用小记(HelloWorld)

    FreeMarker是开源的模板框架.对于它的介绍网上已经很多了.详情可参考主页:http://www.freemarker.org/ 现在我们就开始我们的FreeMarker版的Hello Worl ...

  8. Scala入门:从HelloWorld开始【源码及编译】

    最近在学习Scala语言,虽然还没有完全学通, 但是隐约可以体会到Scala的简洁和强大. 它既能让程序员使用函数式编程, 也提供了全面的面向对象编程. 在刚刚开始读<Scala编程>的时 ...

  9. ActiveMQ安装与持久化消息

    activityMQ官网:http://activemq.apache.org/ 有windows版与linux版  windows版启动 在bin目录下双击activemq.bat linux版的安 ...

随机推荐

  1. linux中的amount的解释

    挂载(amount)概念简述: 根文件系统之外的其他文件要想能够被访问,都必须通过“关联”至根文件系统上的某个目录来实现,此关联操作即为“挂载”,此目录即为“挂载点”,解除此关联关系的过程称之为“卸载 ...

  2. 运行批处理文件怎么不显示DOS命令窗口

    运行批处理文件怎么不显示DOS命令窗口   BAT没法不显示DOS窗口.你可以考虑用脚本保持以下到文本文件,重命名为AutoUp_ddyy.vbs set WshShell = WScript.Cre ...

  3. PhantomJS快速入门-无界面浏览器

    https://blog.csdn.net/libsyc/article/details/78199850 PhantomJS快速入门 本文简要介绍了PhantomJS的相关基础知识点,主要包括Pha ...

  4. 探索基于.NET下实现一句话木马之asmx篇

    0x01 前言 上篇介绍了一般处理程序(ashx)的工作原理以及实现一句话木马的过程,今天接着介绍Web Service程序 (asmx)下的工作原理和如何实现一句话木马,当然介绍之前笔者找到了一款a ...

  5. cad2015卸载/安装失败/如何彻底卸载清除干净cad2015注册表和文件的方法

    cad2015提示安装未完成,某些产品无法安装该怎样解决呢?一些朋友在win7或者win10系统下安装cad2015失败提示cad2015安装未完成,某些产品无法安装,也有时候想重新安装cad2015 ...

  6. safe close tcp connection

    https://blog.netherlabs.nl/articles/2009/01/18/the-ultimate-so_linger-page-or-why-is-my-tcp-not-reli ...

  7. Spring boot中使用log4j

    我们知道,Spring Boot中默认日志工具为logback,但是对于习惯了log4j的开发者,Spring Boot依然可以很好的支持,只是需要做一些小小的配置功能.Spring Boot使用lo ...

  8. CSS3标签显示模式

    HTML标签一般分为块标签和行内标签两种类型,它们也称块元素和行内元素.具体如下: 块级元素(block-level) 每个块元素通常都会独自占据一整行或多整行,可以对其设置宽度.高度.对齐等属性,常 ...

  9. Xshell 配色方案

    [wsp] text=cOc0c0 cyan(bold)=50ebfc text(bold)=9999e8 magenta=7b5175 green=008000 green(bold)=1cc470 ...

  10. centos7上mysql5.6版本主从复制

    做主从复制实验: 第一步:主服务器上操作 1.修改主服务器master: [root@localhost ~]# vim /etc/my.cnf server_id = 1  //[必须]服务器唯一I ...