JMS初探

lib:
jms1.1.jar
activemq-all-5.0.jar

首先启动 activemq.bat或者执行以下代码启动一个broker

import org.apache.activemq.broker.BrokerService;

/**
* This example demonstrates how to run an embedded broker inside your Java code
*
* @version $Revision: 565003 $
*/
public final class EmbeddedBroker {

private EmbeddedBroker() {
}

public static void main(String[] args) throws Exception {
BrokerService broker = new BrokerService();
broker.setUseJmx(true);
broker.addConnector("tcp://localhost:61616");
broker.start();

// now lets wait forever to avoid the JVM terminating immediately
Object lock = new Object();
synchronized (lock) {
lock.wait();
}
}
}



消费端

package com.jms;

import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

public class ConsumerTool implements MessageListener {

private String user = ActiveMQConnection.DEFAULT_USER;

private String password = ActiveMQConnection.DEFAULT_PASSWORD;

private String url = ActiveMQConnection.DEFAULT_BROKER_URL;

private String subject = "TOOL.DEFAULT";

private Destination destination = null;

private Connection connection = null;

private Session session = null;

private MessageConsumer consumer = null;

//初始化
private void initialize() throws JMSException, Exception{
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(user, password, url);
connection = connectionFactory.createConnection();
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
destination = session.createQueue(subject);
consumer = session.createConsumer(destination);
}

//消费消息
public void consumeMessage() throws JMSException, Exception{
initialize();
connection.start();

System.out.println("Consumer:->Begin listening...");
//开始监听
consumer.setMessageListener(this);
//Message message = consumer.receive();
}

//关闭连接
public void close() throws JMSException{
System.out.println("Consumer:->Closing connection");
if (consumer != null) consumer.close();
if (session != null) session.close();
if (connection != null) connection.close();
}

public void onMessage(Message message) {
try{
if (message instanceof TextMessage){
TextMessage txtMsg = (TextMessage) message;
String msg = txtMsg.getText();
System.out.println("Consumer:->Received: " + msg);
} else{
System.out.println("Consumer:->Received: " + message);
}
} catch (JMSException e){
e.printStackTrace();
}
}

}



producter:

package com.jms;

import javax.jms.Connection;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

public class ProducerTool {

private String user = ActiveMQConnection.DEFAULT_USER;

private String password = ActiveMQConnection.DEFAULT_PASSWORD;

private String url = ActiveMQConnection.DEFAULT_BROKER_URL;

private String subject = "TOOL.DEFAULT";

private Destination destination = null;

private Connection connection = null;

private Session session = null;

private MessageProducer producer = null;

//初始化
private void initialize() throws JMSException, Exception{
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(user, password, url);
connection = connectionFactory.createConnection();
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
destination = session.createQueue(subject);
producer = session.createProducer(destination);
producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
}

//发送消息
public void produceMessage(String message) throws JMSException, Exception{
initialize();
TextMessage msg = session.createTextMessage(message);
connection.start();
System.out.println("Producer:->Sending message: " + message);
producer.send(msg);
System.out.println("Producer:->Message sent complete!");
}

//关闭连接
public void close() throws JMSException{
System.out.println("Producer:->Closing connection");
if (producer != null) producer.close();
if (session != null) session.close();
if (connection != null) connection.close();
}

}



下面是一个Broker实现,不属于同一个例子!

package com.jms;

import java.io.IOException;
import java.util.Hashtable;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class MessageBroker extends HttpServlet
{
private ConnectionFactory confactory=null;
private Connection jmsCon=null;
private Destination dest=null;
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
{
this.doPost(req, resp);
}

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
{
Session session;
try
{
String deptId=null;
String deptName=null;
deptId=req.getParameter("deptId");
deptName=req.getParameter("deptName");
session = this.jmsCon.createSession(false, Session.CLIENT_ACKNOWLEDGE);
MessageProducer msgProducer=session.createProducer(dest);
Message textMsg=session.createTextMessage();
textMsg.setStringProperty("deptId", deptId);
textMsg.setStringProperty("deptName", deptName);
msgProducer.send(textMsg);
session.close();
resp.sendRedirect("http://localhost/JmsTestWeb2/");
}
catch (Exception e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}

}
/**
*
*/
public void init(ServletConfig config) throws ServletException
{
super.init(config);
try
{
this.confactory=this.getConnectionFactoryFromLdap();
this.dest=this.getDestinationFromLdap();
this.jmsCon=this.confactory.createConnection();
/** 开启一个会话来创建一个消息消费者,异步监听到来的消息。*/
Session session=jmsCon.createSession(false, Session.CLIENT_ACKNOWLEDGE);
MessageConsumer msgConsumer=session.createConsumer(this.dest);
MessageListenerForOrgMsg msgListener=new MessageListenerForOrgMsg();
msgConsumer.setMessageListener(msgListener);
/** 开启另一个会话来创建另外一个消息消费者,异步监听到来的消息。*/
Session session2=jmsCon.createSession(false, Session.CLIENT_ACKNOWLEDGE);
MessageConsumer msgConsumer2=session2.createConsumer(this.dest);
MessageListenerForOrgMsg2 msgListener2=new MessageListenerForOrgMsg2();
msgConsumer2.setMessageListener(msgListener2);
this.jmsCon.start();
}
catch (Exception e)
{
e.printStackTrace();
}
}
/**
*
* @return
* @throws NamingException
*/
private ConnectionFactory getConnectionFactoryFromLdap() throws NamingException
{
String account="uid=admin,ou=administrators,ou=topologymanagement,o=netscaperoot";//操作LDAP的帐户。默认就是Admin。
String password="111111" ;//帐户Admin的密码。
String root="ou=jmsstore,dc=xindongfang,dc=com"; //所操作的WLS域。也就是LDAP的根节点的DC
Hashtable env = new Hashtable();
env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");//必须这样写,无论用什么LDAP服务器。
env.put(Context.PROVIDER_URL, "ldap://192.168.0.15:2922/" + root);//LDAP服务器的地址:端口。对WLS端口就是7001
env.put(Context.SECURITY_AUTHENTICATION, "simple");//授权界别,可以有三种授权级别,但是如果设为另外两种都无法登录,我也不知道为啥,但是只能设成这个值"none"。
env.put(Context.SECURITY_PRINCIPAL, account );//载入登陆帐户和登录密码
env.put(Context.SECURITY_CREDENTIALS, password);
InitialContext ctx=null;
ConnectionFactory conFacotry=null;
try
{
ctx = new InitialContext(env);//初始化上下文
conFacotry=(ConnectionFactory)ctx.lookup("cn=topicconfac");
System.out.println("get Connection factory success");
return conFacotry;
}

finally
{
if (ctx!=null) ctx.close();
}
}
/**
*
* @return
* @throws NamingException
*/
private Destination getDestinationFromLdap() throws NamingException
{
String account="uid=admin,ou=administrators,ou=topologymanagement,o=netscaperoot";//操作LDAP的帐户。默认就是Admin。
String password="111111" ;//帐户Admin的密码。
String root="ou=jmsstore,dc=xindongfang,dc=com"; //所操作的WLS域。也就是LDAP的根节点的DC
Hashtable env = new Hashtable();
env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");//必须这样写,无论用什么LDAP服务器。
env.put(Context.PROVIDER_URL, "ldap://192.168.0.15:2922/" + root);//LDAP服务器的地址:端口。对WLS端口就是7001
env.put(Context.SECURITY_AUTHENTICATION, "simple");//授权类别,可以有三种授权级别,但是如果设为另外两种都无法登录,我也不知道为啥,但是只能设成这个值"none"。
env.put(Context.SECURITY_PRINCIPAL, account );//载入登陆帐户和登录密码
env.put(Context.SECURITY_CREDENTIALS, password);
InitialContext ctx=null;
Destination dst=null;
try
{
ctx = new InitialContext(env);//初始化上下文
dst=(Destination)ctx.lookup("cn=orgmsg");
System.out.println("get destination success");
return dst;
}
finally
{
if (ctx!=null) ctx.close();
}
}

public void destroy()
{
if (this.jmsCon!=null)
{
try
{
this.jmsCon.close();
}
catch (JMSException e)
{
e.printStackTrace();
}
}
super.destroy();
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值