weblogic JMS 初体验P2P模式
2010-07-09 15:22
218 查看
程序运行前,需要编译wlfullclient.jar
主要步骤为
1.通过JNDI查询ConnectionFactory
2.通过工厂建立连接connection
3.创建session
程序简单,直接代码
下面是P2P的生成者
package com.test;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class JMSP2PSend {
public static void main(String[] args) {
System.setProperty(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory");
System.setProperty(Context.PROVIDER_URL, "t3://localhost:7001");
QueueConnection connection = null;
QueueSession session = null;
Context ctx = null;
try {
ctx = new InitialContext();
//1.通过JNDI查询ConnectionFactory
QueueConnectionFactory factory = (QueueConnectionFactory) ctx.lookup("jms/connectionFactory");
//2.通过工厂建立连接connection
connection = factory.createQueueConnection();
//3.创建session
session = connection.createQueueSession(false,QueueSession.AUTO_ACKNOWLEDGE);
//4.创建Destination
Destination destination = (Destination) ctx.lookup("jms/fileQueue");
//5.创建MessageProducer(生产)或者MessageConsumer(消费)
MessageProducer mp = session.createProducer(destination);
//构造消息体
TextMessage tm = session.createTextMessage();
tm.setText("csdn tczxg");
tm.setStringProperty("user", "嘿嘿,JMS挺简单的。。。");
mp.send(tm);
} catch (NamingException ne) {
ne.printStackTrace();
} catch (JMSException jse) {
jse.printStackTrace();
} finally {
if (session != null)
try {
session.close();
} catch (JMSException e) {
}
if (connection != null)
try {
connection.close();
} catch (JMSException e) {
}
if (ctx != null)
try {
ctx.close();
} catch (NamingException e) {
}
}
}
}
下面是P2P jms 消费者代码
package com.test;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class JMSP2PReciver {
/**
* @param args
*/
public static void main(String[] args) {
System.setProperty(Context.INITIAL_CONTEXT_FACTORY,
"weblogic.jndi.WLInitialContextFactory");
System.setProperty(Context.PROVIDER_URL, "t3://localhost:7001");
QueueConnection connection = null;
QueueSession session = null;
Context ctx = null;
try {
ctx = new InitialContext();
//1.通过JNDI查询ConnectionFactory
QueueConnectionFactory factory = (QueueConnectionFactory) ctx.lookup("jms/connectionFactory");
//2.通过工厂建立连接connection
connection = factory.createQueueConnection();
//3.创建session
session = connection.createQueueSession(false,QueueSession.AUTO_ACKNOWLEDGE);
//4.创建Destination
Destination destination = (Destination) ctx.lookup("jms/fileQueue");
//5.创建MessageProducer(生产)或者MessageConsumer(消费)
MessageConsumer mc = session.createConsumer(destination);
connection.start();
//构造消息体
Message message = mc.receive();
if(message instanceof TextMessage){
TextMessage tm = (TextMessage) message ;
String user = tm.getStringProperty("user");
System.out.println(tm.getText() + ", user : "+user);
}
connection.close();
} catch (NamingException ne) {
ne.printStackTrace();
} catch (JMSException jse) {
jse.printStackTrace();
} finally {
if (session != null)
try {
session.close();
} catch (JMSException e) {
}
if (ctx != null)
try {
ctx.close();
} catch (NamingException e) {
}
}
}
}
主要步骤为
1.通过JNDI查询ConnectionFactory
2.通过工厂建立连接connection
3.创建session
程序简单,直接代码
下面是P2P的生成者
package com.test;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class JMSP2PSend {
public static void main(String[] args) {
System.setProperty(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory");
System.setProperty(Context.PROVIDER_URL, "t3://localhost:7001");
QueueConnection connection = null;
QueueSession session = null;
Context ctx = null;
try {
ctx = new InitialContext();
//1.通过JNDI查询ConnectionFactory
QueueConnectionFactory factory = (QueueConnectionFactory) ctx.lookup("jms/connectionFactory");
//2.通过工厂建立连接connection
connection = factory.createQueueConnection();
//3.创建session
session = connection.createQueueSession(false,QueueSession.AUTO_ACKNOWLEDGE);
//4.创建Destination
Destination destination = (Destination) ctx.lookup("jms/fileQueue");
//5.创建MessageProducer(生产)或者MessageConsumer(消费)
MessageProducer mp = session.createProducer(destination);
//构造消息体
TextMessage tm = session.createTextMessage();
tm.setText("csdn tczxg");
tm.setStringProperty("user", "嘿嘿,JMS挺简单的。。。");
mp.send(tm);
} catch (NamingException ne) {
ne.printStackTrace();
} catch (JMSException jse) {
jse.printStackTrace();
} finally {
if (session != null)
try {
session.close();
} catch (JMSException e) {
}
if (connection != null)
try {
connection.close();
} catch (JMSException e) {
}
if (ctx != null)
try {
ctx.close();
} catch (NamingException e) {
}
}
}
}
下面是P2P jms 消费者代码
package com.test;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class JMSP2PReciver {
/**
* @param args
*/
public static void main(String[] args) {
System.setProperty(Context.INITIAL_CONTEXT_FACTORY,
"weblogic.jndi.WLInitialContextFactory");
System.setProperty(Context.PROVIDER_URL, "t3://localhost:7001");
QueueConnection connection = null;
QueueSession session = null;
Context ctx = null;
try {
ctx = new InitialContext();
//1.通过JNDI查询ConnectionFactory
QueueConnectionFactory factory = (QueueConnectionFactory) ctx.lookup("jms/connectionFactory");
//2.通过工厂建立连接connection
connection = factory.createQueueConnection();
//3.创建session
session = connection.createQueueSession(false,QueueSession.AUTO_ACKNOWLEDGE);
//4.创建Destination
Destination destination = (Destination) ctx.lookup("jms/fileQueue");
//5.创建MessageProducer(生产)或者MessageConsumer(消费)
MessageConsumer mc = session.createConsumer(destination);
connection.start();
//构造消息体
Message message = mc.receive();
if(message instanceof TextMessage){
TextMessage tm = (TextMessage) message ;
String user = tm.getStringProperty("user");
System.out.println(tm.getText() + ", user : "+user);
}
connection.close();
} catch (NamingException ne) {
ne.printStackTrace();
} catch (JMSException jse) {
jse.printStackTrace();
} finally {
if (session != null)
try {
session.close();
} catch (JMSException e) {
}
if (ctx != null)
try {
ctx.close();
} catch (NamingException e) {
}
}
}
}
相关文章推荐
- weblogic JMS 初体验Topic模式
- JMS的两种模式 P2P,PUB/SUB
- JMS的两种模式 P2P,PUB/SUB 消息发送
- JMS点对点(P2P)模式示例
- jms 的两种模式,p2p ,publish/substrib
- 迎接下一代购物模式,体验全新的移动支付
- JMS-activeMq发布订阅模式(非持久订阅)
- 24种设计模式的体验
- JMS(四): 点对点模型(P2P)
- 体验编程的艺术-设计模式
- Android透明状态栏效果和沉浸式模式体验
- weblogic集群及jms配置
- 商业模式(三):P2P网贷平台,毛利润测算
- weblogic 下的JMS开发与配置详解(第一部分)
- P2P网贷第三方托管模式存在5大缺陷,托管机构才是最大赢家
- EJB3.0学习笔记---MDBbean--区分P2P模式和Pub/Sub模式的示例
- 美女体验小米无人机4K版:直接解锁新手模式
- P2P网贷中的4种理财业务模式
- C++设计模式的Builder模式生活中的体验