• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            Tomcat連接池配置與使用

            src:http://www.javaeye.com/topic/25161

            其實Tomcat的連接池配置并不是很難,但也花費了我一些時間。今天,終于搞定,希望將經驗分享出來,能給未解決問題的朋友提供幫助。
               
            這里我的Tomcat版本為5.0.28,這個版本應該說是Tomcat比較穩定的一個版本。
               
            首先備份你的$TomcatHome$/conf/server.xml文件($TomcatHome$是指你的tomcat安裝路徑),然后在<Host>節點下添加:

            Java代碼

            1. <Context path="/pool" docBase="pool">  
            2.   <Resource name="jdbc/test" scope="Shareable" type="javax.sql.DataSource"/>  
            3.   <ResourceParams name="jdbc/test">  
            4.     <parameter>  
            5.       <name>factory</name>  
            6.       <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>  
            7.     </parameter>  
            8.     <!-- DBCP database connection settings -->  
            9.     <parameter>  
            10.       <name>url</name>  
            11.       <value>jdbc:jtds:sqlserver://localhost:1433;DatabaseName=pubs</value>  
            12.     </parameter>  
            13.     <parameter>  
            14.       <name>driverClassName</name>  
            15.       <value>net.sourceforge.jtds.jdbc.Driver</value>  
            16.     </parameter>  
            17.     <parameter>  
            18.       <name>username</name>  
            19.       <value>sa</value>  
            20.     </parameter>  
            21.     <parameter>  
            22.       <name>password</name>  
            23.       <value>sa</value>  
            24.     </parameter>  
            25.     <!-- DBCP connection pooling options -->  
            26.     <parameter>  
            27.       <name>maxWait</name>  
            28.       <value>3000</value>  
            29.     </parameter>  
            30.     <parameter>  
            31.       <name>maxIdle</name>  
            32.       <value>100</value>  
            33.     </parameter>  
            34.     <parameter>  
            35.       <name>maxActive</name>  
            36.       <value>10</value>  
            37.     </parameter>  
            38.   </ResourceParams>  
            39. </Context> 
            <Context path="/pool" docBase="pool">
              <Resource name="jdbc/test" scope="Shareable" type="javax.sql.DataSource"/>
              <ResourceParams name="jdbc/test">
                <parameter>
                  <name>factory</name>
                  <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
                </parameter>
                <!-- DBCP database connection settings -->
                <parameter>
                  <name>url</name>
                  <value>jdbc:jtds:sqlserver://localhost:1433;DatabaseName=pubs</value>
                </parameter>
                <parameter>
                  <name>driverClassName</name>
                  <value>net.sourceforge.jtds.jdbc.Driver</value>
                </parameter>
                <parameter>
                  <name>username</name>
                  <value>sa</value>
                </parameter>
                <parameter>
                  <name>password</name>
                  <value>sa</value>
                </parameter>
                <!-- DBCP connection pooling options -->
                <parameter>
                  <name>maxWait</name>
                  <value>3000</value>
                </parameter>
                <parameter>
                  <name>maxIdle</name>
                  <value>100</value>
                </parameter>
                <parameter>
                  <name>maxActive</name>
                  <value>10</value>
                </parameter>
              </ResourceParams>
            </Context>


               
            其中紅色部分是你需要修改的。
                <Context path="/pool" docBase="pool">
            這里的pool是指你的項目在tomcat發布目錄webapps下的目錄路徑,這里我的項目目錄為:.../webapps/pool
                <Resource name="jdbc/test"..>jdbc/test
            為需要通過jndi調用的數據源名稱。
                <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
            這里我們用的是dbcp連接池包,這是apache提供的一個免費開源連接池,而且效率和穩定性都不錯。如果你使用的是tomcat5x或以上的版本,可以在$TomcatHome$/common/lib目錄下找到它。
               
            關于數據庫的設置,這里就不在多說。

               
            下面打開web.xml文件,在其根節點下添加數據源的引用設置。

            Java代碼

            1. <resource-ref>  
            2.   <res-ref-name>jdbc/test</res-ref-name>  
            3.   <res-type>javax.sql.DataSource</res-type>  
            4.   <res-auth>Container</res-auth>  
            5. </resource-ref> 
            <resource-ref>
              <res-ref-name>jdbc/test</res-ref-name>
              <res-type>javax.sql.DataSource</res-type>
              <res-auth>Container</res-auth>
            </resource-ref>


               
            最后我們在代碼中從連接池獲得Connection對象。

            Java代碼

            1. Context context = new InitialContext();  
            2. //獲得數據源  
            3. DataSource ds = context.lookup("java:comp/env/jdbc/test");  
            4. //獲取連接  
            5. Connection conn = ds.getConnection(); 
            Context context = new InitialContext();
            //獲得數據源
            DataSource ds = context.lookup("java:comp/env/jdbc/test");
            //獲取連接
            Connection conn = ds.getConnection();


               
            這樣我們就在代碼中獲得了Connection對象,至于剩下的操作,就完全是jdbc操作了。

             Test.jsp
            <%@ page contentType="text/html; charset=GBK"%>
            <%@ page import="java.sql.*,javax.sql.DataSource,javax.naming.*"%>
            <html>
            <head><title>test.jsp</title></head>
            <body bgcolor="#ffffff">
            <h1>test Tomcat</h1>
            <%
            try
            {
                Context initCtx=new InitialContext();
                DataSource ds = (DataSource)initCtx.lookup("java:comp/env/jdbc/TestDB");
                Connection conn=ds.getConnection();
                out.println("data from database:<br>");
                Statement stmt=conn.createStatement();
                ResultSet rs =stmt.executeQuery("select id, foo, bar from testdata");
                while(rs.next())
                {
                    out.println(rs.getInt("id"));
                    out.println(rs.getString("foo"));
                    out.println(rs.getString("bar"));
                }
                rs.close();
                stmt.close();
            }
            catch(Exception e)
            {
                e.printStackTrace();
            }
            %>
            </body>
            </html>

            聲明:JavaEye文章版權屬于作者,受法律保護。沒有作者書面許可不得轉載。

            推薦鏈接

             

            posted on 2009-08-03 17:54 肥仔 閱讀(179) 評論(0)  編輯 收藏 引用 所屬分類: Web-后臺

            久久久久人妻一区二区三区 | 99久久精品国产一区二区三区| 国内精品伊人久久久久av一坑| 国产精品对白刺激久久久| 99热都是精品久久久久久| 亚洲国产精品成人久久蜜臀 | 香蕉久久影院| 国产精品九九九久久九九| 无码任你躁久久久久久久| 狠狠色婷婷久久一区二区三区| 久久精品女人天堂AV麻| 久久久国产精品亚洲一区| 欧美激情精品久久久久久| 无码人妻少妇久久中文字幕蜜桃| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 久久无码一区二区三区少妇 | 日韩十八禁一区二区久久| 国产精品久久影院| 亚洲精品乱码久久久久久蜜桃图片| 国产激情久久久久影院| 国产精品对白刺激久久久| 午夜不卡久久精品无码免费| 四虎影视久久久免费| 久久精品国产亚洲av瑜伽| 久久精品一区二区国产| 久久w5ww成w人免费| 日日躁夜夜躁狠狠久久AV| 狠狠色噜噜色狠狠狠综合久久 | 麻豆av久久av盛宴av| 久久有码中文字幕| 日韩久久久久中文字幕人妻| 久久伊人中文无码| 久久中文精品无码中文字幕| 久久久青草青青国产亚洲免观| 久久93精品国产91久久综合| 国产99久久久久久免费看| 国产成人精品久久亚洲| 久久久久久久综合日本| 亚洲国产婷婷香蕉久久久久久| 亚洲中文字幕伊人久久无码| 久久精品国产乱子伦|