Tomcat配置JNDI數據源

經過3個多小時的努力,配置JNDI數據源(主要是通過DBCP連接池)終于搞定~
還是Tomcat官方的說明好,不過全是英文的,大概還看得懂.
百度上那么花花綠綠的太多了,一個也沒成功!...
本例使用的數據庫為Ms SQL Server 2000,對于其它數據庫只是修改一下相應的參數即可,
服務器是Tomcat5.5, 與之間的版本配置連接池最簡便
自己總結了一下,希望起到一個拋磚引玉的作用

總結:
第一步:

將驅動程序(jar包)放到tomcat安裝目錄下的common\lib文件夾下
第二步:

在Tomcat的webapps目錄隨便創建一個工程目錄,例如myjdbc。在myjdbc目錄下創建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=""?
??driverClassName="net.sourceforge.jtds.jdbc.Driver"
?????????url="jdbc:jtds:sqlserver://localhost/pubs"/>
?</Context>

?

附注如下:
Tomcat標準數據源資源工廠配置項如下:
* driverClassName - 所使用的JDBC驅動類全稱。
* maxActive - 同一時刻可以自數據庫連接池中被分配的最大活動實例數。
* maxIdle - 同一時刻數據庫連接池中處于非活動狀態的最大連接數。
* maxWait - 當連接池中沒有可用連接時,連接池在拋出異常前將等待的最大時間,單位毫秒。
* password - 傳給JDBC驅動的數據庫密碼。
* url - 傳給JDBC驅動的連接URL。
* user - 傳給JDBC驅動的數據庫用戶名。
* validationQuery - 一個SQL查詢語句,用于在連接被返回給應用前的連接池驗證。
* 如果指定了該屬性,則必為至少返回一行記錄的SQL SELECT語句。


jdbc/test是數據源的名稱(隨意寫,要和web.xml文件中 <res-ref-name>jdbc/test</res-ref-name> 一樣即可),
其他的參數按照自己的實際情況進行修改,例如數據庫的名稱、賬號、密碼。

第三步:

在myjdbc目錄下創建WEB-INF目錄,創建web.xml文件,內容如下:?

<?xml?version="1.0"?encoding="UTF-8"?>?
<web-app?xmlns="http://java.sun.com/xml/ns/j2ee"?
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"?
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee?http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"?
version="2.4">?

????<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>?

?

說明:
<resource-ref>
<descrtiption>引用資源說明</descrtiption>
<res-ref-name>引用資源的JNDI名</res-ref-name>
<res-type>引用資源的類名</res-type>
<res-auth>管理者(Container)</res-auth><!--Container-容器管理 Application-Web應用管理-->
</resource-ref>
第四步:

寫個jsp,試一下吧!

<%@?page?contentType="text/html;charset=utf-8"%>
<%@?page?import="java.sql.*,javax.sql.*,javax.naming.*,com.DBConnection"?%>
<%
??try
??{
???//初始化查找命名空間
???Context?ctx?=?new?InitialContext();?
???//InitialContext?ctx?=?new?InitialContext();亦可?
???//找到DataSource,對名稱進行定位java:comp/env是必須加的,后面跟你的DataSource名
???DataSource?ds?=?(DataSource)ctx.lookup("java:comp/env/jdbc/test");
???//取出連接
???Connection?conn?=?ds.getConnection();
System.out.println("connection?pool?connected?!!");???
??}?catch?(NamingException?e)?{
???System.out.println(e.getMessage());
??}?catch?(SQLException?e)?{
???e.printStackTrace();
??}finally
??{
???//注意不是關閉,是放回連接池.
???conn.close();
??}

}
%>


或寫個JSP用標簽庫測試一下:

<%@?page?language="java"?import="java.util.*"?pageEncoding="ISO-8859-1"%>
<%@?taglib?uri="http://java.sun.com/jsp/jstl/sql"?prefix="sql"?%>
<%@?taglib?uri="http://java.sun.com/jsp/jstl/core"?prefix="c"?%>

<sql:query?var="rs"?dataSource="jdbc/test">
select?*?from?authors
</sql:query>

<html>
??<head>
????<title>DB?Test</title>
??</head>
??<body>
<c:forEach?var="row"?items="${rs.rows}">
????${row.city}<br/>
</c:forEach>
??</body>
</html>

?

我成功了!Good Luck!
以下是配置JNDI的其他方法,個人不建議使用,因為修改服務器的
server.xml和web.xml,如果有一點錯誤,你的容器就會崩潰~

注:連接數據源的方法還有很多,在這里我簡要說之:
比如說第二步還可以這么做:

在/tomcat/conf/Catalina/localhost(或其它主機名)/中添加以
虛擬目錄名稱(你的工程名)命名的XML文件來配置context.
比如我的主機下有個目錄dbpool其地址為tomcat/webapps/test我可以這樣來配置這個上下文:
在tomcat/conf/Catalina/localhost/目錄下創建test.xml文件,內容和上面一樣.

還可以:
在/tomcat/conf/server.xml中<host></host>標簽之間添加
???
?

<Context?path="/test"?docBase="test"
????????debug="5"?reloadable="true"?crossContext="true">
??<Resource?name="jdbc/test"?auth="Container"?type="javax.sql.DataSource"
???????????????maxActive="100"?maxIdle="30"?maxWait="10000"
???????????????username="javauser"?password="javadude"?driverClassName="net.sourceforge.jtds.jdbc.Driver"
???????????????url="jdbc:jtds:sqlserver://localhost/pubs"/>
</Context>

?

其中path是你的工程路徑(相對或絕對亦可),其中docBase="test"說明,此主機已經指向到webapps目錄下了,回頭
來看test這個上下文,它實際目錄是位于webapps的目錄下的,所以
在Context中我們可以將docBase直接設置為test了。如果它在webapps/dbpool/test下,則設置為dbpool/test就可以了。

附:JNDI——Java Naming and Directory Interface是一套提供naming和 directory功能的 API,
Java應用程式開發者透過使用 JNDI,在naming和 directory方面的應用上就有了共通的準則.

?

from :http://www.blogjava.net/supercrsky/articles/174931.html

轉載于:https://www.cnblogs.com/xuan52rock/p/4745262.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/397659.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/397659.shtml
英文地址,請注明出處:http://en.pswp.cn/news/397659.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 線程池 固定大小_使用Executors服務在Java中創建固定大小線程池的最佳方法...

查看源代碼,您將意識到&#xff1a;Executors.newFixedThreadPool(threadPoolSize);相當于&#xff1a;return new ThreadPoolExecutor(threadPoolSize, threadPoolSize, 0L, MILLISECONDS,new LinkedBlockingQueue());由于它不提供顯式的RejectedExecutionHandler,因此使用默認…

令牌驗證 token

通過令牌驗證在注冊中心控制權限&#xff0c;以決定要不要下發令牌給消費者&#xff0c;可以防止消費者繞過注冊中心訪問提供者&#xff0c;另外通過注冊中心可靈活改變授權方式&#xff0c;而不需修改或升級提供者。 可以全局設置開啟令牌驗證&#xff1a; <!--隨機token令…

easybcd 支持 windows 10 和 ubuntu 14.04 雙系統啟動

家里計算機系統 windows 10 全新安裝。 原本是雙系統的&#xff0c;還有一個ubuntu。 windows 10 安裝以后&#xff0c;恢復ubuntu就是問題了。 (事后經驗&#xff1a;請不要立刻安裝bcd修改工具) 最初的方法是利用easybcd修改bcd記錄。操作是成功的&#xff0c;但系統重新啟動…

需求分析與原型設計

結對者&#xff1a;031402140李嚴 0314026617林瑞斌 需求分析與原型設計 NABCD模型 N&#xff08;Need&#xff0c;需求&#xff09;: 收集信息的過程太過繁瑣&#xff0c;有班級總負責人需匯總每一個同學的志愿并填入excel表中&#xff0c;上交年級負責人&#xff0c;年級負責…

java導出表格_java怎么導出excel表格

import com.spire.xls.ExcelVersion;import com.spire.xls.Workbook;import com.spire.xls.Worksheet;public class InsertArray {public static void main(String[] args) {//創建Workbook對象Workbook wb new Workbook();//獲取第一張62616964757a686964616fe4b893e5b19e313…

for 循環 和 Array 數組對象

博客地址&#xff1a;https://ainyi.com/12 for 循環 和 Array 數組對象方法 for for-in for-of forEach效率比較 - 四種循環&#xff0c;遍歷長度為 1000000 的數組疊加&#xff0c;得到的時間差&#xff1a;for 3for-in 250for-of 7forEach 44- 效率速度&#xff1a;for >…

IntelliJ IDEA---java的編譯工具【轉】

轉自&#xff1a;http://baike.baidu.com/link?urlsEpS0rItaB9BiO3i-qCdGSYiTIVPSJfBTjSXXngtN2hBhGl1j36CYQORKrbpqMHqjvu3MOfkgVzpMqr8To2l2q IDEA 全稱 IntelliJ IDEA&#xff0c;是java語言開發的集成環境&#xff0c;IntelliJ在業界被公認為最好的java開發工具之一&#…

OC中文件讀取類(NSFileHandle)介紹和常用使用方法

NSFileHandle 1.NSFileManager類主要對于文件的操作(刪除&#xff0c;修改&#xff0c;移動&#xff0c;賦值等等) //判斷是否有 tagetPath 文件路徑&#xff0c;沒有就創建NSFileManager *fileManage [NSFileManager defaultManager];BOOL success [fileManage createFileAt…

java filereader讀文件_Java FileReader讀文件

import java.io.*;class FileReaderDemo{public static void main(String[] args) throws IOException{//創建一個文件讀取流對象&#xff0c;和指定名稱的文件相關聯。//要保證該文件是已經存在的&#xff0c;如果不存在&#xff0c;會發生異常FileNotFoundExceptionFileReade…

struts2攔截器

struts攔截器 圖&#xff1a; 1、攔截器是什么&#xff1f; 分離關注&#xff1a; 完成一個功能&#xff0c;可以寫在一個類中&#xff0c;然后一個類中4個步驟&#xff0c;實現該類完成。 我們可以將4個步驟寫在4個類中&#xff0c;然后每一個類完成一部分功能&#xff0c;然后…

Springboot-Jpa多數據庫配置-2.0+版本

pom.xml增加: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId></dependency> 配置表同JdbcTemplate配置. 主數據源: ConfigurationEnableTransactionManagementEna…

Windows虛擬地址轉物理地址(原理+源碼實現,附簡單小工具)

By Lthis 上個月就想寫了&#xff0c;一直沒時間...網上大概搜了一下&#xff0c;原理與操作倒是一大堆&#xff0c;一直沒看到源碼實現&#xff0c;總得有人動手&#xff0c;這回輪到我了。東西寫得很爛&#xff0c;請大牛勿噴。一直覺得靠源碼的方式驅動學習是非常好的一種學…

python裝飾器的使用

借用裝飾器&#xff0c;我們可以批量的對老的函數進行改造或擴展老函數功能&#xff0c;比如需要對函數的接收參數進行過濾&#xff0c;Flash的url路由功能就是使用的這個方式 def dropoushu(): # 這一層函數可以去掉&#xff0c;如果去掉了&#xff0c;則使用checkjiou這種方…

7_文件上傳漏洞

文件上傳漏洞 當文件上傳時&#xff0c;若服務端腳本語言未對上傳的文件進行嚴格驗證和過濾&#xff0c;若惡意用戶上傳惡意的腳本文件時&#xff0c;就有可能控制整個網站甚至是服務器&#xff0c;這就是文件上傳漏洞。 權限 1.網站后臺權限&#xff1a;登陸了后臺&#xff0…

mysql數據庫如何實現分頁查詢_不同數據庫的分頁查詢實現方法總結

分頁查詢是數據庫查詢中經常用到的一項操作&#xff0c;對查詢出來的結果進行分頁查詢可以方便瀏覽。那么Oracle、SQL Server、MySQL是如何實現查詢的呢&#xff1f;本文我們就來介紹這一部分內容。首先我們先看一下SQL Server 數據庫中SQL語句查詢分頁數據的解決方案&#xff…

POJ - 3842 An Industrial Spy dfs(水)

題意:給你一串數字&#xff0c;最少一個&#xff0c;最多七個&#xff0c;問用這里面的數字能組成多少素數&#xff0c;不重復。 思路&#xff1a;之前還遍歷10000000的每一個素數&#xff0c;結果超時&#xff0c;后來發現直接dfs就可以了&#xff0c;只是標記一下做過的數。 …

飛機大戰小游戲1.0版本

小時候大家應該都玩過飛機大戰吧&#xff0c;這就是仿的一個飛機大戰&#xff0c;但是沒有寫的很全&#xff0c;只能玩一次&#xff0c;死掉之后需要刷新頁面玩第二次&#xff0c;話不說多&#xff0c;上代碼&#xff1a; 初始頁面&#xff1a; 整個的html代碼還是很少&#xf…

記一次Jquery獲取值的典型錯誤

直接上代碼&#xff1a; 代碼很簡單&#xff0c;通過Post的形式提交參數&#xff0c;但是發現提交的data總是空&#xff0c;昨晚有點納悶&#xff0c;今天一看才發現。。。 獲取值得時候的順序有問題&#xff0c;獲取值應該是在onclick事件中。 綜上&#xff1a;寫Jquery的時間…

android 調用java接口_android調用java的web service接口

android中通過webservice調用服務器端其實還是很簡單的&#xff0c;只要按部就班的按照下面步驟進行即可&#xff1a;(1)創建HttpTransportSE對象&#xff0c;該對象用于調用WebService操作代碼如下:HttpTransportSE ht new HttpTransportSE(SERVICE_URL);(2)創建SoapSerializ…

iOS: TableView如何刷新指定的cell 或section

/一個section刷新 NSIndexSet *indexSet[[NSIndexSet alloc]initWithIndex:2]; [tableview reloadSections:indexSet withRowAnimation:UITableViewRowAnimationAutomatic]; //一個cell刷新 NSIndexPath *indexPath[NSIndexPath indexPathForRow:3 inSection:0…