JMS系列(二)-java操作JMS Queue實(shí)例

上一篇文章中,介紹了如何在weblogic中創(chuàng)建jms相關(guān)資源显熏,下面要介紹如何通過(guò)java向jms隊(duì)列中寫(xiě)入消息以及如何從jms隊(duì)列中取出消息蔚万。
要使用weblogic的jms蚁飒,需要引入以下兩個(gè)包

  • javax.jms.jar
  • wlfullclient.jar
    如果是使用jdeveloper開(kāi)發(fā)袖瞻,直接引入以下兩個(gè)Library即可

消息發(fā)送

java將消息發(fā)送到消息隊(duì)列中迷扇,需要經(jīng)過(guò)以下步驟

  • 連接jms服務(wù)器
  • 獲取連接工廠(chǎng)(Connection Factory)
  • 通過(guò)連接工廠(chǎng)創(chuàng)建隊(duì)列連接(QueueConnection)
  • 通過(guò)隊(duì)列連接創(chuàng)建隊(duì)列會(huì)話(huà)(QueueSession)
  • 通過(guò)隊(duì)列會(huì)話(huà)創(chuàng)建隊(duì)列生產(chǎn)者(Sender/Product)
  • 創(chuàng)建消息(Message)
  • 通過(guò)生產(chǎn)者將消息發(fā)送到隊(duì)列中
    具體代碼實(shí)現(xiàn):
package asan.demo.jms;
import java.util.Hashtable;
import javax.jms.JMSException;
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.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;

public class JMSSender {
    private QueueSender sender = null;
    private QueueSession session = null;
    private static final String JMS_FACTORY_JNDI = "jms/jms_test_connection_factory1";
    private static final String JMS_QUEUE_JNDI = "jms/jms_test_queue";

    public JMSSender() {
        super();
    }

    public void sendMessage(String msg) {
        TextMessage textMsg;
        try {
            if (this.sender == null) {
                this.init();
            }
            textMsg = session.createTextMessage();
            textMsg.setText(msg);
            sender.send(textMsg);
        } catch (JMSException e) {
            e.printStackTrace();
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
//    1. 連接jms服務(wù)器
//    2. 獲取連接工廠(chǎng)(Connection Factory)
//    3. 通過(guò)連接工廠(chǎng)創(chuàng)建隊(duì)列連接(QueueConnection)
//    4. 通過(guò)隊(duì)列連接創(chuàng)建隊(duì)列會(huì)話(huà)(QueueSession)
//    5. 通過(guò)隊(duì)列會(huì)話(huà)創(chuàng)建隊(duì)列生產(chǎn)者(Sender/Product)
//    6. 創(chuàng)建消息(Message)
//    7. 通過(guò)生產(chǎn)者將消息發(fā)送到隊(duì)列中
    private void init() throws NamingException, JMSException {
        Hashtable properties = new Hashtable();
        properties.put(Context.INITIAL_CONTEXT_FACTORY,
                       "weblogic.jndi.WLInitialContextFactory");
        properties.put(Context.PROVIDER_URL, "t3://127.0.0.1:7101");
        properties.put(Context.SECURITY_PRINCIPAL, "weblogic");
        properties.put(Context.SECURITY_CREDENTIALS, "weblogic1");
        InitialContext ctx = new InitialContext(properties);
        QueueConnectionFactory jmsFactory =
            (QueueConnectionFactory)ctx.lookup(JMS_FACTORY_JNDI);
        QueueConnection jmsConn = jmsFactory.createQueueConnection();
        session = jmsConn.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
        Queue queue = (Queue)ctx.lookup(JMS_QUEUE_JNDI);
        sender = session.createSender(queue);
    }
    
    public static void main(String[]cmd){
        JMSSender sender=new JMSSender();
        sender.sendMessage("hello world");
    }
}

運(yùn)行程序后登錄console瑟蜈,進(jìn)入domain->Services->Messaging->JMS Module->jms_test_module->jms_test_queue在Monitoring頁(yè)面可以看到隊(duì)列中增加一條消息,點(diǎn)擊Show Messages可以查看消息詳細(xì)內(nèi)容

消息接收

java從消息隊(duì)列中獲取消息姐帚,需要經(jīng)過(guò)以下步驟

  • 連接jms服務(wù)器
  • 獲取連接工廠(chǎng)(Connection Factory)
  • 通過(guò)連接工廠(chǎng)創(chuàng)建隊(duì)列連接(QueueConnection)
  • 通過(guò)隊(duì)列連接創(chuàng)建隊(duì)列會(huì)話(huà)(QueueSession)
  • 通過(guò)隊(duì)列會(huì)話(huà)創(chuàng)建隊(duì)列消費(fèi)者(Reciver/Consumer)
  • 接收消息(Message)

和消息發(fā)送到步驟差不多吏垮。
具體代碼實(shí)現(xiàn):

package asan.demo.jms;

import java.util.Hashtable;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSession;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;

public class JMSReciver {
    private MessageConsumer reciver = null;
    private static final String JMS_FACTORY_JNDI = "jms/jms_test_connection_factory1";
    private static final String JMS_QUEUE_JNDI = "jms/jms_test_queue";
    public JMSReciver() {
        super();
    }
    public void reciveMessage() {
        try {
            if (this.reciver == null) {
                this.init();
            }
            System.out.println("waiting to recive message from jms queue "+JMS_QUEUE_JNDI);
            while(true){
                Message msg=reciver.receive();
                if(msg instanceof TextMessage){
                    TextMessage textMsg=(TextMessage)msg;
                    System.out.println("recive jms message:"+textMsg.getText());
                }
            }
        } catch (JMSException e) {
            e.printStackTrace();
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
    //    1. 連接jms服務(wù)器
    //    2. 獲取連接工廠(chǎng)(Connection Factory)
    //    3. 通過(guò)連接工廠(chǎng)創(chuàng)建隊(duì)列連接(QueueConnection)
    //    4. 通過(guò)隊(duì)列連接創(chuàng)建隊(duì)列會(huì)話(huà)(QueueSession)
    //    5. 通過(guò)隊(duì)列會(huì)話(huà)創(chuàng)建隊(duì)列消費(fèi)者(Reciver/Consumer)
    //    6. 接收消息(Message)
    private void init() throws NamingException, JMSException {
        Hashtable properties = new Hashtable();
        properties.put(Context.INITIAL_CONTEXT_FACTORY,
                       "weblogic.jndi.WLInitialContextFactory");
        properties.put(Context.PROVIDER_URL, "t3://127.0.0.1:7101");
        properties.put(Context.SECURITY_PRINCIPAL, "weblogic");
        properties.put(Context.SECURITY_CREDENTIALS, "weblogic1");
        InitialContext ctx = new InitialContext(properties);
        QueueConnectionFactory jmsFactory =
            (QueueConnectionFactory)ctx.lookup(JMS_FACTORY_JNDI);
        QueueConnection jmsConn = jmsFactory.createQueueConnection();
        QueueSession session = jmsConn.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
        Queue queue = (Queue)ctx.lookup(JMS_QUEUE_JNDI);
        reciver = session.createReceiver(queue);
        jmsConn.start();
    }
    
    public static void main(String[]cmd){
        JMSReciver consumer=new JMSReciver();
        consumer.reciveMessage();
    }
}

運(yùn)行程序,控制臺(tái)打印出隊(duì)列中消息

JMS客戶(hù)端

為了更清楚了解jms消息發(fā)送過(guò)程,這邊寫(xiě)了一個(gè)客戶(hù)端罐旗,該客戶(hù)端有兩種模式膳汪,當(dāng)作為生產(chǎn)者可以在控制臺(tái)輸入消息發(fā)送到消息隊(duì)列中,當(dāng)作為消費(fèi)者九秀,一旦消息隊(duì)列中有消息產(chǎn)生遗嗽,立刻將消息打印到控制臺(tái)。
客戶(hù)端代碼如下:

package asan.demo.jms;

import java.util.Scanner;

public class JMSClient {
    public JMSClient() {
        super();
    }

    public static void help() {
        System.out.println("Usage:java -jar JMSClient.jar sender/reciver");
        System.out.println("sender:向jms隊(duì)列發(fā)送消息");
        System.out.println("reciver:從隊(duì)列中取出消息");
    }

    public static void main(String[] cmd) {
        if (cmd.length == 0) {
            help();
            return;
        }
        String mode = cmd[0];
        if ("sender".equalsIgnoreCase(mode)) {
            JMSSender sender = new JMSSender();
            Scanner sc = new Scanner(System.in);
            System.out.println("input you message(input end to exit):");
            while (true) {
                String msg = sc.nextLine();
                if ("end".equalsIgnoreCase(msg)) {
                    return;
                }
                sender.sendMessage(msg);
            }
        } else {
            JMSReciver consumer = new JMSReciver();
            consumer.reciveMessage();
        }
    }
}

將代碼打包(關(guān)于如何打包參考這篇文章)鼓蜒,jar名稱(chēng)為JMSClient.jar痹换,執(zhí)行以下命令將客戶(hù)端作為生產(chǎn)者運(yùn)行

java -jar JMSClient.jar sender

重新打開(kāi)一個(gè)控制臺(tái),執(zhí)行以下命令將客戶(hù)端作為消費(fèi)者運(yùn)行

java -jar JMSClient.jar reciver

在第一個(gè)控制臺(tái)中輸入消息友酱,消息立馬在第二個(gè)控制臺(tái)輸出


程序稍加改造就能變成一個(gè)實(shí)時(shí)點(diǎn)對(duì)點(diǎn)聊天程序晴音,思路是在weblogic中創(chuàng)建兩個(gè)隊(duì)列每個(gè)客戶(hù)端對(duì)應(yīng)一個(gè)隊(duì)列柔纵,兩個(gè)客戶(hù)端分別向?qū)Ψ疥?duì)列發(fā)送消息并從自己的隊(duì)列中獲取消息缔杉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市搁料,隨后出現(xiàn)的幾起案子或详,更是在濱河造成了極大的恐慌系羞,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,383評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件霸琴,死亡現(xiàn)場(chǎng)離奇詭異椒振,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)梧乘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)澎迎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人选调,你說(shuō)我怎么就攤上這事夹供。” “怎么了仁堪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,852評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵哮洽,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我弦聂,道長(zhǎng)鸟辅,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,621評(píng)論 1 284
  • 正文 為了忘掉前任莺葫,我火速辦了婚禮匪凉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘捺檬。我一直安慰自己洒缀,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布欺冀。 她就那樣靜靜地躺著树绩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪隐轩。 梳的紋絲不亂的頭發(fā)上饺饭,一...
    開(kāi)封第一講書(shū)人閱讀 49,929評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音职车,去河邊找鬼瘫俊。 笑死,一個(gè)胖子當(dāng)著我的面吹牛悴灵,可吹牛的內(nèi)容都是我干的扛芽。 我是一名探鬼主播,決...
    沈念sama閱讀 39,076評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼积瞒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼川尖!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起茫孔,我...
    開(kāi)封第一講書(shū)人閱讀 37,803評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤叮喳,失蹤者是張志新(化名)和其女友劉穎被芳,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體馍悟,經(jīng)...
    沈念sama閱讀 44,265評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡畔濒,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了锣咒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片侵状。...
    茶點(diǎn)故事閱讀 38,716評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖毅整,靈堂內(nèi)的尸體忽然破棺而出壹将,到底是詐尸還是另有隱情,我是刑警寧澤毛嫉,帶...
    沈念sama閱讀 34,395評(píng)論 4 333
  • 正文 年R本政府宣布诽俯,位于F島的核電站,受9級(jí)特大地震影響承粤,放射性物質(zhì)發(fā)生泄漏暴区。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評(píng)論 3 316
  • 文/蒙蒙 一辛臊、第九天 我趴在偏房一處隱蔽的房頂上張望仙粱。 院中可真熱鬧,春花似錦彻舰、人聲如沸伐割。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)隔心。三九已至,卻和暖如春尚胞,著一層夾襖步出監(jiān)牢的瞬間硬霍,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,027評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工笼裳, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留唯卖,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,488評(píng)論 2 361
  • 正文 我出身青樓躬柬,卻偏偏與公主長(zhǎng)得像拜轨,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子允青,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理橄碾,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,637評(píng)論 18 139
  • ActiveMQ 即時(shí)通訊服務(wù) 淺析http://www.cnblogs.com/hoojo/p/active_m...
    bboymonk閱讀 1,481評(píng)論 0 11
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,778評(píng)論 6 342
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法堪嫂,類(lèi)相關(guān)的語(yǔ)法,內(nèi)部類(lèi)的語(yǔ)法木柬,繼承相關(guān)的語(yǔ)法皆串,異常的語(yǔ)法,線(xiàn)程的語(yǔ)...
    子非魚(yú)_t_閱讀 31,599評(píng)論 18 399
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,805評(píng)論 0 11