Tomcat連接池
Tomcat 連接池的配置步驟:
1.配置Tomcat的server.xml文件。創(chuàng)建數(shù)據(jù)源(指定具體的數(shù)據(jù)庫(kù))
2.在web.xml中引用。
3.在javabean、servlet中使用。
4.server.xml文件修改后要記得發(fā)布(Publish)。
直接上代碼:
1.server.xml文件配置
- <Host>
- <!--
- docBase : 該Context的根目錄是webapps/qms
- path="" 是Context的路徑名為空則運(yùn)行Host的默認(rèn)Context 例子中的qms是有這個(gè)名字的文件
- reloadable:設(shè)為true, Tomcat在運(yùn)行狀態(tài)下會(huì)監(jiān)視在WEB-INF/classes和Web-INF/lib目錄CLASS文件
- 的改動(dòng).如果監(jiān)視到有class文件被更新,服務(wù)器自重新加載Web應(yīng)用。
- driverClassName: 數(shù)據(jù)庫(kù)的驅(qū)動(dòng) MySQL的是com.mysql.jdbc.Driver
- -->
- <Context docBase="qms" path="/qms" reloadable="true" source="org.eclipse.jst.jee.server:qms">
- <!--name:指定資源池的Resource的JNDI的名字,
- auth:管理權(quán)限,可以是Container或Application。
- type:Resource所屬的是什么類型的數(shù)據(jù)源本例是SQL的
-
- -->
- <Resource
- name="jdbc/publicdb"
- auth="Container"
- type="javax.sql.DataSource"
- maxActive="10"
- maxIdle="5"
- maxWait="10000"
- username="sa"
- password="12345"
- driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
- url="jdbc:sqlserver://192.168.84.49\U3C:1433;databaseName=u3cdb_200"
- validationQuery="SELECT CURRENT_USER"
- removeAbandoned="true"
- removeAbandonedTimeout="60"
- logAbandoned="true" />
- </Context>
- </Host>
<Host>
<!--
docBase : 該Context的根目錄是webapps/qms
path="" 是Context的路徑名為空則運(yùn)行Host的默認(rèn)Context 例子中的qms是有這個(gè)名字的文件
reloadable:設(shè)為true, Tomcat在運(yùn)行狀態(tài)下會(huì)監(jiān)視在WEB-INF/classes和Web-INF/lib目錄CLASS文件
的改動(dòng).如果監(jiān)視到有class文件被更新,服務(wù)器自重新加載Web應(yīng)用。
driverClassName: 數(shù)據(jù)庫(kù)的驅(qū)動(dòng) MySQL的是com.mysql.jdbc.Driver
-->
<Context docBase="qms" path="/qms" reloadable="true" source="org.eclipse.jst.jee.server:qms">
<!--name:指定資源池的Resource的JNDI的名字,
auth:管理權(quán)限,可以是Container或Application。
type:Resource所屬的是什么類型的數(shù)據(jù)源本例是SQL的
-->
<Resource
name="jdbc/publicdb"
auth="Container"
type="javax.sql.DataSource"
maxActive="10"
maxIdle="5"
maxWait="10000"
username="sa"
password="12345"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://192.168.84.49\U3C:1433;databaseName=u3cdb_200"
validationQuery="SELECT CURRENT_USER"
removeAbandoned="true"
removeAbandonedTimeout="60"
logAbandoned="true" />
</Context>
</Host>
server.xml 文件詳解 :
<Server>
<Listener />
<GlobaNamingResources>
</GlobaNamingResources
<Service>
<Connector />
<Engine>
<Logger />
<Realm />
<host>
<Logger />
<Context />
</host>
</Engine>
</Service>
</Server>
元素名
|
屬性
|
解釋
|
server
|
port
|
指定一個(gè)端口,這個(gè)端口負(fù)責(zé)監(jiān)聽(tīng)關(guān)閉tomcat的請(qǐng)求
|
shutdown
|
指定向端口發(fā)送的命令字符串
|
service
|
name
|
指定service的名字
|
Connector(表示客戶端和service之間的連接)
|
port
|
指定服務(wù)器端要?jiǎng)?chuàng)建的端口號(hào),并在這個(gè)斷口監(jiān)聽(tīng)來(lái)自客戶端的請(qǐng)求
|
minProcessors
|
服務(wù)器啟動(dòng)時(shí)創(chuàng)建的處理請(qǐng)求的線程數(shù)
|
maxProcessors
|
最大可以創(chuàng)建的處理請(qǐng)求的線程數(shù)
|
enableLookups
|
如果為true,則可以通過(guò)調(diào)用request.getRemoteHost()進(jìn)行DNS查詢來(lái)得到遠(yuǎn)程客戶端的實(shí)際主機(jī)名,若為false則不進(jìn)行DNS查詢,而是返回其ip地址
|
redirectPort
|
指定服務(wù)器正在處理http請(qǐng)求時(shí)收到了一個(gè)SSL傳輸請(qǐng)求后重定向的端口號(hào)
|
acceptCount
|
指定當(dāng)所有可以使用的處理請(qǐng)求的線程數(shù)都被使用時(shí),可以放到處理隊(duì)列中的請(qǐng)求數(shù),超過(guò)這個(gè)數(shù)的請(qǐng)求將不予處理
|
connectionTimeout
|
指定超時(shí)的時(shí)間數(shù)(以毫秒為單位)
|
Engine(表示指定service中的請(qǐng)求處理機(jī),接收和處理來(lái)自Connector的請(qǐng)求)
|
defaultHost
|
指定缺省的處理請(qǐng)求的主機(jī)名,它至少與其中的一個(gè)host元素的name屬性值是一樣的
|
Context(表示一個(gè)web應(yīng)用程序,通常為WAR文件,關(guān)于WAR的具體信息見(jiàn)servlet規(guī)范)
|
docBase
|
應(yīng)用程序的路徑或者是WAR文件存放的路徑
|
path
|
表示此web應(yīng)用程序的url的前綴,這樣請(qǐng)求的url為http://localhost:8080/path/****
|
reloadable
|
這個(gè)屬性非常重要,如果為true,則tomcat會(huì)自動(dòng)檢測(cè)應(yīng)用程序的/WEB-INF/lib 和/WEB-INF/classes目錄的變化,自動(dòng)裝載新的應(yīng)用程序,我們可以在不重起tomcat的情況下改變應(yīng)用程序
|
host(表示一個(gè)虛擬主機(jī))
|
name
|
指定主機(jī)名
|
appBase
|
應(yīng)用程序基本目錄,即存放應(yīng)用程序的目錄
|
unpackWARs
|
如果為true,則tomcat會(huì)自動(dòng)將WAR文件解壓,否則不解壓,直接從WAR文件中運(yùn)行應(yīng)用程序
|
Logger(表示日志,調(diào)試和錯(cuò)誤信息)
|
className
|
指定logger使用的類名,此類必須實(shí)現(xiàn)org.apache.catalina.Logger 接口
|
prefix
|
指定log文件的前綴
|
suffix
|
指定log文件的后綴
|
timestamp
|
如果為true,則log文件名中要加入時(shí)間,如下例:localhost_log.001-10-04.txt
|
Realm(表示存放用戶名,密碼及role的數(shù)據(jù)庫(kù))
|
className
|
指定Realm使用的類名,此類必須實(shí)現(xiàn)org.apache.catalina.Realm接口
|
Valve(功能與Logger差不多,其prefix和suffix屬性解釋和Logger 中的一樣)
|
className
|
指定Valve使用的類名,如用org.apache.catalina.valves.AccessLogValve類可以記錄應(yīng)用程序的訪問(wèn)信息
|
directory
|
指定log文件存放的位置
|
pattern
|
有兩個(gè)值,common方式記錄遠(yuǎn)程主機(jī)名或ip地址,用戶名,日期,第一行請(qǐng)求的字符串,HTTP響應(yīng)代碼,發(fā)送的字節(jié)數(shù)。combined方式比common方式記錄的值更多
|