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

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

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

    Ytl's Java Blog

    厚積而薄發---每一天都是一個全新的開始
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    Tomcat 6.0配置數據源(DBCP)和JNDI使用

    Posted on 2009-04-14 17:10 ytl 閱讀(8087) 評論(6)  編輯  收藏 所屬分類: 學習總結

     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平臺企業級開發的分布式計算環境以組織和查找組件方式與其他技術協同工作。

    Tomcat 6.0 的數據源配置
     

    給大家我的配置方式:

    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名稱
    auth 表示認證方式,一般為Container
    type 表示數據源床型,使用標準的javax.sql.DataSource
    maxActive 表示連接池當中最大的數據庫連接
    maxIdle 表示最大的空閑連接數
    maxWait 當池的數據庫連接已經被占用的時候,最大等待時間
    username 表示數據庫用戶名
    password 表示數據庫用戶的密碼
    driverClassName 表示JDBC DRIVER
    url 表示數據庫URL地址


    同時你需要把你使用的數據驅動jar包放到Tomcat的lib目錄下。
    如果你使用其他數據源如DBCP數據源,需要在<Resouce 標簽多添加一個屬性如
      factory="org.apache.commons.dbcp.BasicDataSourceFactory"
    當然你也要把DBCP相關jar包放在tomcat的lib目錄下。

    這樣的好處是,以后的項目需要這些jar包,可以共享適合于項目實施階段。
    如果是個人開發階段一個tomcat下部署多個項目,在啟動時消耗時間,同時
    可能不同項目用到不用數據源帶來麻煩。所以有配置方法2

    2在項目的中配置:

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


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

    總后一點:提醒大家,有個同學可能說 tomacat的有DBCP的jar包,確實tomcat把它放了
    進去,你就認為不用添加DBCP數據源的jar包,也按照上面的配置,100%你要出錯。
    因為tomcat重新打包了相應的jar,你應該把 
    factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory" 改為
      factory="org.apache.commons.dbcp.BasicDataSourceFactory"
      

    同時加上DBCP 所依賴的jar包(commons-dbcp.jar和commons-pool.jar)
    你可以到www.apache.org 項目的commons里面找到相關的內容

    2.2 使用Tomcat 自帶的DBCP數據源

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

    也不要想添加額外的jar包

    最后,不管使用哪種配置,都需要把數據庫驅動jar包放在目錄tomcat /lib里面

    JNDI使用示例代碼:

    Context initContext;
    try 
    {
       Context context
    =new
     InitialContext(); 
       DataSource ds
    =(DataSource) context.lookup("java:/comp/env/jdbc/tango"
    );  
    //
     "java:/comp/env/"是固定寫法,后面接的是 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();
    }

    謝謝!

    評論

    # re: Tomcat 6.0配置數據源(DBCP)和JNDI使用[未登錄]  回復  更多評論   

    2009-04-14 21:06 by java愛好者
    好!

    # re: Tomcat 6.0配置數據源(DBCP)和JNDI使用[未登錄]  回復  更多評論   

    2009-04-14 21:07 by java愛好者
    總結的不錯。

    # re: Tomcat 6.0配置數據源(DBCP)和JNDI使用  回復  更多評論   

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

    # re: Tomcat 6.0配置數據源(DBCP)和JNDI使用[未登錄]  回復  更多評論   

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

    # re: Tomcat 6.0配置數據源(DBCP)和JNDI使用[未登錄]  回復  更多評論   

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

    # re: Tomcat 6.0配置數據源(DBCP)和JNDI使用  回復  更多評論   

    2011-10-08 14:43 by 曹夢
    嗯 萬分感謝 ,但問下在自己配置的數據源中 factory屬性必須添加嗎?我這里有一個apps就沒有添加factory屬性,沒有問題。
    主站蜘蛛池模板: 国产成人精品亚洲精品| 7m凹凸精品分类大全免费| 女人让男人免费桶爽30分钟 | 亚洲精品无码永久在线观看| 亚洲AV无码无限在线观看不卡| 曰批视频免费30分钟成人| 亚洲国产精品线观看不卡| 91精品视频免费| 国产精品亚洲一区二区麻豆| 无码日韩人妻av一区免费| 亚洲 欧洲 视频 伦小说| 动漫黄网站免费永久在线观看| 亚洲国产精品美女| 无码国产精品一区二区免费虚拟VR | 久久精品无码专区免费| 中文字幕在线亚洲精品| 久久九九AV免费精品| 亚洲黄色网址大全| 在线v片免费观看视频| 精品久久久久久亚洲综合网| 国产偷窥女洗浴在线观看亚洲 | 免费看黄网站在线看| 伊人久久大香线蕉亚洲五月天| 久操视频免费观看| 亚洲一区二区三区在线网站| 国产三级免费电影| 国产一级婬片A视频免费观看| 亚洲男人的天堂在线播放| 全免费毛片在线播放| 美女被艹免费视频| 亚洲AV日韩AV永久无码久久 | 美女内射毛片在线看免费人动物| 亚洲av日韩av综合| 免费看国产曰批40分钟| 久久免费香蕉视频| 色噜噜亚洲男人的天堂| 亚洲精品久久久www| 99久热只有精品视频免费观看17 | 久久亚洲欧美国产精品| 久99精品视频在线观看婷亚洲片国产一区一级在线 | 九九全国免费视频|