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

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

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

    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名稱
    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ù)用戶名
    password 表示數(shù)據(jù)庫(kù)用戶的密碼
    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 所依賴的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è)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 成人免费无毒在线观看网站 | 亚洲国产综合专区电影在线| 国产亚洲精品免费| 免费视频淫片aa毛片| 亚洲av永久无码精品网址| 精品免费久久久久久成人影院| 亚洲欧美日韩综合久久久| 在线观看成人免费| 国产亚洲综合视频| 国产裸模视频免费区无码| 免费一区二区无码视频在线播放| 日韩亚洲精品福利| 你是我的城池营垒免费观看完整版| 久久亚洲国产精品一区二区| 香蕉免费一区二区三区| 亚洲国产片在线观看| 青草草在线视频永久免费| 亚洲av无码无线在线观看| 亚洲国产一成久久精品国产成人综合 | GOGOGO免费观看国语| 亚洲AV无码乱码国产麻豆| 91在线老王精品免费播放| 亚洲人妖女同在线播放| 国产美女做a免费视频软件| 一个人免费观看www视频| 国产成人无码综合亚洲日韩| 91免费国产在线观看| 免费夜色污私人影院在线观看| 久久嫩草影院免费看夜色| 久久精品国产亚洲av麻豆色欲| 免费在线视频你懂的| 亚洲av无码一区二区三区在线播放| 亚洲精品无码久久毛片| 久久久精品2019免费观看| 在线亚洲精品视频| 中文字幕亚洲一区二区三区 | 久久久久久免费一区二区三区| 亚洲精品在线不卡| 亚洲精品乱码久久久久久不卡| 无码人妻一区二区三区免费看 | 亚洲va在线va天堂成人|