专栏电商日志财经减肥爱情
投稿投诉
爱情常识
搭配分娩
减肥两性
孕期塑形
财经教案
论文美文
日志体育
养生学堂
电商科学
头戴业界
专栏星座
用品音乐

SpringBootDruidDataSource实现监控M

  1。基本概念
  我们都使用过连接池,比如C3P0,DBCP,hikari,Druid,虽然HikariCP的速度稍快,但Druid能够提供强大的监控和扩展功能,也是阿里巴巴的开源项目。
  Druid是阿里巴巴开发的号称为监控而生的数据库连接池,在功能、性能、扩展性方面,都超过其他数据库连接池,包括DBCP、C3P0、BoneCP、Proxool、JBossDataSource等等,秒杀一切。
  Druid可以很好的监控DB池连接和SQL的执行情况,天生就是针对监控而生的DB连接池。
  SpringBoot默认数据源HikariDataSource与JdbcTemplate中已经介绍SpringBoot2。x默认使用Hikari数据源,可以说Hikari与Driud都是当前JavaWeb上最优秀的数据源。
  而Druid已经在阿里巴巴部署了超过600个应用,经过好几年生产环境大规模部署的严苛考验!stat:Druid内置提供一个StatFilter,用于统计监控信息。wall:Druid防御SQL注入攻击的WallFilter就是通过Druid的SQLParser分析。Druid提供的SQLParser可以在JDBC层拦截SQL做相应处理,比如说分库分表、审计等。log4j2:这个就是日志记录的功能,可以把sql语句打印到log4j2供排查问题。2。相关配置2。1添加依赖propertiesjava。version1。8java。version1。2。11alibabaDruidStarter。versionpropertiesdependencygroupIdcom。alibabagroupIddruidspringbootstarterartifactIdversion{alibabaDruidStarter。version}versiondependency2。2配置属性配置Druid数据源(连接池):如同c3p0、dbcp数据源可以设置数据源连接初始化大小、最大连接数、等待时间、最小连接数等一样,Druid数据源同理可以进行设置。配置Druidweb监控filter(WebStatFilter):这个过滤器的作用就是统计web应用请求中所有的数据库信息,比如发出的sql语句,sql执行的时间、请求次数、请求的url地址、以及seesion监控、数据库表的访问次数等等。配置Druid后台管理Servlet(StatViewServlet):Druid数据源具有监控的功能,并提供了一个web界面方便用户查看,类似安装路由器时,人家也提供了一个默认的web页面;需要设置Druid的后台管理页面的属性,比如登录账号、密码等。
  【注意】:DruidSpringBootStarter配置属性的名称完全遵照Druid,可以通过SpringBoot配置文件来配置Druid数据库连接池和监控,如果没有配置则使用默认值,如下在application。yml配置相关属性:spring配置spring:datasource:driverclassname:com。mysql。cj。jdbc。Driverpassword:123456username:rooturl:jdbc:mysql:localhost:3306superjson?useUnicodetruecharacterEncodingutf8useSSLfalse连接池配置druid:初始化大小,最小,最大initialsize:5minidle:5maxactive:20配置获取连接等待超时的时间maxwait:60000配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位毫秒timebetweenevictionrunsmillis:60000配置一个连接在池中最小生存时间minevictableidletimemillis:300000validationquery:SELECT1FROMusertestwhileidle:truetestonborrow:falsetestonreturn:false打开PSCache,并且指定每个连接上PSCache的大小poolpreparedstatements:truemaxpoolpreparedstatementperconnectionsize:20配置监控统计拦截的Filter,去掉后监控界面SQL无法统计,wall用于防火墙filters:stat,wall,slf4j通过connectionproperties属性打开mergeSql功能;慢SQL记录connectionproperties:druid。stat。mergeSqltrue;druid。stat。slowSqlMillis5000配置DruidStatFilterwebstatfilter:enabled:trueurlpattern:exclusions:。js,。gif,。jpg,。bmp,。png,。css,。ico,druid配置DruidStatViewServletstatviewservlet:urlpattern:druidIP白名单,没有配置或者为空,则允许所有访问allow:127。0。0。1IP黑名单,若白名单也存在,则优先使用deny:192。168。31。253禁用HTML中ResetAll按钮resetenable:false登录用户名密码loginusername:rootloginpassword:123456需要设置enabledtrue,否则会报出Therewasanunexpectederror(typeNotFound,status404)。错误,或者将druidspringbootstarter的版本降低到1。1。10及以下是否启用StatViewServlet(监控页面)默认值为false(考虑到安全问题默认并未启动,如需启用建议设置密码或白名单以保障安全)enabled:true
  上述配置文件的参数可以在com。alibaba。druid。spring。boot。autoconfigure。properties。DruidStatProperties和org。springframework。boot。autoconfigure。jdbc。DataSourcePropertie中找到。2。3配置Filter
  可以通过spring。datasource。druid。filtersstat,wall,log4j。。。的方式来启用相应的内置Filter,不过这些Filter都是默认配置。如果默认配置不能满足需求,可以放弃这种方式,通过配置文件来配置Filter,如下所示:配置StatFilterspring。datasource。druid。filter。stat。enabledtruespring。datasource。druid。filter。stat。dbtypeh2spring。datasource。druid。filter。stat。logslowsqltruespring。datasource。druid。filter。stat。slowsqlmillis2000配置WallFilterspring。datasource。druid。filter。wall。enabledtruespring。datasource。druid。filter。wall。dbtypeh2spring。datasource。druid。filter。wall。config。deleteallowfalsespring。datasource。druid。filter。wall。config。droptableallowfalse
  目前为以下Filter提供了配置支持,根据(spring。datasource。druid。filter。)进行配置。StatFilterWallFilterConfigFilterEncodingConvertFilterSlf4jLogFilterLog4jFilterLog4j2FilterCommonsLogFilter
  不想使用内置的Filters,要想使自定义Filter配置生效需要将对应Filter的enabled设置为true,DruidSpringBootStarter默认禁用StatFilter,可以将其enabled设置为true来启用它。3监控页面启动项目后,访问http:localhost:8081druidlogin。html来到登录页面,输入用户名密码登录,如下所示:
  图片数据源页面是当前DataSource配置的基本信息,上述配置的Filter可以在里面找到,如果没有配置Filter(一些信息会无法统计,例如SQL监控会无法获取JDBC相关的SQL执行信息)
  图片SQL监控页面,统计了所有SQL语句的执行情况
  图片URL监控页面,统计了所有Controller接口的访问以及执行情况
  图片Spring监控页面,利用aop对指定接口的执行时间,jdbc数进行记录
  图片SQL防火墙页面
  druid提供了黑白名单的访问,可以清楚的看到sql防护情况。Session监控页面
  可以看到当前的session状况,创建时间、最后活跃时间、请求次数、请求时间等详细参数。JSONAPI页面
  通过api的形式访问Druid的监控接口,api接口返回Json形式数据。4。sql监控
  配置Druidweb监控filter(WebStatFilter)这个过滤器,作用就是统计web应用请求中所有的数据库信息,比如发出的sql语句,sql执行的时间、请求次数、请求的url地址、以及seesion监控、数据库表的访问次数,如下配置:spring:datasource:druid:配置WebStatFilter,用于采集web关联监控的数据webstatfilter:enabled:true启动StatFilterurlpattern:过滤所有urlexclusions:。js,。gif,。jpg,。png,。css,。ico,druid排除一些不必要的urlsessionstatenable:true开启session统计功能sessionstatmaxcount:1000session的最大个数,默认1005。慢sql记录
  有时候,系统中有些SQL执行很慢,我们希望使用日志记录下来,可以开启Druid的慢SQL记录功能,如下配置:spring:datasource:druid:filter:stat:enabled:true开启DruidDataSource状态监控dbtype:mysql数据库的类型logslowsql:true开启慢SQL记录功能slowsqlmillis:2000默认3000毫秒,这里超过2s,就是慢,记录到日志
  启动后,如果遇到执行慢的SQL,便会输出到日志中6。spring监控
  访问之后spring监控默认是没有数据的,但需要导入SprngBoot的AOP的Starter,如下所示:!SpringBoot的aop模块dependencygroupIdorg。springframework。bootgroupIdspringbootstarteraopartifactIddependency
  同时需要在application。yml按如下配置:
  Spring监控AOP切入点,如com。springboot。template。dao。,配置多个英文逗号分隔spring。datasource。druid。aoppatternscom。springboot。template。dao。7。去广告(Ad)
  访问监控页面的时候,你可能会在页面底部(footer)看到阿里巴巴的广告,如下所示:
  图片
  原因:引入的druid的jar包中的common。js(里面有一段js代码是给页面的footer追加广告的)
  如果想去掉,有两种方式:1。直接手动注释这段代码
  如果是使用Maven,直接到本地仓库中,查找这个jar包,注释如下代码:this。buildFooter();
  common。js的位置:comalibabadruid1。1。23druid1。1。23。jar!supporthttpresourcesjscommon。js2。使用过滤器过滤
  注册一个过滤器,过滤common。js的请求,使用正则表达式替换相关的广告内容,如下代码所示:ConfigurationConditionalOnWebApplicationAutoConfigureAfter(DruidDataSourceAutoConfigure。class)ConditionalOnProperty(namespring。datasource。druid。statviewservlet。enabled,havingValuetrue,matchIfMissingtrue)publicclassRemoveDruidAdConfig{方法名:removeDruidAdFilterRegistrationBean方法描述除去页面底部的广告parampropertiescom。alibaba。druid。spring。boot。autoconfigure。properties。DruidStatPropertiesreturnorg。springframework。boot。web。servlet。FilterRegistrationBeanBeanpublicFilterRegistrationBeanremoveDruidAdFilterRegistrationBean(DruidStatPropertiesproperties){获取web监控页面的参数DruidStatProperties。StatViewServletconfigproperties。getStatViewServlet();提取common。js的配置路径Stringpatternconfig。getUrlPattern()!null?config。getUrlPattern():druid;StringcommonJsPatternpattern。replaceAll(,jscommon。js);finalStringfilePathsupporthttpresourcesjscommon。js;创建filter进行过滤FilterfilternewFilter(){Overridepublicvoidinit(FilterConfigfilterConfig)throwsServletException{}OverridepublicvoiddoFilter(ServletRequestrequest,ServletResponseresponse,FilterChainchain)throwsIOException,ServletException{chain。doFilter(request,response);重置缓冲区,响应头不会被重置response。resetBuffer();获取common。jsStringtextUtils。readFromResource(filePath);正则替换banner,除去底部的广告信息texttext。replaceAll(
  ,);texttext。replaceAll(powered。?shrek。wang,);response。getWriter()。write(text);}Overridepublicvoiddestroy(){}};FilterRegistrationBeanregistrationBeannewFilterRegistrationBean();registrationBean。setFilter(filter);registrationBean。addUrlPatterns(commonJsPattern);returnregistrationBean;}}
  两种方式都可以,建议使用的是第一种,从根源解决。8。获取Druid的监控数据
  Druid的监控数据可以在开启StatFilter后,通过DruidStatManagerFacade进行获取;
  DruidStatManagerFacadegetDataSourceStatDataList该方法可以获取所有数据源的监控数据,除此之外DruidStatManagerFacade还提供了一些其他方法,可以按需选择使用。RestControllerRequestMapping(valuedruid)publicclassDruidStatController{GetMapping(stat)publicObjectdruidStat(){获取数据源的监控数据returnDruidStatManagerFacade。getInstance()。getDataSourceStatDataList();}}

国家一级演员王刚三婚娶小20岁女粉丝,60岁得子后不敢休息阅读此文之前,麻烦您点击下关注,方便您及时观看下一篇精彩文章。1994年,一部宰相刘罗锅的走红,让王刚饰演的和珅走进了大众的视野。此后他先后在不同的剧中饰演了320集的和珅,因此被中央气象台北方继续大风降温沙尘天气南方将有今年以来最强降水今天(3月22日),冷空气带来的大风沙尘影响我国北方地区,昨天(21日),大范围的沙尘天气覆盖我国西北华北等地,今天还将继续向南推进至黄淮南部一带,预计到明天白天才会逐渐减弱结束。娃写字难看,不爱写字,咋办?本文看点写字,也可以有趣,如何让孩子愿意练习,关键在于父母如何搭建脚手架。今天的文章,就是一些非常实用的建议最近好多妈妈跟我聊天说娃因为字难看被老师找,回家盯着娃练,磨磨蹭蹭30分孕反严重,剖腹产手术前一晚还在吐的我,竟生出了6斤6两的娃2023育儿季妊娠反应一般会持续多长时间?3个月,4个月还是5个月?但你们有见过孕反持续了整个孕期的人吗?我就是这种人。毫不夸张,已经到预产期要做剖腹产手术的前一晚,我还在呕吐。怀湖南常宁茶香四溢3月20日,在湖南衡阳常宁市塔山瑶族乡,茶农在茶园采茶(无人机照片)。近日,湖南衡阳常宁市塔山瑶族乡的5。3万亩高山茶进入采摘期,茶农忙着采摘加工供应市场。当地依托自然生态特点,发喜讯!茂名高新区企业荣获华炬杯总决赛2个一等奖3月17日,第八届华炬杯创新创业大赛总决赛暨颁奖仪式在清远高新区华南863科技创新园隆重举行。其中,来自茂名高新区的广东汇发塑业科技有限公司荣获海归精英组一等奖广东新华粤树脂科技有宝安百亿级企业的数字产线智能制造时代,数字化智能化赋能企业高质量发展。作为深圳的制造压舱石,宝安早已在产业数字化领域迈开探索的步伐,尤其是几大产业集群链主,智慧工厂建设已颇具规模和成效,产业数字化数字产业2022年湖南省消费维权十大典型案例打击消费侵权十大典型案例公布2022年湖南省消费维权十大典型案例(一)宁乡市调处长沙某游泳有限公司教练员和安全员资格考试培训不履约退费案(二)攸县调处攸县某超市鸭制品亚硝酸盐超标损害赔偿案(三)平江县调处平江转发周知!关于儿童退烧药的十个热点问答退烧药应该怎么选?什么时候给孩子用退烧药?两种退烧药可以交替使用吗?关于儿童退烧药,就家长关注的十大热点问题,专家解答来了问题一退烧药应该怎么选?目前推荐的儿童安全有效的退热药物只项羽为何宁死不肯过乌江,并非不想卷土重来,而是过江比自刎更惨项羽是楚汉时期的一代英雄人物,堪称一代战神千古无二,如果没有项羽,秦军大将章邯,很有可能会带领秦军,逐一打败各路实力,维持秦朝的统治。但是巨鹿之战,项羽以5万人马,其中只有八千江东外祖母那惨白的人生很长时间以来,一想起外祖母时,卢慕贞和朱安夫人两个小脚老太的影子就会同时浮现在我的脑海里。卢慕贞是孙中山的原配夫人,朱安是鲁迅的结发之妻。她们彼此的生活轨迹虽没有交集,然而她们悲剧
遇见你,有欢喜,有心痛,想念你,有幸福,有伤感头条创作挑战赛时间悄悄流逝,有多少人,成了笔下的故事,写下太多的思念,只为了能让你看见,心里想念着你,这个冬天不会感受到严寒。遇见你,有欢喜,有心痛,想念你,有幸福,有伤感,阳光正周鹏升至CBA历史总出场次数榜榜首深圳力克上海终结对手3连胜北京时间1月13日11时,202223赛季CBA常规赛第25轮,上海队对战深圳队。历经一番角逐,深圳队11299力克上海队从而终结了对手3连胜势头。此役战罢,周鹏CBA生涯总出场次顾全4记三分,萨林杰22分,王哲林低迷,深圳六人上双力克上海!北京时间1月13日1100点,CBA常规赛迎来上海与深圳的三番战,前两战两队平分秋色,此役上海全员低迷,而深圳多点开花,最终深圳拿下比赛。首节,沈梓捷率先攻进,顾全三分射进,王哲林上海球迷想念刘铮,疲惫上海不敌深圳,李春江想提前放弃?202223赛季CBA第26轮比赛,上海对战深圳。这是本赛季两队第三次交手,也是常规赛最后一次,此前交手两队互有胜负打成平手。上海队目前胜场领先深圳两个,所以本场比赛深圳势在必得,谁赞成谁反对?大公主HHH及其他WWE官员反对公司出售!前几天,文斯麦克曼重返了WWE董事会。最近,据透露,文斯麦克曼想要出售WWE,并正在为WWE寻找可能的买家。文斯麦克曼回到WWE后,斯蒂芬妮麦克曼宣布辞职并离开WWE。后来,文斯麦谦虚!非洲选手战胜国乒名将,盛赞对手优秀,曾多次打败世界冠军乒乓球WTT南非德班挑战赛正火热进行,在男单的首轮较量中,国乒名将孙闻惨遭暴击,大比分13输给了非洲一哥尼日利亚选手阿鲁纳。不过在比赛结束后,阿鲁纳非常谦虚地盛赞对手很优秀,同时祝好消息恶意撞人致5死13伤的司机可能被判死刑,这回他笑不出来了1月11日17时25分,广州天河路体育东路口发生一起车祸,一辆宝马车连续6次恶意撞击行人,目前已经造成5人死亡,13人受伤。最新消息传来2023年1月14日,广州市检察机关依法以涉大麦植发冲击植发第二股,高毛利低净利能走多远?作者丨魏笑编辑丨孙超逸继容貌焦虑身材焦虑后,脱发焦虑正席卷年轻人。此外,值得注意的是,继咳嗽失眠脑雾后,近日脱发也成为人们热议的新冠后遗症之一。年轻群体的头发焦虑也带动了植发赛道迅西超杯4淘汰贝蒂斯将与皇马争冠北京时间1月13日凌晨3点,西班牙超级杯第二场半决赛在沙特进行,巴塞罗那对阵皇家贝蒂斯。上半场,登贝莱助攻莱万破门下半场,费基尔扳平比分,90分钟两队打成11。进入加时赛,法蒂为巴全明星投票第二轮结果詹姆斯力压KD蝉联票王,塔图姆反超恩比德NBA公布了全明星投票第二轮结果勒布朗詹姆斯以482万5229张票蝉联票王,凯文杜兰特450万9238张票领衔东部所有球员。西部前场詹姆斯(482万5229张)尼克拉约基奇(344足协杯发现国足大问题,第一国门竟然一个点球都扑不出来北京时间1月11日下午1630,足协杯半决赛,上海海港对阵浙江。第10分钟,伊萨卡隆在无对抗情况下受伤倒地,随后他被冯劲替换下场。第32分钟,武磊下底传低平球,吕文君的射门被浙江后
友情链接:快好找快生活快百科快传网中准网文好找聚热点快软网