JNDI詳解

xmh_sxh_1314發表於2020-10-04

在這裡插入圖片描述
JNDI 是什麼
JNDI是 Java 命名與目錄介面(Java Naming and Directory Interface),在J2EE規範中是重要的規範之一,不少專家認為,沒有透徹理解JNDI的意義和作用,就沒有真正掌握J2EE特別是EJB的知識。
那麼,JNDI到底起什麼作用?
要了解JNDI的作用,我們可以從“如果不用JNDI我們怎樣做?用了JNDI後我們又將怎樣做?”這個問題來探討。
沒有JNDI的做法:
程式設計師開發時,知道要開發訪問MySQL資料庫的應用,於是將一個對 MySQL JDBC 驅動程式類的引用進行了編碼,並通過使用適當的 JDBC URL 連線到資料庫。
就像以下程式碼這樣:
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並進行SQL操作 */

conn.close();
}
catch(Exception e) {
e.printStackTrace();
}
finally {
if(conn!=null) {
try {
conn.close();
} catch(SQLException e) {}
}
}
這是傳統的做法,也是以前非Java程式設計師(如Delphi、VB等)常見的做法。這種做法一般在小規模的開發過程中不會產生問題,只要程式設計師熟悉Java語言、瞭解JDBC技術和MySQL,可以很快開發出相應的應用程式。
沒有JNDI的做法存在的問題:
1、資料庫伺服器名稱MyDBServer 、使用者名稱和口令都可能需要改變,由此引發JDBC URL需要修改;
2、資料庫可能改用別的產品,如改用DB2或者Oracle,引發JDBC驅動程式包和類名需要修改;
3、隨著實際使用終端的增加,原配置的連線池引數可能需要調整;
4、…
解決辦法:
程式設計師應該不需要關心“具體的資料庫後臺是什麼?JDBC驅動程式是什麼?JDBC URL格式是什麼?訪問資料庫的使用者名稱和口令是什麼?”等等這些問題,程式設計師編寫的程式應該沒有對 JDBC 驅動程式的引用,沒有伺服器名稱,沒有使用者名稱稱或口令 —— 甚至沒有資料庫池或連線管理。而是把這些問題交給J2EE容器來配置和管理,程式設計師只需要對這些配置和管理進行引用即可。
由此,就有了JNDI。
用了JNDI之後的做法:
首先,在在J2EE容器中配置JNDI引數,定義一個資料來源,也就是JDBC引用引數,給這個資料來源設定一個名稱;然後,在程式中,通過資料來源名稱引用資料來源從而訪問後臺資料庫。
具體操作如下(以JBoss為例):
1、配置資料來源
在JBoss的 D:/jboss420GA/docs/examples/jca 資料夾下面,有很多不同資料庫引用的資料來源定義模板。將其中的 mysql-ds.xml 檔案Copy到你使用的伺服器下,如 D:/jboss420GA/server/default/deploy。
修改 mysql-ds.xml 檔案的內容,使之能通過JDBC正確訪問你的MySQL資料庫,如下:

<?xml version="1.0" encoding="UTF-8"?> MySqlDS jdbc:mysql://localhost:3306/lw com.mysql.jdbc.Driver root rootpassword org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter mySQL 這裡,定義了一個名為MySqlDS的資料來源,其引數包括JDBC的URL,驅動類名,使用者名稱及密碼等。 2、在程式中引用資料來源: Connection conn=null; try { Context ctx=new InitialContext(); Object datasourceRef=ctx.lookup("java:MySqlDS"); //引用資料來源 DataSource ds=(Datasource)datasourceRef; conn=ds.getConnection(); /* 使用conn進行資料庫SQL操作 */ ...... c.close(); } catch(Exception e) { e.printStackTrace(); } finally { if(conn!=null) { try { conn.close(); } catch(SQLException e) { } } } 直接使用JDBC或者通過JNDI引用資料來源的程式設計程式碼量相差無幾,但是現在的程式可以不用關心具體JDBC引數了。 在系統部署後,如果資料庫的相關引數變更,只需要重新配置 mysql-ds.xml 修改其中的JDBC引數,只要保證資料來源的名稱不變,那麼程式原始碼就無需修改。 由此可見,JNDI避免了程式與資料庫之間的緊耦合,使應用更加易於配置、易於部署。 JNDI的擴充套件:JNDI在滿足了資料來源配置的要求的基礎上,還進一步擴充了作用:所有與系統外部的資源的引用,都可以通過JNDI定義和引用。 所以,在J2EE規範中,J2EE 中的資源並不侷限於 JDBC 資料來源。引用的型別有很多,其中包括資源引用(已經討論過)、環境實體和 EJB 引用。特別是 EJB 引用,它暴露了 JNDI 在 J2EE 中的另外一項關鍵角色:查詢其他應用程式元件。 EJB 的 JNDI 引用非常類似於 JDBC 資源的引用。在服務趨於轉換的環境中,這是一種很有效的方法。可以對應用程式架構中所得到的所有元件進行這類配置管理,從 EJB 元件到 JMS 佇列和主題,再到簡單配置字串或其他物件,這可以降低隨時間的推移服務變更所產生的維護成本,同時還可以簡化部署,減少整合工作。 外部資源”。 總 結: J2EE 規範要求所有 J2EE 容器都要提供 JNDI 規範的實現。JNDI 在 J2EE 中的角色就是“交換機” —— J2EE 元件在執行時間接地查詢其他元件、資源或服務的通用機制。在多數情況下,提供 JNDI 供應者的容器可以充當有限的資料儲存,這樣管理員就可以設定應用程式的執行屬性,並讓其他應用程式引用這些屬性(Java 管理擴充套件(Java Management Extensions,JMX)也可以用作這個目的)。JNDI 在 J2EE 應用程式中的主要角色就是提供間接層,這樣元件就可以發現所需要的資源,而不用瞭解這些間接性。 在 J2EE 中,JNDI 是把 J2EE 應用程式合在一起的粘合劑,JNDI 提供的間接定址允許跨企業交付可伸縮的、功能強大且很靈活的應用程式。這是 J2EE 的承諾,而且經過一些計劃和預先考慮,這個承諾是完全可以實現的。 最近一直在對J2EE的筆記進行整理和複習,雖然J2EE視訊是看過一遍了,但是當我看自己做的筆記的時候陌生程度還是很大,而真正的對某個概念有所認識的時候是將筆記和以前看過的視訊印象進行摩擦,J2EE主要講解的內容是各個規範,再清楚一些就是各個概念,現階段的目標並不是掌握J2EE,而是對J2EE進行輪廓和概念上的瞭解和認識,到下一步DRP專案中再深層次的對各個規範進行摩擦和認識。 JNDI,翻譯為Java命名和目錄結構(JavaNaming And Directory Interface)官方對其解釋為JNDI是一組在Java應用中訪問命名和目錄服務的API(ApplicationProgramming Interface)說明很精煉,但是比較抽象。

上面的解釋中提高了命名服務和目錄服務兩個概念.先要了解JNDI就必須知道,命名服務和目錄服務是做什麼用的。

學習新的概念和知識,比較有效的方式是通過和以前所學過的內容進行聯絡,比較。
關於命名服務,其實我們很多時候都在用它,但是並不知道它是它,比較典型的是域名伺服器DNS(Domain Naming Service),大對人對DNS還是比較瞭解的,它是將域名對映到IP地址的服務.比如百度的域名www.baidu.com所對映的IP地址是http://202.108.22.5/,你在瀏覽器中輸入兩個內容是到的同一個頁面.用命名伺服器的原因是因為我們記憶baidu這幾個有意義的字母要比記202.108.22.5更容易記憶,但如果站到計算機的角度上,它更喜歡處理這些數字。
從我們生活中找的話還有很多類似的例子,比如說你的身份證號和你的名字可以"理解"成一種命名服務,你的學號和姓名也可以"解釋"為一種命名服務。
可以看出命名服務的特點:一個值和另一個值的對映,將我們人類更容易認識的值同計算機更容易認識的值進行一一對映。
到現在應該對命名服務有所理解吧?
至於目錄服務,從計算機角度理解為在網際網路上有著各種各樣的資源和主機,但是這些內容都是散落在網際網路中,為了訪問這些散落的資源並獲得相應的服務,就需要用到目錄服務。

從我們日常生活中去理解目錄服務的概念可以從電話簿說起,電話簿本身就是一個比較典型的目錄服務,如果你要找到某個人的電話號碼,你需要從電話簿裡找到這個人的名稱,然後再看其電話號碼。

理解了命名服務和目錄服務再回過頭來看JDNI,它是一個為Java應用程式提供命名服務的應用程式介面,為我們提供了查詢和訪問各種命名和目錄服務的通用統一的介面.通過JNDI統一介面我們可以來訪問各種不同型別的服務.如下圖所示,我們可以通過JNDI API來訪問剛才談到的DNS。

至此已經對JNDI有了一個初步認識,如果想要進一步瞭解JNDI,並對使用JDNI給我們帶來哪些便利之處,我推薦兩篇關於JDNI的文章,寫的非常的好,兩篇文章從“如果不用JNDI我們怎樣做?用了JNDI後我們又將怎樣做?”這個角度來加深對JNDI的認識。

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
+CmVFk89tfMXxnAki3XXCQ==

相關文章