当前位置:首页 > 文章列表 > 数据库 > MySQL > mybatis使用spring-druid数据源连接池配置log4j打印sql语句以及开启监控平台

mybatis使用spring-druid数据源连接池配置log4j打印sql语句以及开启监控平台

来源:SegmentFault 2023-01-17 20:10:08 0浏览 收藏

大家好,今天本人给大家带来文章《mybatis使用spring-druid数据源连接池配置log4j打印sql语句以及开启监控平台》,文中内容主要涉及到MySQL、Java、mybatis、druid-spring-事务-连接池、log4j,如果你对数据库方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

杂七杂的杂

作为程序员,开发工程中,一套利于测试或者监控的工具很重要,mybatis默认没有提供log4j的打印sql语句的配置。

这对于开发rest服务,提供接口的开发者而言,是在很不好做,再加上mybatis很灵活,使用脚本动态生成sql语句,因此,有时候真不知道运行的sql是不是我们所期望的,过滤的条件是否起作用。

所幸,德鲁伊监控平台是个不错的选择,在性能方面druid连接池也比spring原生的要好,因此也是很多企业开发的首选数据源配置。

在引言阶段,我们先看看目前我配置的结果是否是你想要的,如果不是你所期望的,就别浪费时间往下面看,毕竟大家都时间有限,没必要花费时间看一些对自己没用的东西。

  • 控制台打印的日志,慎重的告诉你,这种大量打印信息不能用于生产坏境,生产环境中这些信息写到tomcat的日志文件中了

    druid连接池配置属性列表详解
    <h2>web.xml配置</h2>
    <p><code><?xml version="1.0" encoding="UTF-8"?><web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemalocation="http://java.sun.com/xml/ns/javaee
              http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:META-INF/spring/*.xml</param-value></context-param><!-- 初始化参数,引入log4j配置--><context-param><param-name>log4jConfigLocation</param-name><param-value>WEB-INF/classes/log4j.xml</param-value></context-param><context-param><param-name>log4jRefreshInterval</param-name><param-value>60000</param-value></context-param><!-- 开启德鲁伊stat过滤,WebStatFilter用于采集web-jdbc关联监控的数据,注意放在其它的过滤器以及dispatcher前面,很重哦 --><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>/static/*,*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*</param-value></init-param><!-- 下面的所有的init-param可以不用配置,使用默认值即可,如果你有处女座情结,删除即可 --><!-- 缺省sessionStatMaxCount是1000个。你可以按需要进行配置 --><init-param><param-name>sessionStatMaxCount</param-name><param-value>1000</param-value></init-param><!-- druid 0.2.7版本开始支持profile,配置profileEnable能够监控单个url调用的sql列表 --><init-param><param-name>profileEnable</param-name><param-value>true</param-value></init-param><!--
            <init-param>
                <param-name>principalSessionName</param-name>
                <param-value>users.username</param-value>
            </init-param> --><!-- 你可以关闭session统计功能 --><!-- 
            <init-param>
                <param-name>sessionStatEnable</param-name>
                <param-value>true</param-value>
            </init-param> --></filter><filter-mapping><filter-name>DruidWebStatFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping><!--this listener must be defined before the spring listener--><listener><listener-class>com.alibaba.dubbo.remoting.http.servlet.BootstrapListener</listener-class></listener><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><!-- log4j监听器 --><listener><listener-class>org.springframework.web.util.Log4jConfigListener</listener-class></listener><servlet><servlet-name>dispatcher</servlet-name><servlet-class>com.alibaba.dubbo.remoting.http.servlet.DispatcherServlet</servlet-class><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/*</url-pattern></servlet-mapping><!-- 德鲁伊监控平台监控器 --><servlet><servlet-name>DruidStatView</servlet-name><servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class><init-param><!-- 允许清空统计数据 --><param-name>resetEnable</param-name><param-value>true</param-value></init-param><init-param><!-- 用户名 --><param-name>loginUsername</param-name><param-value>druid</param-value></init-param><init-param><!-- 密码 --><param-name>loginPassword</param-name><param-value>druid</param-value></init-param></servlet><servlet-mapping><servlet-name>DruidStatView</servlet-name><url-pattern>/druid/*</url-pattern></servlet-mapping></web-app></code></p>

    上面加了注解的配置,是本文配置的重点,其它配置不在这里讲解。

    配置
    <th align="left">缺省值</th>
    <th align="left">说明</th>
    
    <tbody><tr><td align="left">name</td>
    <td align="left"> </td>
    <td align="left">配置这个属性的意义在于,如果存在多个数据源,监控的时候可以通过名字来区分开来。如果没有配置,将会生成一个名字,格式是:”DataSource-” + System.identityHashCode(this)</td>
    </tr><tr><td align="left">jdbcUrl</td>
    <td align="left"> </td>
    <td align="left">连接数据库的url,不同数据库不一样。例如:mysql : jdbc:mysql://10.20.153.104:3306/druid2;oracle : jdbc:oracle:thin:@10.20.149.85:1521:ocnauto</td>
    </tr><tr><td align="left">username</td>
    <td align="left"> </td>
    <td align="left">连接数据库的用户名</td>
    </tr><tr><td align="left">password</td>
    <td align="left"> </td>
    <td align="left">连接数据库的密码。如果你不希望密码直接写在配置文件中,可以使用ConfigFilter。详细看这里:<a target='_blank'  href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXuytMyero5ko5XFfIfNhNCyr5q5aZjEeZydvpCCmHxri7HJutKjgGWb1cVmnNqCuLlpgrt6dayHenuvjo1jeo2kaK-4q2yFZHDavqGd0orQ0KycrYapq6t9nq6yhpuKjYpssqe4pIOGidCxnnaXkdCxsoe6l2WxeYWus2uFqn1rjmm-3cCig4N0og' rel='nofollow'>https://github.com/alibaba/dr...</a>
    </td>
    </tr><tr><td align="left">driverClassName</td>
    <td align="left">根据url自动识别</td>
    <td align="left">这一项可配可不配,如果不配置druid会根据url自动识别dbType,然后选择相应的driverClassName</td>
    </tr><tr><td align="left">initialSize</td>
    <td align="left">0</td>
    <td align="left">初始化时建立物理连接的个数。初始化发生在显示调用init方法,或者第一次getConnection时</td>
    </tr><tr><td align="left">maxActive</td>
    <td align="left">8</td>
    <td align="left">最大连接池数量</td>
    </tr><tr><td align="left">maxIdle</td>
    <td align="left">8</td>
    <td align="left">已经不再使用,配置了也没效果</td>
    </tr><tr><td align="left">minIdle</td>
    <td align="left"> </td>
    <td align="left">最小连接池数量</td>
    </tr><tr><td align="left">maxWait</td>
    <td align="left"> </td>
    <td align="left">获取连接时最大等待时间,单位毫秒。配置了maxWait之后,缺省启用公平锁,并发效率会有所下降,如果需要可以通过配置useUnfairLock属性为true使用非公平锁。</td>
    </tr><tr><td align="left">poolPreparedStatements</td>
    <td align="left">false</td>
    <td align="left">是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql5.5以下的版本中没有PSCache功能,建议关闭掉。5.5及以上版本有PSCache,建议开启。</td>
    </tr><tr><td align="left">maxOpenPreparedStatements</td>
    <td align="left">-1</td>
    <td align="left">要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100</td>
    </tr><tr><td align="left">validationQuery</td>
    <td align="left"> </td>
    <td align="left">用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会其作用。</td>
    </tr><tr><td align="left">testOnBorrow</td>
    <td align="left">true</td>
    <td align="left">申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。</td>
    </tr><tr><td align="left">testOnReturn</td>
    <td align="left">false</td>
    <td align="left">归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能</td>
    </tr><tr><td align="left">testWhileIdle</td>
    <td align="left">false</td>
    <td align="left">建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。timeBetweenEvictionRunsMillis有两个含义:1) Destroy线程会检测连接的间隔时间 2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明</td>
    </tr><tr><td align="left">numTestsPerEvictionRun</td>
    <td align="left"> </td>
    <td align="left">不再使用,一个DruidDataSource只支持一个EvictionRun</td>
    </tr><tr><td align="left">minEvictableIdleTimeMillis</td>
    <td align="left"> </td>
    </tr><tr><td align="left">connectionInitSqls</td>
    <td align="left"> </td>
    <td align="left">物理连接初始化的时候执行的sql</td>
    </tr><tr><td align="left">exceptionSorter</td>
    <td align="left">根据dbType自动识别</td>
    <td align="left">当数据库抛出一些不可恢复的异常时,抛弃连接</td>
    </tr><tr><td align="left">filters</td>
    <td align="left"> </td>
    <td align="left">属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:监控统计用的filter:stat; 日志用的filter:log4j;防御sql注入的filter:wall;合并sql的filter:mergeStat</td>
    </tr><tr><td align="left">proxyFilters</td>
    <td align="left"> </td>
    <td align="left">类型是List<com.alibaba.druid.filter.filter>,如果同时配置了filters和proxyFilters,是组合关系,并非替换关系</com.alibaba.druid.filter.filter></td>
    </tr></tbody><h2>补充说明</h2>
    <p>前面说过,mybatis配置的时候,可以配置sqlSessionFactory的时候通过configLocation属性可以指定mybatis的一些额外配置。</p>
    <p>这里分享一段数据库字段值为null时,不返回字段名,而我们希望的是不管值为什么,字段名都应该返回。配置如下:</p>
    <p><code><?xml version="1.0" encoding="UTF-8"?><configuration><settings><setting name="callSettersOnNulls" value="true"></setting><setting name="logImpl" value="LOG4J"></setting></settings></configuration></code></p>

    今天带大家了解了MySQL、Java、mybatis、druid-spring-事务-连接池、log4j的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
MySQL避免索引列使用 OR 条件MySQL避免索引列使用 OR 条件
上一篇
MySQL避免索引列使用 OR 条件
mac和linux下mysql字符集设置问题
下一篇
mac和linux下mysql字符集设置问题
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    96次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    89次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    107次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    98次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    98次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码