感謝原文作者:chenhongyong
原文鏈接:https://www.cnblogs.com/chy18883701161/p/12594889.html
更多請查閱阿里官方API文檔:https://github.com/alibaba/druid/wiki
目錄
Druid簡介
Druid是阿里開源的數據庫連接池,作為后起之秀,性能比dbcp、c3p0更高,使用也越來越廣泛。
當然Druid不僅僅是一個連接池,還有很多其他的功能。
druid的優點
- 高性能。性能比dbcp、c3p0高很多。
- 只要是jdbc支持的數據庫,druid都支持,對數據庫的支持性好。並且Druid針對oracle、mysq了特別優化。
- 提供監控功能。可以監控sql語句的執行時間、ResultSet持有時間、返回行數、更新行數、錯誤次數、錯誤堆棧等信息,來了解連接池、sql語句的工作情況,方便統計、分析SQL的執行性能
Druid的使用
添加依賴
<!--Alibaba Druid數據庫連接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.18</version>
</dependency>
方式一:純代碼方式
//數據源配置
DruidDataSource dataSource = new DruidDataSource();
dataSource.setUrl("jdbc:mysql://127.0.0.1/db_student?serverTimezone=UTC");
dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver"); //這個可以缺省的,會根據url自動識別
dataSource.setUsername("root");
dataSource.setPassword("abcd");
//下面都是可選的配置
dataSource.setInitialSize(10); //初始連接數,默認0
dataSource.setMaxActive(30); //最大連接數,默認8
dataSource.setMinIdle(10); //最小閑置數
dataSource.setMaxWait(2000); //獲取連接的最大等待時間,單位毫秒
dataSource.setPoolPreparedStatements(true); //緩存PreparedStatement,默認false
dataSource.setMaxOpenPreparedStatements(20); //緩存PreparedStatement的最大數量,默認-1(不緩存)。大於0時會自動開啟緩存PreparedStatement,所以可以省略上一句代碼
//獲取連接
Connection connection = dataSource.getConnection();
//Statement接口
Statement statement = connection.createStatement();
String sql1 = "insert into tb_student (name,age) values ('chy',20)";
statement.executeUpdate(sql1);
//PreparedStatement接口
String sql2 = "insert into tb_student (name,age) values ('chy',21)";
PreparedStatement preparedStatement = connection.prepareStatement(sql2);
preparedStatement.execute();
//關閉連接
connection.close();
方式二:配置文件方式
1、在sources
下新建druid.properties
url=jdbc:mysql://127.0.0.1/db_student?serverTimezone=UTC
#這個可以缺省的,會根據url自動識別
driverClassName=com.mysql.cj.jdbc.Driver
username=root
password=abcd
##初始連接數,默認0
initialSize=10
#最大連接數,默認8
maxActive=30
#最小閑置數
minIdle=10
#獲取連接的最大等待時間,單位毫秒
maxWait=2000
#緩存PreparedStatement,默認false
poolPreparedStatements=true
#緩存PreparedStatement的最大數量,默認-1(不緩存)。大於0時會自動開啟緩存PreparedStatement,所以可以省略上一句設置
maxOpenPreparedStatements=20
2、使用
public class Test {
public static void main(String[] args) throws Exception {
//數據源配置
Properties properties=new Properties();
//通過當前類的class對象獲取資源文件
InputStream is = Test.class.getResourceAsStream("/druid.properties");
properties.load(is);
//返回的是DataSource,不是DruidDataSource
DataSource dataSource = DruidDataSourceFactory.createDataSource(properties);
//獲取連接
Connection connection = dataSource.getConnection();
//Statement接口
Statement statement = connection.createStatement();
String sql1 = "insert into tb_student (name,age) values ('chy',20)";
statement.executeUpdate(sql1);
//PreparedStatement接口
String sql2 = "insert into tb_student (name,age) values ('chy',22)";
PreparedStatement preparedStatement = connection.prepareStatement(sql2);
preparedStatement.execute();
//關閉連接
connection.close();
}
}
這種方式對properties
的key
有嚴格要求,必須值指定的字符串,容易寫錯。
如果覺得老調不好,可以DruidDataSource dataSource = new DruidDataSource(); 再調用setter方法使用配置文件的值,不過很麻煩。
常見框架中使用
在Spring中使用Druid
1、resources
下新建druid.properties
druid.url=jdbc:mysql://127.0.0.1/db_student?serverTimezone=UTC
#這個可以缺省的,會根據url自動識別
druid.driverClassName=com.mysql.cj.jdbc.Driver
druid.username=root
druid.password=abcd
##初始連接數,默認0
druid.initialSize=10
#最大連接數,默認8
druid.maxActive=30
#最小閑置數
druid.minIdle=10
#獲取連接的最大等待時間,單位毫秒
druid.maxWait=2000
#緩存PreparedStatement,默認false
druid.poolPreparedStatements=true
#緩存PreparedStatement的最大數量,默認-1(不緩存)。大於0時會自動開啟緩存PreparedStatement,所以可以省略上一句設置
druid.maxOpenPreparedStatements=20
2、spring配置文件
<!--引入druid配置文件-->
<context:property-placeholder location="classpath:druid.properties" />
<!--druid連接池-->
<bean name="druidDataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="url" value="${druid.url}" />
<property name="driverClassName" value="${druid.driverClassName}" />
<property name="username" value="${druid.username}" />
<property name="password" value="${druid.password}" />
<property name="initialSize" value="${druid.initialSize}"/>
<property name="maxActive" value="${druid.maxActive}" />
<property name="minIdle" value="${druid.minIdle}" />
<property name="maxWait" value="${druid.maxWait}" />
<property name="poolPreparedStatements" value="${druid.poolPreparedStatements}" />
<property name="maxOpenPreparedStatements" value="${druid.maxOpenPreparedStatements}" />
</bean>
注意要配置包掃描,掃描注解。
3、使用
@Repository
public class Xxx {
@Resource
private DruidDataSource dataSource;
public void xxx() throws SQLException {
//獲取連接
Connection connection = dataSource.getConnection();
//Statement接口
Statement statement = connection.createStatement();
String sql1 = "insert into tb_student (name,age) values ('chy',20)";
statement.executeUpdate(sql1);
//PreparedStatement接口
String sql2 = "insert into tb_student (name,age) values ('chy',22)";
PreparedStatement preparedStatement = connection.prepareStatement(sql2);
preparedStatement.execute();
//關閉連接
connection.close();
}
}
在SpringBoot中使用Druid
SpringBoot默認提供了DBCP連接池的配置,只需要在配置文件中配置即可。
C3P0、Druid沒有提供配置,需要我們在配置文件中添加配置,並自己寫一個配置類來創建連接池。
參考我的另一篇隨筆:https://www.cnblogs.com/chy18883701161/p/12685833.html
使用durid的監控功能
1、在druid數據源里啟用stat過濾器
<property name="filters" value="stat" />
2、在web.xml
中配置StatViewServlet
<servlet>
<servlet-name>DruidStatView</servlet-name>
<servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>
<!--<!– 是否允許清空統計數據,不寫時默認true –>-->
<!--<init-param>-->
<!-- <param-name>resetEnable</param-name>-->
<!-- <param-value>false</param-value>-->
<!--</init-param>-->
<!--<!– 用戶名。用戶名和密碼可以不配置,不配置時進入監控頁面時不需要輸入用戶名、密碼 –>-->
<!--<init-param>-->
<!-- <param-name>loginUsername</param-name>-->
<!-- <param-value>chy</param-value>-->
<!--</init-param>-->
<!--<!– 密碼 –>-->
<!--<init-param>-->
<!-- <param-name>loginPassword</param-name>-->
<!-- <param-value>abcd</param-value>-->
<!-- </init-param>-->
</servlet>
<servlet-mapping>
<servlet-name>DruidStatView</servlet-name>
<url-pattern>/druid/*</url-pattern>
</servlet-mapping>
啟動web應用,在 localhost:8080/druid
可看到sql的執行情況統計。(注意不是項目下)
druid默認會清空統計數據,所以只能看到當時的情況,應用需要持續操作數據庫才好看到效果。