1。JDBCHikariDataSource 在SpringBoot2。x项目中,默认使用Hikari连接池管理数据源。相比于传统的C3P0、DBCP、Tomcatjdbc等连接池更加优秀。 当项目pom。xml引入springbootstarterjdbc启动器依赖后,即可自动导入Hikari,该启动器不但依赖它,还会对其自动配置并创建数据源。我们以MySQL数据库为例,介绍如何使用Hikari。 数据源是啥?为什么要用?怎么用?1。1应用实例 演示SpringBoot如何通过JDBCHikariDataSource完成对Mysql操作。 (1)数据库和表创建数据库DROPDATABASEIFEXISTSspringboot;CREATEDATABASEspringboot;USEspringboot;创建表CREATETABLEfurn(idINT(11)PRIMARYKEYAUTOINCREMENT,idnameVARCHAR(64)NOTNULL,家居名makerVARCHAR(64)NOTNULL,厂商priceDECIMAL(11,2)NOTNULL,价格salesINT(11)NOTNULL,销量stockINT(11)NOTNULL,库存imgpathVARCHAR(256)NOTNULL照片路径);初始化家居数据INSERTINTOfurn(id,name,maker,price,sales,stock,imgpath)VALUES(NULL,北欧风格小桌子,熊猫家居,180,666,7,assetsimagesproductimage6。jpg);INSERTINTOfurn(id,name,maker,price,sales,stock,imgpath)VALUES(NULL,简约风格小椅子,熊猫家居,180,666,7,assetsimagesproductimage4。jpg);INSERTINTOfurn(id,name,maker,price,sales,stock,imgpath)VALUES(NULL,典雅风格小台灯,蚂蚁家居,180,666,7,assetsimagesproductimage14。jpg);INSERTINTOfurn(id,name,maker,price,sales,stock,imgpath)VALUES(NULL,温馨风格盆景架,蚂蚁家居,180,666,7,assetsimagesproductimage16。jpg);SELECTFROMfurn; (2)进行数据库开发,首先要在pom。xml文件中引入springbootstarterdatajdbc。SpringBoot不知道项目要操作Mysql还是Oracle,因此还需要导入数据库驱动,并指定对应版本。!进行数据库开发,引入datajdbcstarterdependencygroupIdorg。springframework。bootgroupIdspringbootstarterdatajdbcartifactIddependency!导入mysql驱动,如果使用版本仲裁,SpringBoot默认的版本为8。0。26dependencygroupIdmysqlgroupIdmysqlconnectorjavaartifactIdversion5。1。49versiondependency (3)在application。yml配置操作数据源的信息spring:datasource:配置数据源说明:如果没有配置useSSLtrue,启动项目会报红警告,但不影响使用url:jdbc:mysql:localhost:3306springboot?useSSLtrueuseUnicodetruecharacterEncodingUTF8username:rootpassword:123456driverclassname:com。mysql。jdbc。Driver (4)创建JavabeanFurn。javapackagecom。li。thymeleaf。bean;importlombok。AllArgsConstructor;importlombok。Data;importlombok。NoArgsConstructor;importjava。math。BigDecimal;author李version1。0DataNoArgsConstructorAllArgsConstructorpublicclassFurn{privateIntegerid;privateStringname;privateStringmaker;privateBigDecimalprice;privateIntegersales;privateIntegerstock;privateStringimgPath;} (5)测试类ApplicationTests。javapackagecom。li。thymeleaf;importcom。li。thymeleaf。bean。Furn;importorg。junit。jupiter。api。Test;importorg。springframework。boot。test。context。SpringBootTest;importorg。springframework。jdbc。core。BeanPropertyRowMapper;importorg。springframework。jdbc。core。JdbcTemplate;importjavax。annotation。Resource;importjava。util。List;author李version1。0演示如何在SpringBoot中开发测试类SpringBootTestpublicclassApplicationTests{这里使用spring的JDBCTemplateResourceprivateJdbcTemplatejdbcTemplate;TestpublicvoidcontextLoads(){使用RowMapper接口来对返回的数据进行封装(底层是反射setter)BeanPropertyRowMapperFurnrowMappernewBeanPropertyRowMapper(Furn。class);ListFurnfurnsjdbcTemplate。query(selectfromfurn,rowMapper);for(Furnfurn:furns){System。out。println(furnfurn);}查看底层使用的是什么数据源System。out。println(jdbcTemplate。getDataSource()。getClass());}} 测试结果: spanstylecolor:E45649;ttdarkmodecolor:E45649;dependencyspanspanstylecolor:E45649;ttdarkmodecolor:E45649;groupIdspanorg。springframework。bootspangroupIdspanspanstylecolor:E45649;ttdarkmodecolor:E45649;artifactIdspanspringbootstartertestspanartifactIdspanspandependencyspan2。整合Druid到SpringBoot2。1Druid介绍alibabadruid:为监控而生的数据库连接池(github。com) 官方使用文档alibabadruidWiki(github。com) Druid数据库连接池性能优秀,它除了提供性能卓越的数据池功能外,还继承了SQL监控,黑名单拦截等功能。强大的监控特性,通过Druid提供的监控功能,可以清楚知道连接池和SQL的工作情况,所以根据项目需要,我们也要掌握Druid和SpringBoot的整合。 整合Druid到SpringBoot的方式:自定义方式引入starter2。2Druid基本使用 (1)修改pom。xml,引入druid依赖!引入druid依赖dependencygroupIdcom。alibabagroupIddruidartifactIdversion1。1。17versiondependency (2)创建配置类DruidDataSourceConfig。java,将DruidDataSource注入容器packagecom。li。thymeleaf。config;importcom。alibaba。druid。pool。DruidDataSource;importorg。springframework。boot。context。properties。ConfigurationProperties;importorg。springframework。context。annotation。Bean;importorg。springframework。context。annotation。Configuration;importjavax。sql。DataSource;author李version1。0配置类ConfigurationpublicclassDruidDataSourceConfig{注入DruidDataSource通过ConfigurationProperties指定读取application。yml文件的数据我们就不需要调用DruidDataSource的setXxx方法来配置(不推荐)ConfigurationProperties(spring。datasource)BeanpublicDataSourcedataSource(){returnnewDruidDataSource();}} (3)测试类ApplicationTests。java(略,同上) 测试结果: 2。2。1一个问题 问题:为什么我们注入了自己的数据源,默认的HikariDataSource就失效了? 先来弄明白,默认的HikariDataSource是如何配置的: SpringBoot通过DataSourceAutoConfiguration。java来进行数据源的配置,在进行默认的配置之前,如果检测到容器中已经有DataSourceBean,就不会注入默认的HikariDataSource。 因此,如果你注入了自己的数据源,就不会注入默认的HikariDataSource。 DataSourceAutoConfiguration。java: 2。3Druid监控功能2。3。1开启内置监控页 怎样使用Druid的内置监控页面:内置监控页面是一个Servlet,具体配置看这里 (1)在配置类中,启用druid的监控页功能: 在web项目中使用web。xml配置,若在SpringBoot中,有两种方法注入Servlet注解和RegistrationBean,这里使用RegistrationBean DruidDataSourceConfig。java:packagecom。li。thymeleaf。config;importcom。alibaba。druid。pool。DruidDataSource;importcom。alibaba。druid。support。http。StatViewServlet;importorg。springframework。boot。context。properties。ConfigurationProperties;importorg。springframework。boot。web。servlet。ServletRegistrationBean;importorg。springframework。context。annotation。Bean;importorg。springframework。context。annotation。Configuration;importjavax。sql。DataSource;author李version1。0配置类ConfigurationpublicclassDruidDataSourceConfig{注入DruidDataSource通过ConfigurationProperties指定读取yml文件的前缀的数据ConfigurationProperties(spring。datasource)BeanpublicDataSourcedataSource(){returnnewDruidDataSource();}配置Druid的监控页功能BeanpublicServletRegistrationBeanstatViewServlet(){创建StatViewServletServletRegistrationBeanStatViewServletregistrationBeannewServletRegistrationBean(newStatViewServlet(),druid);设置初始化参数用户名和密码根据官方配置文件设置registrationBean。addInitParameter(loginUsername,olien);registrationBean。addInitParameter(loginPassword,123456);returnregistrationBean;}} (2)启动项目,浏览器中访问http:项目ip:项目端口项目名称druidindex。html,输入配置的用户名和密码,即可访问到内置的监控页面: 2。3。2SQL监控 配置StatFilteralibabadruidWiki(github。com) 除了文档中的配置方式,也可在配置类中直接对数据源进行设置。 修改DruidDataSourceConfig。java: 启用SQL监控功能之后,在监控页中可以查看到所有对数据库发出的SQL语句: 2。3。3Web关联监控 Web关联监控配置 Spring关联监控配置 修改DruidDataSourceConfig。java:注入webStatFilter配置WebStatFilter,用于采集webjdbc关联的监控数据BeanpublicFilterRegistrationBeanwebStatFilter(){创建过滤器webStatFilterWebStatFilterwebStatFilternewWebStatFilter();FilterRegistrationBeanWebStatFilterfilterRegistrationBeannewFilterRegistrationBean(webStatFilter);设置webStatFilter的监控urlfilterRegistrationBean。setUrlPatterns(Arrays。asList());根据官方文档设置webStatFilter排除的urlfilterRegistrationBean。addInitParameter(exclusions,。js,。gif,。jpg,。png,。css,。ico,druid);returnfilterRegistrationBean;} 启用URI监控功能之后,在监控页中可以查看到所有的Web应用情况和URI请求情况: 2。3。4SQL防火墙 Druid提供了WallFilter,它是基于SQL语义分析来实现防御SQL注入攻击的。具体配置看这里 修改DruidDataSourceConfig。java: 启用SQL防火墙之后,在监控页中可以查看到所有的SQL情况: 2。3。5Session监控 注意:这里的Session不包括Druid后台监控系统产生的Session Druid的Session监控不需要配置,在开启了内置监控功能后就可以使用了。 2。4DruidStarter 整合Druid到SpringBoot的方式有两种:自定义方式和引入starter。 2。3中的所有例子中我们使用的是自己引入druid配置类方式整合druid和监控。此外,还可以引入DruidSrpingBootStarter,让程序员在SpringBoot项目中更加轻松集成Druid和监控。 演示使用DruidStarter(演示之前,删除之前所有的自定义方式操作) (1)pom。xml引入druidspringbootstarter!引入druid的starterdependencygroupIdcom。alibabagroupIddruidspringbootstarterartifactIdversion1。1。17versiondependency (2)在application。yml文件中配置druid和监控功能spring:datasource:配置数据源如果没有配置useSSLtrue,启动项目会报红警告,但不影响使用url:jdbc:mysql:localhost:3306springboot?useSSLtrueuseUnicodetruecharacterEncodingUTF8username:rootpassword:123456driverclassname:com。mysql。jdbc。Driver配置druid和监控功能druid:statviewservlet:(1)开启监控页enabled:trueloginusername:jackloginpassword:1234resetenable:falsewebstatfilter:(2)启用web监控功能enabled:trueurlpattern:exclusions:。js,。gif,。jpg,。png,。css,。ico,druidfilter:stat:(3)启用sql监控功能slowsqlmillis:1000单位mslogslowsql:true启用慢查询的sql日志enabled:truewall:(4)启用sql防火墙功能enabled:trueconfig:droptableallow:false是否允许进行删除表的操作selectallcolumnallow:false是否允许查询所有字段的操作3。练习 将异常处理、注入Servlet、Filter、Listener,Tomcat切换,数据库操作(HikariDataSourceDruidDataSource)相关代码和案例写一遍