JMS配置文档
附件:http://www.blogjava.net/Files/86mang/JMS.doc
1.
登录WebLogic控制台
2.
新建JMS Server
data:image/s3,"s3://crabby-images/e6bde/e6bde115fba3014ca3ed1b758522313b9bc88fb9" alt=""
3.
点击“new”按钮
data:image/s3,"s3://crabby-images/63bc6/63bc689f0ab5104848ab1ffdc84b7dcb7b359d4f" alt=""
4.
Name改为IbosJMSServer,点击Create a New Store按钮
data:image/s3,"s3://crabby-images/edc20/edc206ab972e34cb2e0cb13b3efa80ee2e80aa64" alt=""
5.
选中File Store,点击“Next”
data:image/s3,"s3://crabby-images/d06cc/d06cc3a36db0d697997cbc9eca4d9816868e3f68" alt=""
6.
Name改为IbosFileStore,点击“OK”。返回到以下页面
data:image/s3,"s3://crabby-images/bffb0/bffb02d513b31ef3a1e2e774652bac14616a4034" alt=""
7.
选中IbosFileStore,点击“Next”
data:image/s3,"s3://crabby-images/93216/932162b87e5eef1a787ae9d87cc956ea31712541" alt=""
8.
选中程序所在的Server,点击“Finish”完成。
9.
新建JMS Modules
data:image/s3,"s3://crabby-images/87f3b/87f3b8c6252b406a567055d8f7a70225010df43a" alt=""
10.
点击“New”
data:image/s3,"s3://crabby-images/517a0/517a0a8cfb9c5c3c8e98bde1d7ed63b879f7c8ee" alt=""
11.
Name改为IbosSystemModule,点击“Next”
data:image/s3,"s3://crabby-images/791b2/791b2d37c0743eae06bd4ce2b0fbddd8e8feddf8" alt=""
12.
选中程序所在Server,点击“Next”
data:image/s3,"s3://crabby-images/2a78a/2a78aea88df854b2f99a9e582156fede71369113" alt=""
13.
点击“Finish”完成。
data:image/s3,"s3://crabby-images/9ea9c/9ea9c8422b8415a5b0f5d192d4a500496437e40d" alt=""
14.
新建QueueConnectionFactory,点击IbosSystemModules
data:image/s3,"s3://crabby-images/8d6fd/8d6fd9279eca1f67353df9ba5b109db2575dcd23" alt=""
15.
点击“New”
data:image/s3,"s3://crabby-images/e42be/e42bec6cbf9e71266de5507a2a447b70f49bc21c" alt=""
16.
选中“Connection
Factory”,点击“Next”
data:image/s3,"s3://crabby-images/32fba/32fbad67c5fa176c02951e7c71577b64f7a5b4fd" alt=""
17.
Name改为IbosQueueConnectionFactory,JNDI Name设为IbosQueueConnectionFactory,点击“Next”
data:image/s3,"s3://crabby-images/21904/219045504c86bdb49842ef5302827cdb00d88211" alt=""
18.
点击“Advanced Targeting”按钮
data:image/s3,"s3://crabby-images/d4a82/d4a8234b92b8ffa933c345163d70ac7454112f06" alt=""
19.
点击“Create a New Subdeployment”
data:image/s3,"s3://crabby-images/dc73e/dc73ee085743a5b06ec0664bf1ebf04937e4e3bc" alt=""
20.
Subdeployment Name改为IbosSubdeployment,点击“Next“
data:image/s3,"s3://crabby-images/bb253/bb25322e7b78009794626f172233713b5ce05e3d" alt=""
21.
选中IbosJMSServer,点击“Finish”
data:image/s3,"s3://crabby-images/6e96e/6e96eff9bcdb17ea790cdf488755456ffd7da816" alt=""
22.
Subdeployment选中IbosSubdeployment,点击“Finish”。
data:image/s3,"s3://crabby-images/425ea/425ea3edc8b39ae59a64a576992d1ad12677dd08" alt=""
23.
新建Queue,点击“New”
data:image/s3,"s3://crabby-images/2a0de/2a0dece1c63ff96ddcee5f0834e338767906011d" alt=""
24.
选中“Queue”,点击“Next”
data:image/s3,"s3://crabby-images/ca073/ca0739006f1cc63c968b7219d62be047bc1527de" alt=""
25.
Name改为“IbosQueue”,JNDI Name改为“IbosQueue”,点击“Next”
data:image/s3,"s3://crabby-images/84e1d/84e1dbf4f17f0bc1a9c546a6866d8688fe79563b" alt=""
26.
Subdeployment选中“IbosSubdeployment”,点击“Finish”完成。
27.
重新启动weblogic服务。
代码如下:
package ibos.control;
import java.util.List;
import javax.ejb.ActivationConfigProperty;
import javax.ejb.EJB;
import javax.ejb.MessageDriven;
import javax.ejb.TransactionAttribute;
import javax.ejb.TransactionAttributeType;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.ObjectMessage;
import javax.jms.TextMessage;
import kernel.jpa.JpaUtil;
import kernel.jpa.NamedQueryParameter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@MessageDriven
(mappedName = "IbosQueue",
name = "TransferQueueListener",
activationConfig = {
@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Queue")
}
)
@TransactionAttribute(TransactionAttributeType.NEVER)
public class TransferQueueListener implements MessageListener {
public static Logger log = LoggerFactory.getLogger(TransferQueueListener.class);
public void onMessage(Message message) {
// TextMessage tmsg = (TextMessage) message;
ObjectMessage objMsg = (ObjectMessage) message;
data:image/s3,"s3://crabby-images/87db9/87db9337486e6758d772829a26342839bc8c1a52" alt=""
} catch (JMSException e) {
log.error(e.getMessage());
e.printStackTrace();
}
}
}
package ibos.control;
import java.io.Serializable;
import java.util.Properties;
import java.util.concurrent.ConcurrentHashMap;
import javax.jms.JMSException;
import javax.jms.ObjectMessage;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class SendJmsUtil {
public static String Default_Queue_Name = "IbosQueue";
public static int Default_IIOP_PORT = 8080;
public static class QueueManagedObject {
QueueConnection conn;
QueueSession session;
Queue queue;
QueueSender sender;
public QueueManagedObject(QueueConnection conn, QueueSession session,
Queue queue, QueueSender sender) {
super();
this.conn = conn;
this.session = session;
this.queue = queue;
this.sender = sender;
}
}
public static ConcurrentHashMap<String, QueueManagedObject> queueManagedObjectMap = new ConcurrentHashMap<String, QueueManagedObject>();
public static void sendMessage(Serializable obj, String ip) throws Exception {
sendMessage(obj, ip, Default_IIOP_PORT, Default_Queue_Name);
}
public static void sendMessage(Serializable obj, String ip, int port,
String queueName) throws Exception {
QueueManagedObject queueManagedObject = getQueueManagedObject(ip, port,
queueName);
ObjectMessage msg = queueManagedObject.session.createObjectMessage(obj);
queueManagedObject.sender.send(msg);
// queueManagedObject.sender.close();
}
public static QueueManagedObject getQueueManagedObject(String ip, int port,
String queueName) throws Exception {
String key = ip + port+queueName
;
QueueManagedObject queueManagedObject = queueManagedObjectMap.get(key);
if (queueManagedObject == null) {
QueueConnection conn;
QueueSession session;
Queue queue;
QueueSender sender;
Properties props = new Properties();
props.setProperty("java.naming.factory.initial","weblogic.jndi.WLInitialContextFactory");
String url = "t3://" + ip + ":" + port;
props.setProperty("java.naming.provider.url", url);
InitialContext ctx = new InitialContext(props);
QueueConnectionFactory qcf = (QueueConnectionFactory) ctx
.lookup("IbosQueueConnectionFactory");
conn = qcf.createQueueConnection();
session = conn.createQueueSession(false,
QueueSession.AUTO_ACKNOWLEDGE);
queue = (Queue) ctx.lookup(queueName);
sender = session.createSender(queue);
queueManagedObject = new QueueManagedObject(conn, session,
queue, sender);
queueManagedObjectMap.put(key, queueManagedObject);
}
return queueManagedObject;
}
}
附件:http://www.blogjava.net/Files/86mang/JMS.doc
posted on 2010-05-05 10:43
身在半空 阅读(4211)
评论(0) 编辑 收藏