<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    I'll be back!

      Focus on BPM, celebrate PegaRULES Process Commander (PRPC)
    posts - 76, comments - 161, trackbacks - 0, articles - 2
      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

    JNDI概述

    Posted on 2007-10-21 12:18 zolly 閱讀(2245) 評(píng)論(6)  編輯  收藏
    JNDI是 Java 命名與目錄接口(Java Naming and Directory Interface),在J2EE規(guī)范中是重要的規(guī)范之一,不少專(zhuān)家認(rèn)為,沒(méi)有透徹理解JNDI的意義和作用,就沒(méi)有真正掌握J(rèn)2EE特別是EJB的知識(shí)。
    那么,JNDI到底起什么作用?

    要了解JNDI的作用,我們可以從“如果不用JNDI我們?cè)鯓幼觯坑昧薐NDI后我們又將怎樣做?”這個(gè)問(wèn)題來(lái)探討。

    沒(méi)有JNDI的做法:
    程序員開(kāi)發(fā)時(shí),知道要開(kāi)發(fā)訪(fǎng)問(wèn)MySQL數(shù)據(jù)庫(kù)的應(yīng)用,于是將一個(gè)對(duì) MySQL JDBC 驅(qū)動(dòng)程序類(lèi)的引用進(jìn)行了編碼,并通過(guò)使用適當(dāng)?shù)?JDBC URL 連接到數(shù)據(jù)庫(kù)。
    就像以下代碼這樣:
    Connection conn=null;
    try {
    Class.forName("com.mysql.jdbc.Driver",
    true, Thread.currentThread().getContextClassLoader());
    conn=DriverManager.getConnection("jdbc:mysql://MyDBServer?user=qingfeng&password=mingyue");
    /* 使用conn并進(jìn)行SQL操作 */
    ......
    conn.close();
    }
    catch(Exception e) {
    e.printStackTrace();
    }
    finally {
    if(conn!=null) {
    try {
    conn.close();
    } catch(SQLException e) {}
    }
    }

    這是傳統(tǒng)的做法,也是以前非Java程序員(如Delphi、VB等)常見(jiàn)的做法。這種做法一般在小規(guī)模的開(kāi)發(fā)過(guò)程中不會(huì)產(chǎn)生問(wèn)題,只要程序員熟悉Java語(yǔ)言、了解JDBC技術(shù)和MySQL,可以很快開(kāi)發(fā)出相應(yīng)的應(yīng)用程序。

    沒(méi)有JNDI的做法存在的問(wèn)題:
    1、數(shù)據(jù)庫(kù)服務(wù)器名稱(chēng)MyDBServer 、用戶(hù)名和口令都可能需要改變,由此引發(fā)JDBC URL需要修改;
    2、數(shù)據(jù)庫(kù)可能改用別的產(chǎn)品,如改用DB2或者Oracle,引發(fā)JDBC驅(qū)動(dòng)程序包和類(lèi)名需要修改;
    3、隨著實(shí)際使用終端的增加,原配置的連接池參數(shù)可能需要調(diào)整;
    4、......

    解決辦法:
    程序員應(yīng)該不需要關(guān)心“具體的數(shù)據(jù)庫(kù)后臺(tái)是什么?JDBC驅(qū)動(dòng)程序是什么?JDBC URL格式是什么?訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的用戶(hù)名和口令是什么?”等等這些問(wèn)題,程序員編寫(xiě)的程序應(yīng)該沒(méi)有對(duì) JDBC 驅(qū)動(dòng)程序的引用,沒(méi)有服務(wù)器名稱(chēng),沒(méi)有用戶(hù)名稱(chēng)或口令 —— 甚至沒(méi)有數(shù)據(jù)庫(kù)池或連接管理。而是把這些問(wèn)題交給J2EE容器來(lái)配置和管理,程序員只需要對(duì)這些配置和管理進(jìn)行引用即可。

    由此,就有了JNDI。

    用了JNDI之后的做法:
    首先,在在J2EE容器中配置JNDI參數(shù),定義一個(gè)數(shù)據(jù)源,也就是JDBC引用參數(shù),給這個(gè)數(shù)據(jù)源設(shè)置一個(gè)名稱(chēng);然后,在程序中,通過(guò)數(shù)據(jù)源名稱(chēng)引用數(shù)據(jù)源從而訪(fǎng)問(wèn)后臺(tái)數(shù)據(jù)庫(kù)。
    具體操作如下(以JBoss為例):
    1、配置數(shù)據(jù)源
    在JBoss的 D:\jboss420GA\docs\examples\jca 文件夾下面,有很多不同數(shù)據(jù)庫(kù)引用的數(shù)據(jù)源定義模板。將其中的 mysql-ds.xml 文件Copy到你使用的服務(wù)器下,如 D:\jboss420GA\server\default\deploy。
    修改 mysql-ds.xml 文件的內(nèi)容,使之能通過(guò)JDBC正確訪(fǎng)問(wèn)你的MySQL數(shù)據(jù)庫(kù),如下:
    <?xml version="1.0" encoding="UTF-8"?>
    <datasources>
    <local-tx-datasource>
        <jndi-name>
    MySqlDS</jndi-name>
        <connection-url>
    jdbc:mysql://localhost:3306/lw</connection-url>
        <driver-class>
    com.mysql.jdbc.Driver</driver-class>
        <user-name>
    root</user-name>
        <password>
    rootpassword</password>
    <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>
        <metadata>
           <type-mapping>
    mySQL</type-mapping>
        </metadata>
    </local-tx-datasource>
    </datasources>


    這里,定義了一個(gè)名為MySqlDS的數(shù)據(jù)源,其參數(shù)包括JDBC的URL,驅(qū)動(dòng)類(lèi)名,用戶(hù)名及密碼等。

    2、在程序中引用數(shù)據(jù)源:
    Connection conn=null;
    try {
    Context ctx=new InitialContext();
    Object datasourceRef=ctx.lookup("java:MySqlDS"); //引用數(shù)據(jù)源
    DataSource ds=(Datasource)datasourceRef;
    conn=ds.getConnection();
    /* 使用conn進(jìn)行數(shù)據(jù)庫(kù)SQL操作 */
    ......
    c.close();
    }
    catch(Exception e) {
    e.printStackTrace();
    }
    finally {
    if(conn!=null) {
    try {
    conn.close();
    } catch(SQLException e) { }
    }
    }
    直接使用JDBC或者通過(guò)JNDI引用數(shù)據(jù)源的編程代碼量相差無(wú)幾,但是現(xiàn)在的程序可以不用關(guān)心具體JDBC參數(shù)了。
    在系統(tǒng)部署后,如果數(shù)據(jù)庫(kù)的相關(guān)參數(shù)變更,只需要重新配置 mysql-ds.xml 修改其中的JDBC參數(shù),只要保證數(shù)據(jù)源的名稱(chēng)不變,那么程序源代碼就無(wú)需修改。

    由此可見(jiàn),JNDI避免了程序與數(shù)據(jù)庫(kù)之間的緊耦合,使應(yīng)用更加易于配置、易于部署。

    JNDI的擴(kuò)展:
    JNDI在滿(mǎn)足了數(shù)據(jù)源配置的要求的基礎(chǔ)上,還進(jìn)一步擴(kuò)充了作用:所有與系統(tǒng)外部的資源的引用,都可以通過(guò)JNDI定義和引用。

    所以,在J2EE規(guī)范中,J2EE 中的資源并不局限于 JDBC 數(shù)據(jù)源。引用的類(lèi)型有很多,其中包括資源引用(已經(jīng)討論過(guò))、環(huán)境實(shí)體和 EJB 引用。特別是 EJB 引用,它暴露了 JNDI 在 J2EE 中的另外一項(xiàng)關(guān)鍵角色:查找其他應(yīng)用程序組件。

    EJB 的 JNDI 引用非常類(lèi)似于 JDBC 資源的引用。在服務(wù)趨于轉(zhuǎn)換的環(huán)境中,這是一種很有效的方法。可以對(duì)應(yīng)用程序架構(gòu)中所得到的所有組件進(jìn)行這類(lèi)配置管理,從 EJB 組件到 JMS 隊(duì)列和主題,再到簡(jiǎn)單配置字符串或其他對(duì)象,這可以降低隨時(shí)間的推移服務(wù)變更所產(chǎn)生的維護(hù)成本,同時(shí)還可以簡(jiǎn)化部署,減少集成工作。 外部資源”。


    總結(jié):
    J2EE 規(guī)范要求所有 J2EE 容器都要提供 JNDI 規(guī)范的實(shí)現(xiàn)。JNDI 在 J2EE 中的角色就是“交換機(jī)” —— J2EE 組件在運(yùn)行時(shí)間接地查找其他組件、資源或服務(wù)的通用機(jī)制。在多數(shù)情況下,提供 JNDI 供應(yīng)者的容器可以充當(dāng)有限的數(shù)據(jù)存儲(chǔ),這樣管理員就可以設(shè)置應(yīng)用程序的執(zhí)行屬性,并讓其他應(yīng)用程序引用這些屬性(Java 管理擴(kuò)展(Java Management Extensions,JMX)也可以用作這個(gè)目的)。JNDI 在 J2EE 應(yīng)用程序中的主要角色就是提供間接層,這樣組件就可以發(fā)現(xiàn)所需要的資源,而不用了解這些間接性。

    在 J2EE 中,JNDI 是把 J2EE 應(yīng)用程序合在一起的粘合劑,JNDI 提供的間接尋址允許跨企業(yè)交付可伸縮的、功能強(qiáng)大且很靈活的應(yīng)用程序。這是 J2EE 的承諾,而且經(jīng)過(guò)一些計(jì)劃和預(yù)先考慮,這個(gè)承諾是完全可以實(shí)現(xiàn)的。
     

    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1683227


    評(píng)論

    # re: JNDI概述  回復(fù)  更多評(píng)論   

    2008-03-19 09:52 by chelseafan
    寫(xiě)的很 清楚,明白,謝謝

    # re: JNDI概述[未登錄](méi)  回復(fù)  更多評(píng)論   

    2008-05-05 17:18 by yy
    IBM 上的東西,引來(lái)引去,都成什么了!
    http://www.ibm.com/developerworks/cn/java/j-jndi/index.html

    # re: JNDI概述  回復(fù)  更多評(píng)論   

    2008-05-20 14:07 by eminem
    中國(guó)就是因?yàn)閘z這樣的人太多了,所以軟件行業(yè)上不去阿!
    ps:引用了別人的文章還不指明轉(zhuǎn)載地址。哎。

    # re: JNDI概述  回復(fù)  更多評(píng)論   

    2008-07-18 11:24 by ssdf
    寫(xiě)的挺好啊!
    看了好幾個(gè)資源,看了你這個(gè)覺(jué)的講解的方式最直接!
    樓上的說(shuō)是轉(zhuǎn)載,好象不是啊,
    再說(shuō)了,重要的是了解了這個(gè)知識(shí),形式不重要!
    不管怎樣,感謝樓主!

    # re: JNDI概述  回復(fù)  更多評(píng)論   

    2008-11-17 16:35 by limp_t
    @yy
    精簡(jiǎn)了那么多。不算是抄襲吧。
    @eminem
    抄出來(lái)讓你學(xué)習(xí),不也是一種知識(shí)傳播的精神嗎

    # re: JNDI概述  回復(fù)  更多評(píng)論   

    2009-01-03 21:32 by zolly
    聲明:本人摘于
    http://tb.blog.csdn.net/TrackBack.aspx?PostId=1683227

    只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 三根一起会坏掉的好痛免费三级全黄的视频在线观看 | 久久精品无码专区免费东京热| 亚洲aⅴ无码专区在线观看春色 | 国产亚洲精品美女久久久久久下载| 亚洲一区综合在线播放| 亚洲毛片不卡av在线播放一区| 免费黄色大片网站| 免费看黄视频网站| 98精品全国免费观看视频| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲视频在线免费观看| 在线亚洲精品自拍| 亚洲AV无码不卡在线观看下载| 毛片基地免费观看| 免费人成在线观看69式小视频| 精品四虎免费观看国产高清午夜| 一级做a爱过程免费视频高清| 色噜噜噜噜亚洲第一| 亚洲综合无码一区二区痴汉| 久久亚洲国产精品成人AV秋霞| 亚洲AV无一区二区三区久久| 国产成人亚洲综合| 亚洲AV无码不卡在线观看下载| 免费日本黄色网址| 国产乱色精品成人免费视频| 国产色婷婷精品免费视频| 免费的一级片网站| 在线播放免费播放av片| 四虎成人免费网址在线| 成人免费视频软件网站| 永久免费毛片手机版在线看| 国内免费高清在线观看| 男人的好看免费观看在线视频 | 亚洲午夜无码久久久久小说| 国产成人精品日本亚洲直接| 亚洲一区在线免费观看| 亚洲欧美中文日韩视频| 久久亚洲AV成人无码国产电影| 亚洲av无码专区国产不乱码| 日韩亚洲人成网站| 一级一级一级毛片免费毛片|