Ytl's Java Blog

          厚積而薄發(fā)---每一天都是一個(gè)全新的開(kāi)始

           JNDI : Java Naming and Directory Interface (JNDI)
          JNDI works in concert with other technologies in the Java Platform, Enterprise Edition (Java EE) to organize and locate components in a distributed computing environment.
          翻譯:JNDI  在Java平臺(tái)企業(yè)級(jí)開(kāi)發(fā)的分布式計(jì)算環(huán)境以組織和查找組件方式與其他技術(shù)協(xié)同工作。

          Tomcat 6.0 的數(shù)據(jù)源配置
           

          給大家我的配置方式:

          1,在Tomcat中配置:
              tomcat 安裝目錄下的conf的context.xml 的
             <Context></Context>中
          添加代碼如下:


              
          <Resource  name="jdbc/tango"
                      auth
          ="Container"
                  type
          ="javax.sql.DataSource"
                      maxActive
          ="20"
                      maxIdel
          ="10"
                      maxWait
          ="1000"
                      username
          ="root"
                      password
          ="root"
              driverClassName
          ="com.mysql.jdbc.Driver"        url="jdbc:mysql://localhost:3306/tango"
                  
          >
              
                
          </Resource> 
          其中:
          name 表示指定的jndi名稱(chēng)
          auth 表示認(rèn)證方式,一般為Container
          type 表示數(shù)據(jù)源床型,使用標(biāo)準(zhǔn)的javax.sql.DataSource
          maxActive 表示連接池當(dāng)中最大的數(shù)據(jù)庫(kù)連接
          maxIdle 表示最大的空閑連接數(shù)
          maxWait 當(dāng)池的數(shù)據(jù)庫(kù)連接已經(jīng)被占用的時(shí)候,最大等待時(shí)間
          username 表示數(shù)據(jù)庫(kù)用戶(hù)名
          password 表示數(shù)據(jù)庫(kù)用戶(hù)的密碼
          driverClassName 表示JDBC DRIVER
          url 表示數(shù)據(jù)庫(kù)URL地址


          同時(shí)你需要把你使用的數(shù)據(jù)驅(qū)動(dòng)jar包放到Tomcat的lib目錄下。
          如果你使用其他數(shù)據(jù)源如DBCP數(shù)據(jù)源,需要在<Resouce 標(biāo)簽多添加一個(gè)屬性如
            factory="org.apache.commons.dbcp.BasicDataSourceFactory"
          當(dāng)然你也要把DBCP相關(guān)jar包放在tomcat的lib目錄下。

          這樣的好處是,以后的項(xiàng)目需要這些jar包,可以共享適合于項(xiàng)目實(shí)施階段。
          如果是個(gè)人開(kāi)發(fā)階段一個(gè)tomcat下部署多個(gè)項(xiàng)目,在啟動(dòng)時(shí)消耗時(shí)間,同時(shí)
          可能不同項(xiàng)目用到不用數(shù)據(jù)源帶來(lái)麻煩。所以有配置方法2

          2在項(xiàng)目的中配置:

          2.1  使用自己的DBCP數(shù)據(jù)源
          在WebRoot下面建文件夾META-INF,里面建一個(gè)文件context.xml,
          添加內(nèi)容和 配置1一樣
          同時(shí)加上<Resouce 標(biāo)簽多添加一個(gè)屬性如
           factory="org.apache.commons.dbcp.BasicDataSourceFactory"


          這樣做的:可以把配置需要jar包直接放在WEB-INF的lib里面 和web容器(Tomcat)無(wú)關(guān)

          總后一點(diǎn):提醒大家,有個(gè)同學(xué)可能說(shuō) tomacat的有DBCP的jar包,確實(shí)tomcat把它放了
          進(jìn)去,你就認(rèn)為不用添加DBCP數(shù)據(jù)源的jar包,也按照上面的配置,100%你要出錯(cuò)。
          因?yàn)閠omcat重新打包了相應(yīng)的jar,你應(yīng)該把 
          factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory" 改為
            factory="org.apache.commons.dbcp.BasicDataSourceFactory"
            

          同時(shí)加上DBCP 所依賴(lài)的jar包(commons-dbcp.jar和commons-pool.jar)
          你可以到www.apache.org 項(xiàng)目的commons里面找到相關(guān)的內(nèi)容

          2.2 使用Tomcat 自帶的DBCP數(shù)據(jù)源

          在WebRoot下面建文件夾META-INF,里面建一個(gè)文件context.xml,
          添加相應(yīng)的內(nèi)容
          這是可以不需要添加配置
          配置1一樣
           factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"

          也不要想添加額外的jar包

          最后,不管使用哪種配置,都需要把數(shù)據(jù)庫(kù)驅(qū)動(dòng)jar包放在目錄tomcat /lib里面

          JNDI使用示例代碼:

          Context initContext;
          try 
          {
             Context context
          =new
           InitialContext(); 
             DataSource ds
          =(DataSource) context.lookup("java:/comp/env/jdbc/tango"
          );  
          //
           "java:/comp/env/"是固定寫(xiě)法,后面接的是 context.xml中的Resource中name屬性的值 
              Connection conn = ds.getConnection();
              Statement stmt 
          =
           conn.createStatement();
              ResultSet set 
          = stmt.executeQuery("SELECT id,name,age FROM user_lzy"
          );
              
          while(set.next())
          {
          System.out.println(set.getString(
          "name"
          ));
              }

              
          //etc.
          }
           catch (NamingException e) {
              
          // TODO Auto-generated catch block

              e.printStackTrace();
          }
           catch (SQLException e) {
              
          // TODO Auto-generated catch block

              e.printStackTrace();
          }

          謝謝!

          評(píng)論

          # re: Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用[未登錄](méi)  回復(fù)  更多評(píng)論   

          2009-04-14 21:06 by java愛(ài)好者
          好!

          # re: Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用[未登錄](méi)  回復(fù)  更多評(píng)論   

          2009-04-14 21:07 by java愛(ài)好者
          總結(jié)的不錯(cuò)。

          # re: Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用  回復(fù)  更多評(píng)論   

          2009-05-02 11:32 by josdoc
          好文章!
          Java開(kāi)源文檔(www.josdoc.com)轉(zhuǎn)載了您的文章,
          若有異議請(qǐng)告知,謝謝!

          # re: Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用[未登錄](méi)  回復(fù)  更多評(píng)論   

          2009-12-24 14:38 by sk
          第二種方式時(shí):我的還需要把commons-dbcp和commons-pool這兩個(gè)jar包拷貝到WEB-INF的lib下面.

          # re: Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用[未登錄](méi)  回復(fù)  更多評(píng)論   

          2010-12-14 01:43 by abc
          搜索這么多,只有你的才是對(duì)的!非常感謝

          # re: Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用  回復(fù)  更多評(píng)論   

          2011-10-08 14:43 by 曹夢(mèng)
          嗯 萬(wàn)分感謝 ,但問(wèn)下在自己配置的數(shù)據(jù)源中 factory屬性必須添加嗎?我這里有一個(gè)apps就沒(méi)有添加factory屬性,沒(méi)有問(wèn)題。

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


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 湖北省| 新干县| 东辽县| 句容市| 香港 | 锡林浩特市| 县级市| 公安县| 临沧市| 酒泉市| 恭城| 阜城县| 成安县| 静海县| 稷山县| 望奎县| 南昌县| 呼伦贝尔市| 天台县| 襄垣县| 乳源| 长顺县| 阳谷县| 松原市| 日土县| 新乡县| 洮南市| 墨竹工卡县| 顺昌县| 且末县| 清流县| 平武县| 鹤岗市| 瑞丽市| 宁安市| 日照市| 宣汉县| 平利县| 德令哈市| 土默特右旗| 扶沟县|