`

初JMS(java消息服务发布/订阅demo_01)

阅读更多

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点对点和发布/订阅模式demo

    ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循开放消息传递协议(Open Message Broker API,也称为JMS,Java消息服务)。ActiveMQ在分布式系统中起着至关重要的作用,它允许应用程序通过发送和接收...

    ActiveMQ的点对点与发布/订阅模式小demo

    ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循开放消息传递协议(Open Message Broker Protocol,简称AMQP)和Java消息服务(Java Message Service,简称JMS)。在这个"ActiveMQ的点对点与发布/订阅...

    JMS demo 及 资料

    Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用集成的标准化接口,它允许应用程序创建、发送、接收和读取消息。JMS被设计用来在分布式环境中传递可靠的数据,使得不同系统之间可以进行...

    activemq和spring整合发布消息和订阅消息demo

    这个"activemq和spring整合发布消息和订阅消息demo"是用于演示如何在Spring环境中配置和使用ActiveMQ来实现实时的数据通信。现在,我们将深入探讨相关的知识点。 首先,ActiveMQ是Apache软件基金会开发的一个开源...

    Weblogic提供JMS服务Demo

    Weblogic服务器是一款由Oracle公司开发的企业级应用服务器,它提供了丰富的功能和服务,其中包括Java消息服务(JMS,Java Message Service)。JMS是一种标准接口,允许应用程序创建、发送、接收和读取消息。在这个...

    JMS的一个非常好的demo

    2. **发布/订阅(Publish/Subscribe)模型**:另一种JMS模型,消息发布到一个主题(Topic),多个订阅者可以订阅这个主题并接收消息。在这个例子中,可能展示了如何设置发布者和订阅者,以及消息如何广播到所有在线...

    ActiveMq 点对点 发布订阅demo

    在本文中,我们将深入探讨ActiveMQ中的两种主要通信模式:点对点(Point-to-Point)和发布/订阅(Publish/Subscribe),并基于提供的"ActiveMq 点对点 发布订阅demo"进行分析。 1. **点对点通信模式(Point-to-...

    JMS_DEMO

    《JMS_DEMO——深入理解Java消息服务》 在IT领域,Java消息服务(Java Message Service,简称JMS)是一个标准接口,它允许应用程序创建、发送、接收和读取消息。JMS_DEMO是一个用于演示JMS实际应用的实例,通过这个...

    ActiveMQ-Topic订阅发布模式Demo

    本示例“ActiveMQ-Topic订阅发布模式Demo”主要关注的是发布/订阅模式,这是一种一对多的消息传递方式。在发布/订阅模式中,生产者(Publisher)发送消息到一个主题(Topic),而多个消费者(Subscriber)可以订阅这...

    Jms做的一些的demo

    **Java消息服务(Java Message Service,JMS)**是一种在分布式系统中用于应用程序间异步通信的标准接口。它允许应用程序创建、发送、接收和读取消息。在Java中,JMS通常用于解耦生产者(消息发送方)和消费者(消息...

    JMS消息队列机制及案例

    - **日志记录**:分布式系统中的日志收集可以通过JMS主题实现,各个服务节点发布日志消息,日志收集器订阅并处理这些消息,实现跨服务器的日志聚合。 **Apache ActiveMQ介绍** Apache ActiveMQ是流行的开源JMS...

    demo.zip_DEMO

    创建Web服务的一般步骤包括:定义服务接口、实现服务、发布服务和调用服务。 Java消息服务(JMS)则是另一种数据传递机制,主要用于应用程序之间的异步通信。它提供了一种标准的API,允许开发者发送和接收消息。JMS...

    java MqDemo

    Java MQDemo是一个基于Java实现的消息队列(Message Queue)演示项目,它主要用于展示如何在Java应用程序中使用消息队列技术。消息队列是一种中间件,它允许不同组件之间异步通信,通过解耦发送者和接收者来提高系统...

    activeMQ_spring_Demo.zip_DEMO_activemq_activemq spring_rowbv3

    ActiveMQ作为Apache基金会的一个开源项目,是Java消息服务(JMS)的一个实现,而Spring框架则广泛应用于Java后端开发,提供了一整套的轻量级容器服务。本教程将重点讲解如何将ActiveMQ与Spring进行整合,以创建一个...

    消息队列入门项目demo

    Java消息服务(Java Message Service,JMS)是Java平台中用于企业级应用系统之间进行异步消息传递的一种标准API。通过JMS,开发人员可以编写代码来发送、接收和管理消息,这些消息可以在不同的应用程序之间传输,...

    esper和jms做的小demo

    1. 温度传感器不断采集环境温度,并通过JMS将温度数据发布到消息主题或队列。 2. 应用程序中配置了一个Esper引擎,它订阅了相关的JMS消息源,持续接收温度数据。 3. Esper接收到温度数据后,会根据预先定义的规则和...

    ActiveMQ通信方式点对点和订阅发布

    ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循开放消息传递协议(Open Message Broker Protocol,即AMQP)和Java消息服务(Java Message Service,JMS)规范,为企业级应用提供可靠的消息传递服务。...

    JMS Api Demo

    Java消息服务(Java Message Service,简称JMS)是Java平台中用于在分布式环境中交换异步消息的标准API。它允许应用程序创建、发送、接收和读取消息,提供了在分布式系统间可靠且高效的数据通信。JMS API 的核心概念...

    SpringMVC+JMS(ActiveMQ)整合的Demo

    本项目结合这三者,提供了一个整合的Demo,旨在帮助开发者理解如何在SpringMVC应用中集成JMS和ActiveMQ,实现消息的发布与订阅。 首先,SpringMVC是Spring框架的一部分,专门用于构建Web应用程序的模型-视图-控制器...

    EJB消息驱动bean Demo

    JMS提供两种消息模型:点对点(Point-to-Point, P2P)和发布/订阅(Publish/Subscribe)。在P2P模型中,消息从一个生产者发送到一个队列,然后由一个或多个消费者接收;而在发布/订阅模型中,消息发布到一个主题,多...

Global site tag (gtag.js) - Google Analytics