druid简单例子

阅读(10)
评论(0)
Beginning
为什么选择使用阿里巴巴数据库连接池Druid?
阿里巴巴推出的国产数据库连接池,据网上测试对比,比目前的DBCP或C3P0数据库连接池性能更好


简单使用介绍
Druid与其他数据库连接池使用方法基本一样(与DBCP非常相似),将数据库的连接信息全部配置给DataSource对象


基于Spring创建
1. 配置jdbc.properties:
#druid Connection
jdbc.url=jdbc:mysql://localhost:3306/database
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.username=username
jdbc.password=password
       
jdbc.filters=stat
   
jdbc.maxActive=20
jdbc.initialSize=1
jdbc.maxWait=60000
jdbc.minIdle=10
jdbc.maxIdle=15
   
jdbc.timeBetweenEvictionRunsMillis=60000
jdbc.minEvictableIdleTimeMillis=300000
   
jdbc.validationQuery=SELECT 'x'
jdbc.testWhileIdle=true
jdbc.testOnBorrow=false
jdbc.testOnReturn=false


jdbc.maxOpenPreparedStatements=20
jdbc.removeAbandoned=true
jdbc.removeAbandonedTimeout=1800
jdbc.logAbandoned=true




2. 配置使用mybatis
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">  
     <!-- 数据库基本信息配置 -->
     <property name="url" value="${jdbc.url}" />  
     <property name="username" value="${jdbc.username}" />  
     <property name="password" value="${jdbc.password}" />  
     <property name="driverClassName" value="${jdbc.driverClassName}" />  
     <property name="filters" value="${jdbc.filters}" />  
         <!-- 最大并发连接数 -->
     <property name="maxActive" value="${jdbc.maxActive}" />
     <!-- 初始化连接数量 -->
     <property name="initialSize" value="${jdbc.initialSize}" />
     <!-- 配置获取连接等待超时的时间 -->
     <property name="maxWait" value="${jdbc.maxWait}" />
     <!-- 最小空闲连接数 -->
     <property name="minIdle" value="${jdbc.minIdle}" />  
         <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
     <property name="timeBetweenEvictionRunsMillis" value="${jdbc.timeBetweenEvictionRunsMillis}" />
     <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
     <property name="minEvictableIdleTimeMillis" value="${jdbc.minEvictableIdleTimeMillis}" />  
     <property name="validationQuery" value="${jdbc.validationQuery}" />  
     <property name="testWhileIdle" value="${jdbc.testWhileIdle}" />  
     <property name="testOnBorrow" value="${jdbc.testOnBorrow}" />  
     <property name="testOnReturn" value="${jdbc.testOnReturn}" />  
     <property name="maxOpenPreparedStatements" value="${jdbc.maxOpenPreparedStatements}" />
     <!-- 打开removeAbandoned功能 -->
     <property name="removeAbandoned" value="${jdbc.removeAbandoned}" />
     <!-- 1800秒,也就是30分钟 -->
     <property name="removeAbandonedTimeout" value="${jdbc.removeAbandonedTimeout}" />
     <!-- 关闭abanded连接时输出错误日志 -->   
     <property name="logAbandoned" value="${jdbc.logAbandoned}" />
</bean> 


3. 启用Web监控统计功能需要在Web应用的web.xml中加入这个Servlet声明
<!-- 启用Web监控统计功能 -->
<filter>
    <filter-name>DruidWebStatFilter</filter-name>
    <filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class>
    <init-param>
        <param-name>exclusions</param-name>
        <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>DruidWebStatFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
<servlet>
    <servlet-name>DruidStatView</servlet-name>
    <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>DruidStatView</servlet-name>
    <url-pattern>/druid/*</url-pattern>
</servlet-mapping>
<listener>
Ending
本文如果对您有帮助欢迎打赏作者,多少随意一分也是爱!

作者:Java夜未眠

出处:https://www.cnblogs.com/liangxianning/p/17058273.html

版权声明:本博客所有文章除特别声明外,均采用「 MIT 许可协议。」许可协议进行许可

关于博主: 评论和私信会可能回复较慢,点击上面加人图标加我为好友吧

posted @   Java夜未眠  阅读(10)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
more_horiz
keyboard_arrow_up light_mode
选择主题
点击右上角即可分享
微信分享提示