Queue和Topic的例子_Tomcat, WebLogic及J2EE讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Tomcat, WebLogic及J2EE讨论区 »
总帖数
4
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4284 | 回复: 3   主题: Queue和Topic的例子        下一篇 
yunpeng.xian
注册用户
等级:少校
经验:993
发帖:34
精华:0
注册:1970-1-1
状态:离线
发送短消息息给yunpeng.xian 加好友    发送短消息息给yunpeng.xian 发消息
发表于: IP:您无权察看 2014-8-1 17:27:48 | [全部帖] [楼主帖] 楼主

首先配置weblogic,下面是步骤:

1、选择服务——》消息传递——》JMS服务器

北京联动北方科技有限公司

2、点击新建存储,选着文件存储,点击下一步

北京联动北方科技有限公司

3、填入名称,和目标。目录可以不填会有一个默认目录。点击确定

北京联动北方科技有限公司

4、点击新建存储

北京联动北方科技有限公司

5、选择目标,并单击完成

北京联动北方科技有限公司

选择服务——》消息传递——》JMS模块 选择新建

北京联动北方科技有限公司

勾选服务器

北京联动北方科技有限公司

勾选“是否要向此JMS系统模块中添加资源”

北京联动北方科技有限公司

点击新建

北京联动北方科技有限公司

选着连接工厂

北京联动北方科技有限公司

填写相关名称等,点击下一步

北京联动北方科技有限公司

勾选服务器,并单击完成

北京联动北方科技有限公司

再次新建并选择队列如上建立连接工厂

北京联动北方科技有限公司

点击新建子部署

北京联动北方科技有限公司

北京联动北方科技有限公司

选择子部署并选择目标服务器

北京联动北方科技有限公司

如上一样新建主题 步骤图解如下:

北京联动北方科技有限公司

北京联动北方科技有限公司北京联动北方科技有限公司北京联动北方科技有限公司

建立web程序 代码和目录结构如下

北京联动北方科技有限公司

代码如下:

package test;
import java.util.Properties;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.jms.Session;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class Send {
      /**
      * @param args
      * @throws NamingException
      * @throws JMSException
      */
      public void send() throws NamingException, JMSException {
            String url = "t3://192.168.93.1:7001";
            Properties properties = new Properties();
            properties.put(Context.INITIAL_CONTEXT_FACTORY,
            "weblogic.jndi.WLInitialContextFactory");
            properties.put(Context.PROVIDER_URL, url);
            Context context = new InitialContext(properties);
            //获得JMS信息连接队列工厂
            QueueConnectionFactory connFactory = (QueueConnectionFactory) context.lookup("ConnectionFactory");
            //获得JMS信息连接队列
            QueueConnection queConn = connFactory.createQueueConnection();
            //产生队列session,设置事物模式为false,自动应答消息接收
            QueueSession queSession = queConn.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
            //获得队列
            javax.jms.Queue queue = (javax.jms.Queue) context.lookup("Queue");
            //产生JMS队列发送器
            QueueSender queSender = queSession.createSender(queue);
            //产生JMS消息
            Message msg = queSession.createTextMessage("我的第一个JMS");
            System.out.print("--------------"+msg.toString());
            //发送数据到JMS
            queSender.send(msg);
            System.out.println("发送成功");
            //关闭操作
            queSender.close();
            queSession.close();
            queConn.close();
      }
}
package test;
import java.util.Properties;
import javax.jms.BytesMessage;
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueReceiver;
import javax.jms.QueueSession;
import javax.jms.Session;
import javax.jms.StreamMessage;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class Receiver {
      /**
      * @param args
      * @throws NamingException
      * @throws JMSException
      */
      public void receive() throws NamingException, JMSException {
            String url = "t3://192.168.93.1:7001";
            Properties properties = new Properties();
            properties.put(Context.INITIAL_CONTEXT_FACTORY,
            "weblogic.jndi.WLInitialContextFactory");
            properties.put(Context.PROVIDER_URL, url);
            Context context = new InitialContext(properties);
            //获得JMS信息连接队列工厂
            QueueConnectionFactory connFactory = (QueueConnectionFactory) context.lookup("ConnectionFactory");
            //获得JMS信息连接队列
            QueueConnection queConn = connFactory.createQueueConnection();
            //产生队列session,设置事物模式为false,自动应答消息接收
            QueueSession queSession = queConn.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
            //获得队列
            Queue queue = (Queue) context.lookup("Queue");
            QueueReceiver queReceiver = queSession.createReceiver(queue);
            queReceiver.setMessageListener(new MessageListener(){
                  public void onMessage(Message msg) {
                        String msgText = "";
                        double d = 0;
                        try {
                              if(msg instanceof TextMessage){
                                    msgText = ((TextMessage)msg).getText();
                              }else if(msg instanceof StreamMessage){
                                    msgText = ((StreamMessage)msg).readString();
                                    d = ((StreamMessage)msg).readDouble();
                              }else if(msg instanceof BytesMessage){
                                    byte[] bt = new byte[1024];
                                    ((BytesMessage)msg).readBytes(bt);
                                    msgText = String.valueOf(bt);
                              }else if(msg instanceof MapMessage){
                                    msgText = ((MapMessage)msg).getString("name");
                              }
                        } catch (JMSException e) {
                              // TODO Auto-generated catch block
                              e.printStackTrace();
                        }finally{
                        System.out.println("接收到信息:"+msgText+"----"+d);
                  }
            }
      });
      queConn.start();
}
}
package test2;
import java.util.Properties;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicPublisher;
import javax.jms.TopicSession;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class Publisher {
      public void publisher() throws NamingException, JMSException{
            String url = "t3://localhost:7001";
            Properties properties = new Properties();
            properties.put(Context.INITIAL_CONTEXT_FACTORY,
            "weblogic.jndi.WLInitialContextFactory");
            properties.put(Context.PROVIDER_URL, url);
            Context context = new InitialContext(properties);
            TopicConnectionFactory topFactory = (TopicConnectionFactory) context.lookup("ConnectionFactory");
            TopicConnection topConn = topFactory.createTopicConnection();
            TopicSession topSession = topConn.createTopicSession(false, Session.AUTO_ACKNOWLEDGE);
            Topic topic = (Topic) context.lookup("Topic");
            TopicPublisher topPublisher = topSession.createPublisher(topic);
            Message msg = topSession.createTextMessage("发布杂志");
            topPublisher.publish(msg);
            topPublisher.close();
            topSession.close();
            topConn.close();
      }
}
package test2;
import java.util.Properties;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicSession;
import javax.jms.TopicSubscriber;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class Requester {
      public void requester() throws NamingException, JMSException{
            String url = "t3://localhost:7001";
            Properties properties = new Properties();
            properties.put(Context.INITIAL_CONTEXT_FACTORY,
            "weblogic.jndi.WLInitialContextFactory");
            properties.put(Context.PROVIDER_URL, url);
            Context context = new InitialContext(properties);
            TopicConnectionFactory topFactory = (TopicConnectionFactory) context.lookup("ConnectionFactory");
            TopicConnection topConn = topFactory.createTopicConnection();
            TopicSession topSession = topConn.createTopicSession(false, Session.AUTO_ACKNOWLEDGE);
            Topic topic = (Topic) context.lookup("Topic");
            TopicSubscriber topSubscriber = topSession.createSubscriber(topic);
            topConn.start();
            topSubscriber.setMessageListener(new MessageListener(){
                  public void onMessage(Message message) {
                        // TODO Auto-generated method stub
                        try {
                              if(message instanceof TextMessage){
                                    String msg = ((TextMessage)message).getText();
                                    System.out.println("收到消息:"+msg);
                              }else{
                              System.out.println(message.getClass().getName());
                        }
                  } catch (JMSException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                  }
            }
      });
}
}


由于是事后截的图 JNDI名字不匹配 请读者注意改过来

结果如下:

北京联动北方科技有限公司北京联动北方科技有限公司

可以在控制台中监视queue和Topic也会有相应的结果




赞(0)    操作        顶端 
koei
版主
等级:大校
经验:4180
发帖:7
精华:0
注册:2011-7-21
状态:离线
发送短消息息给koei 加好友    发送短消息息给koei 发消息
发表于: IP:您无权察看 2014-8-4 17:04:29 | [全部帖] [楼主帖] 2  楼

楼主这个,已经都真实跑通了? 北京联动北方科技有限公司



赞(0)    操作        顶端 
yunpeng.xian
注册用户
等级:少校
经验:993
发帖:34
精华:0
注册:1970-1-1
状态:离线
发送短消息息给yunpeng.xian 加好友    发送短消息息给yunpeng.xian 发消息
发表于: IP:您无权察看 2014-8-4 17:58:12 | [全部帖] [楼主帖] 3  楼

对啊 跑通了 不过还有些地方不是很懂 还在研究中



赞(0)    操作        顶端 
yunpeng.xian
注册用户
等级:少校
经验:993
发帖:34
精华:0
注册:1970-1-1
状态:离线
发送短消息息给yunpeng.xian 加好友    发送短消息息给yunpeng.xian 发消息
发表于: IP:您无权察看 2014-8-18 17:25:51 | [全部帖] [楼主帖] 4  楼

     上次做的JMS的例子用的是文件存储,今天尝试了一下用JDBC存储发现代码上不需要改变,只需在建立JMS服务器时指定JDBC存储就可以了,但需要注意的是使用JDBC存储需要建立数据源,而不能将 JDBC 存储配置为使用配置为支持全局事务的 JDBC 数据源。JDBC 存储必须使用使用非 XA JDBC 驱动程序的 JDBC 数据源。也不能在数据源中启用“记录上一个资源”或“仿真两阶段提交”。这个地方不注意的话将根本检测不到JDBC数据源。提供一个网址有一些weblogic的中文帮助文档还不错:http://middleware123.com/weblogic/docs100/ConsoleHelp/taskhelp/stores/CreateJDBCStores.html。并且使用JDBC存储是不需要你关心消息是怎么存储的,服务器会自动在你连接的数据库中生成存储消息的表。



赞(0)    操作        顶端 
总帖数
4
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论