Java的串連池技術__Java

來源:互聯網
上載者:User

  如何使用JNDI(Java Naming and Directory Interface)是一個應用程式介面,為開發人員提供了尋找和訪問各種命名和目錄服務的通用,統一的介面,類似JDBC都是構建在抽象層上。JNDI提供了一種統一的方式,可以用在網路上尋找和訪問服務。通過指定一個資源名稱,該名稱對應於資料庫或命名服務中的一個一個記錄,同時返回資料庫連接建立所必需的資訊。

在實際開發中,我們有時候還會使用伺服器提供給我們的資料庫連接池,比如我們希望Tomcat伺服器在啟動的時候可以協助我們建立一個資料庫連接池,那麼我們在應用程式中就不需要手動去建立資料庫連接池,直接使用Tomcat伺服器建立好的資料庫連接池即可。要想讓Tomcat伺服器再啟動的時候幫我們建立一個資料庫連接池‘,那麼需要簡單配置一下Tomcat伺服器。

  配置過程如下:

(1)將資料庫驅動程式(jar包)放到Tomcat安裝目錄下的lib檔案夾中。

(2)在項目的WebContent\META-INF\目錄下手動建立一個context.xml檔案,編輯裡面的內容,最終內容如下:

 

<?xml version="1.0" encoding="UTF-8"?>
<Context>
<Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource" maxActive="100" maxIdle="30" maxWait="10000" username="sa" password="525825GAOzhe"
 driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
 url="jdbc:sqlserver://localhost:1433;DatabaseName=test" />
</Context>

(3)再在上面WebContent\META-INF\目錄下手動建立一個web.xml檔案,編輯裡面的內容,最終內容如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
 <resource-ref>
 <description>DB Connection</description>
 <res-ref-name>jdbc/test</res-ref-name>
 <res-type>javax.sql.DataSource</res-type>
 <res-auth>Container</res-auth>
 </resource-ref> 
</web-app>

(3)建立一個jsp頁面,進行資料庫的訪問測試,代碼如下:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <%@ page import="java.sql.*, javax.sql.*,javax.naming.*,com.microsoft.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>資料庫連接測試</title>
</head>
<body>
<%
Connection con=null;
try{
Context ctx=new InitialContext();
DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/test");
con=ds.getConnection();


System.out.println("connection pool connectioned!!");
con.close();
}catch(NamingException e){
System.out.println(e.getMessage());
}catch(SQLException e){
e.printStackTrace();
}finally{
    con.close();
   }


%>
</body>
</html>

到此為止,資料庫的串連池就已經建立好了。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.