Hi
今天那个实例来介绍下JMS发布/订阅 .现在网络聊天的需求可以完美的映射到发布.订阅消息的传达模型之上的。
实例:、如果要运行Chat。需要使用支持JNDI和JMS的JMS提供者。我使用的开源JMS提供者:ActiveMq (版本apache-activemq-5.5.0)
apache-activemq-5.5.0下载地址
http://activemq.apache.org/activemq-550-release.html
下载后运行D:\Jar\apache-activemq-5.5.0\bin\
activemq.bat
访问
http://localhost:8161/admin/
页面显示如下表示服务开启
Welcome to the ActiveMQ Console of localhost (ID:dnepc504-1186-1303391964578-0:1)
You can find more information about ActiveMQ on the Apache ActiveMQ Site
Chat.java
package iteye.JMS_Exception.chat;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Properties;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicPublisher;
import javax.jms.TopicSession;
import javax.jms.TopicSubscriber;
import javax.naming.InitialContext;
/**
* Chat 类自身实现了MessageListener接口和onMessage方法
* Email: JMS_Exception@hotmail.com
* @author PC504
*
*/
public class Chat implements javax.jms.MessageListener{
private TopicSession pubSession;
private TopicPublisher publisher;
private TopicConnection connection;
private String username;
/* 初始化Chat */
public Chat(String topicFactory, String topicName, String username)
throws Exception {
// 设置JNDI连接参数
Properties env = new Properties();
env.put(javax.naming.Context.SECURITY_PRINCIPAL, "system");
env.put(javax.naming.Context.SECURITY_CREDENTIALS, "manager");
env.put(javax.naming.Context.INITIAL_CONTEXT_FACTORY,"org.apache.activemq.jndi.ActiveMQInitialContextFactory");
env.put(javax.naming.Context.PROVIDER_URL,"tcp://127.0.0.1:61616");
//实例化InitialContext对象以后
//就可以使用它在消息传送服务器的命名服务中查找TopicConnectionFactory
InitialContext ctx = new InitialContext(env);
//创建到JMS提供者的发布/订阅的 TopicConnection
TopicConnectionFactory conFactory =
(TopicConnectionFactory)ctx.lookup(topicFactory);
//客户端使用一个 TopicConnectionFactory 对象
//来创建到JMS提供者的发布/订阅的 TopicConnection
TopicConnection connection = conFactory.createTopicConnection();
// TopicSession 用于创建Message.TopicPublisher .TopicSubscriber对象的工厂.我们创建两个JMS会话对象
//false意味创建的TopicSession将不是事务性的。
//AUTO_ACKNOWLEDGE 意味消息将在客户端接收之后自动确定
TopicSession pubSession = connection.createTopicSession(
false, Session.AUTO_ACKNOWLEDGE);
//pubSession.createDurableSubscriber(topic, topicName)
TopicSession subSession = connection.createTopicSession(
false, Session.AUTO_ACKNOWLEDGE);
// 查找JMS主题
Topic chatTopic = (Topic)ctx.lookup(topicName);
// 创建JSM 发布/订阅
TopicPublisher publisher =
pubSession.createPublisher(chatTopic);
TopicSubscriber subscriber =
subSession.createSubscriber(chatTopic, null, true);
//设置一个JMS消息监听器
subscriber.setMessageListener(this);
this.connection = connection;
this.pubSession = pubSession;
this.publisher = publisher;
this.username = username;
// 启动JMS连接.允许传达消息
connection.start( );
}
/* 接收来自TopicSubscriber的消息
* 当TopicSubscriber从它的主题接收一条消息,
* 调用了它的MessageListener对象的onMessage()方法
* */
public void onMessage(Message message) {
try {
TextMessage textMessage = (TextMessage) message;
String text = textMessage.getText( );
System.out.println(text);
} catch (JMSException jmse){ jmse.printStackTrace( ); }
}
/*使用发布者创建并发送消息 */
protected void writeMessage(String text) throws JMSException {
//TextMessage类型携带了一个String作为有效负载.
//生产出"准备就绪可传达的TextMessage对象"
TextMessage message = pubSession.createTextMessage( );
//MapMessage mapMessage = pubSession.createMapMessage();
message.setText(username+":"+text);
System.out.println(message.getText());
publisher.publish(message);
}
/* 关闭JMS连接 */
public void close( ) throws JMSException {
connection.close( );
}
/* 运行Main */
public static void main(String [] args){
try{
if (args.length!=3)
System.out.println("Factory, Topic, or username missing");
Chat chat = new Chat(args[0],args[1],args[2]);
// 从命令行读取
BufferedReader commandLine = new
java.io.BufferedReader(new InputStreamReader(System.in));
// 键入"exit" 停止运行
while(true){
String s = commandLine.readLine( );
if (s.equalsIgnoreCase("exit")){
chat.close( );
System.exit(0);
} else
chat.writeMessage(s);
}
} catch (Exception e){ e.printStackTrace( ); }
}
}
jar:
javac iteye\JMS_Exception\chat\Chat.java
李雷和韩梅梅
Han Meimei: Hello!
Li Lei:Hello!
Han Meimei:My name is Han Meimei.What is your name?
Li Lei:My name is LI lei.
在前面我们已经定义了一个名称为TopicCF的主题链接工厂.以及名为Topic1的一个Topic主题.因此要为一个名为LiLei.HanMeimei的用户执行Chat.需要使用以下命令
java iteye.JMS_Exception.chat.Chat TopicCF topic1 LiLei
java iteye.JMS_Exception.chat.Chat TopicCF topic1 HanMeimei
图:
- 大小: 70 KB
- 大小: 62.3 KB
- 大小: 39.3 KB
分享到:
相关推荐
ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循开放消息传递协议(Open Message Broker API,也称为JMS,Java消息服务)。ActiveMQ在分布式系统中起着至关重要的作用,它允许应用程序通过发送和接收...
ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循开放消息传递协议(Open Message Broker Protocol,简称AMQP)和Java消息服务(Java Message Service,简称JMS)。在这个"ActiveMQ的点对点与发布/订阅...
Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用集成的标准化接口,它允许应用程序创建、发送、接收和读取消息。JMS被设计用来在分布式环境中传递可靠的数据,使得不同系统之间可以进行...
这个"activemq和spring整合发布消息和订阅消息demo"是用于演示如何在Spring环境中配置和使用ActiveMQ来实现实时的数据通信。现在,我们将深入探讨相关的知识点。 首先,ActiveMQ是Apache软件基金会开发的一个开源...
Weblogic服务器是一款由Oracle公司开发的企业级应用服务器,它提供了丰富的功能和服务,其中包括Java消息服务(JMS,Java Message Service)。JMS是一种标准接口,允许应用程序创建、发送、接收和读取消息。在这个...
2. **发布/订阅(Publish/Subscribe)模型**:另一种JMS模型,消息发布到一个主题(Topic),多个订阅者可以订阅这个主题并接收消息。在这个例子中,可能展示了如何设置发布者和订阅者,以及消息如何广播到所有在线...
在本文中,我们将深入探讨ActiveMQ中的两种主要通信模式:点对点(Point-to-Point)和发布/订阅(Publish/Subscribe),并基于提供的"ActiveMq 点对点 发布订阅demo"进行分析。 1. **点对点通信模式(Point-to-...
《JMS_DEMO——深入理解Java消息服务》 在IT领域,Java消息服务(Java Message Service,简称JMS)是一个标准接口,它允许应用程序创建、发送、接收和读取消息。JMS_DEMO是一个用于演示JMS实际应用的实例,通过这个...
本示例“ActiveMQ-Topic订阅发布模式Demo”主要关注的是发布/订阅模式,这是一种一对多的消息传递方式。在发布/订阅模式中,生产者(Publisher)发送消息到一个主题(Topic),而多个消费者(Subscriber)可以订阅这...
**Java消息服务(Java Message Service,JMS)**是一种在分布式系统中用于应用程序间异步通信的标准接口。它允许应用程序创建、发送、接收和读取消息。在Java中,JMS通常用于解耦生产者(消息发送方)和消费者(消息...
- **日志记录**:分布式系统中的日志收集可以通过JMS主题实现,各个服务节点发布日志消息,日志收集器订阅并处理这些消息,实现跨服务器的日志聚合。 **Apache ActiveMQ介绍** Apache ActiveMQ是流行的开源JMS...
创建Web服务的一般步骤包括:定义服务接口、实现服务、发布服务和调用服务。 Java消息服务(JMS)则是另一种数据传递机制,主要用于应用程序之间的异步通信。它提供了一种标准的API,允许开发者发送和接收消息。JMS...
Java MQDemo是一个基于Java实现的消息队列(Message Queue)演示项目,它主要用于展示如何在Java应用程序中使用消息队列技术。消息队列是一种中间件,它允许不同组件之间异步通信,通过解耦发送者和接收者来提高系统...
ActiveMQ作为Apache基金会的一个开源项目,是Java消息服务(JMS)的一个实现,而Spring框架则广泛应用于Java后端开发,提供了一整套的轻量级容器服务。本教程将重点讲解如何将ActiveMQ与Spring进行整合,以创建一个...
Java消息服务(Java Message Service,JMS)是Java平台中用于企业级应用系统之间进行异步消息传递的一种标准API。通过JMS,开发人员可以编写代码来发送、接收和管理消息,这些消息可以在不同的应用程序之间传输,...
1. 温度传感器不断采集环境温度,并通过JMS将温度数据发布到消息主题或队列。 2. 应用程序中配置了一个Esper引擎,它订阅了相关的JMS消息源,持续接收温度数据。 3. Esper接收到温度数据后,会根据预先定义的规则和...
ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循开放消息传递协议(Open Message Broker Protocol,即AMQP)和Java消息服务(Java Message Service,JMS)规范,为企业级应用提供可靠的消息传递服务。...
Java消息服务(Java Message Service,简称JMS)是Java平台中用于在分布式环境中交换异步消息的标准API。它允许应用程序创建、发送、接收和读取消息,提供了在分布式系统间可靠且高效的数据通信。JMS API 的核心概念...
本项目结合这三者,提供了一个整合的Demo,旨在帮助开发者理解如何在SpringMVC应用中集成JMS和ActiveMQ,实现消息的发布与订阅。 首先,SpringMVC是Spring框架的一部分,专门用于构建Web应用程序的模型-视图-控制器...
JMS提供两种消息模型:点对点(Point-to-Point, P2P)和发布/订阅(Publish/Subscribe)。在P2P模型中,消息从一个生产者发送到一个队列,然后由一个或多个消费者接收;而在发布/订阅模型中,消息发布到一个主题,多...