Spring提供了兩個這樣的數(shù)據(jù)源(都位于org.springframework.jdbc.datasource程序包里):
DriverManagerDataSource:這個類實現(xiàn)了javax.sql.DataSource接口,但它并沒有提供池化連接的機(jī)制,每次調(diào)用getConnection()獲取新連接時,只是簡單地創(chuàng)建一個新的連接。因此,這個數(shù)據(jù)源類比較適合在單元測試 或簡單的獨(dú)立應(yīng)用中使用,因為它不需要額外的依賴類。
SingleConnectionDataSource:在每個連接請求時都返回同一個連接。雖然它不同嚴(yán)格意義上的池管理數(shù)據(jù)源,但我們可以把它看作只有一個連接的池。
對兩個數(shù)據(jù)源的配置都類似于配置DBCP的BasicDataSource,區(qū)別在于由于DriverManagerDataSource和SingleConnectionDataSource都沒有提供連接池,所以在此沒有設(shè)置池配置屬性。
雖然這兩個數(shù)據(jù)源都對于小程序來說是很不錯的,而且還在不斷發(fā)展,但把它們用于生產(chǎn)程序還是需要認(rèn)真考慮的。SingleConnectionDataSource只使用一個數(shù)據(jù)庫連接,所以不適合用于多線程程序。
而 DriverMangerDataSource雖然能夠支持多線程,但它會在每次連接請求時都新建一個連接,這是以性能為代價的。由于這些限制,我們強(qiáng)烈 建議應(yīng)該使用數(shù)據(jù)源池。
如果應(yīng)用配置在高性能的應(yīng)用服務(wù)器(如WebLogic或Websphere等)上,我們可能更希望使用應(yīng)用服務(wù)器本身提供的數(shù)據(jù)源。應(yīng)用服務(wù)器的數(shù)據(jù)源 使用JNDI開放調(diào)用者使用,Spring為此專門提供引用JNDI資源的JndiObjectFactoryBean類。創(chuàng)新互聯(lián)是一家專注于網(wǎng)站建設(shè)、做網(wǎng)站與策劃設(shè)計,肇州網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:肇州等地區(qū)。肇州做網(wǎng)站價格咨詢:13518219792
SSM框架之DriverManagerDataSource--spring-mybatis.xml
datasource.driverClassName=com.MySQL.cj.jdbc.Driver
datasource.userName=root
datasource.userPassword=123456
datasource.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
SSM框架之dbcp2連接池--spring-mybatis.xml(若是dbcp,個別參數(shù)對應(yīng)不上)
#src/config/dbcp.properties
dbcp.driverClassName=com.mysql.cj.jdbc.Driver
dbcp.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
dbcp.username=root
dbcp.password=123456
dbcp.initialSize=3
dbcp.minIdle=5
dbcp.maxIdle=10
dbcp.maxActive=15
dbcp.maxWait=60000
dbcp.numTestsPerEvictionRun=10
dbcp.timeBetweenEvictionRunsMillis=60000
dbcp.minEvictableIdleTimeMillis=300000
dbcp.validationQuery=SELECT 1
dbcp.testOnBorrow=false
dbcp.removeAbandoned=true
dbcp.removeAbandonedTimeout=1800
SSM框架之c3p0連接池--spring-mybatis.xml
#src/config/c3p0.properties
c3p0.driverClassName=com.mysql.cj.jdbc.Driver
c3p0.jdbcUrl=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
c3p0.user=root
c3p0.password=123456
c3p0.acquireIncrement=3
c3p0.initialPoolSize=3
c3p0.idleConnectionTestPeriod=60
c3p0.minPoolSize=5
c3p0.maxPoolSize=100
c3p0.maxStatements=100
c3p0.numHelperThreads=10
c3p0.maxIdleTime=60
SSM框架之Druid連接池--spring-mybatis.xml
#src/config/druid.properties
druid.driverClassName=com.mysql.cj.jdbc.Driver
druid.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
druid.userName=root
druid.userPassword=123456
druid.initialSize=0
druid.maxActive=20
druid.minIdle=1
druid.maxIdle=20
druid.maxWait=60000
druid.timeBetweenEvictionRunsMillis=60000
druid.minEvictableIdleTimeMillis=300000
druid.poolPreparedStatements=true
druid.maxOpenPreparedStatements=20
druid.validationQuery=SELECT 'x'
druid.testWhileIdle=true
druid.testOnBorrow=false
druid.testOnReturn=false
druid.removeAbandoned=true
druid.removeAbandonedTimeout=1800
druid.logAbandoned=true
druid.filters=stat,log4j
在web.xml添加如下內(nèi)容
DruidWebStatFilter
com.alibaba.druid.support.http.WebStatFilter
exclusions
*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*
DruidWebStatFilter
/*
DruidStatView
com.alibaba.druid.support.http.StatViewServlet
loginUsername
root
loginPassword
root
DruidStatView
/druid/*
輸入用戶名root、密碼root即可登錄