范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

SpringBootDruidDataSource实现监控MySQL性能

  1. 基本概念
  我们都使用过连接池,比如  C3P0,DBCP,hikari, Druid  ,虽然HikariCP的速度稍快,但Druid能够提供强大的监控和扩展功能,也是阿里巴巴的开源项目。
  Druid是阿里巴巴开发的号称为监控而生的数据库连接池,在功能、性能、扩展性方面,都超过其他数据库连接池,包括  DBCP、C3P0、BoneCP、Proxool、JBoss DataSource  等等,秒杀一切。
  Druid可以很好的监控DB池连接和SQL的执行情况,天生就是针对监控而生的DB连接池。
  Spring Boot默认数据源  HikariDataSource  与JdbcTemplate  中已经介绍Spring Boot 2.x默认使用Hikari数据源,可以说Hikari与Driud都是当前Java Web上最优秀的数据源。
  而Druid已经在阿里巴巴部署了超过600个应用,经过好几年生产环境大规模部署的严苛考验!    stat:   Druid内置提供一个StatFilter  ,用于统计监控信息。 wall:   Druid防御SQL注入攻击的WallFilter  就是通过Druid的SQL Parser分析。Druid提供的SQL Parser  可以在JDBC层拦截SQL做相应处理,比如说分库分表、审计等。 log4j2:   这个就是 日志记录的功能,可以把sql语句打印到log4j2供排查问题。 2. 相关配置2.1 添加依赖     1.8     1.2.11        com.alibaba     druid-spring-boot-starter     ${alibabaDruidStarter.version}  2.2 配置属性配置Druid数据源(连接池):   如同c3p0、dbcp数据源可以设置数据源连接初始化大小、最大连接数、等待时间、最小连接数 等一样,Druid数据源同理可以进行设置。 配置Druid web监控filter(WebStatFilter):   这个过滤器的作用就是统计web应用请求中所有的数据库信息,比如 发出的sql语句,sql执行的时间、请求次数、请求的url地址、以及seesion监控、数据库表的访问次数等等。 配置Druid后台管理Servlet(StatViewServlet):   Druid数据源具有监控的功能,并提供了一个web界面方便用户查看,类似安装 路由器 时,人家也提供了一个默认的web页面;需要设置Druid的后台管理页面的属性,比如 登录账号、密码等。
  【注意】:  Druid Spring Boot Starter  配置属性的名称完全遵照Druid,可以通过Spring Boot配置文件来配置Druid数据库连接池和监控,如果没有配置则使用默认值,如下在application.yml  配置相关属性:  # spring 配置 spring:   datasource:     driver-class-name: com.mysql.cj.jdbc.Driver     password: 123456     username: root     url: jdbc:mysql://localhost:3306/superjson?useUnicode=true&characterEncoding=utf8&useSSL=false     # 连接池配置     druid:       # 初始化大小,最小,最大       initial-size: 5       min-idle: 5       max-active: 20       # 配置获取连接等待超时的时间       max-wait: 60000       # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位毫秒       time-between-eviction-runs-millis: 60000       # 配置一个连接在池中最小生存时间       min-evictable-idle-time-millis: 300000       validation-query: SELECT 1 FROM user       test-while-idle: true       test-on-borrow: false       test-on-return: false       # 打开 PSCache,并且指定每个连接上 PSCache 的大小       pool-prepared-statements: true       max-pool-prepared-statement-per-connection-size: 20       # 配置监控统计拦截的 Filter,去掉后监控界面 SQL 无法统计,wall 用于防火墙       filters: stat,wall,slf4j       # 通过 connection-properties 属性打开 mergeSql 功能;慢 SQL 记录       connection-properties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000       # 配置 DruidStatFilter       web-stat-filter:         enabled: true         url-pattern: /*         exclusions: .js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*       # 配置 DruidStatViewServlet       stat-view-servlet:         url-pattern: /druid/*         # IP 白名单,没有配置或者为空,则允许所有访问         allow: 127.0.0.1         # IP 黑名单,若白名单也存在,则优先使用         deny: 192.168.31.253         # 禁用 HTML 中 Reset All 按钮         reset-enable: false         # 登录用户名/密码         login-username: root         login-password: 123456         # 需要设置enabled=true,否则会报出There was an unexpected error (type=Not Found, status=404).错误,或者将druid-spring-boot-starter的版本降低到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.filters=stat,wall,log4j ...  的方式来启用相应的内置Filter,不过这些Filter都是默认配置。如果默认配置不能满足需求,可以放弃这种方式,通过配置文件来配置Filter,如下所示:  # 配置StatFilter  spring.datasource.druid.filter.stat.enabled=true spring.datasource.druid.filter.stat.db-type=h2 spring.datasource.druid.filter.stat.log-slow-sql=true spring.datasource.druid.filter.stat.slow-sql-millis=2000  # 配置WallFilter  spring.datasource.druid.filter.wall.enabled=true spring.datasource.druid.filter.wall.db-type=h2 spring.datasource.druid.filter.wall.config.delete-allow=false spring.datasource.druid.filter.wall.config.drop-table-allow=false
  目前为以下Filter提供了配置支持,根据(  spring.datasource.druid.filter.*  )进行配置。  StatFilter WallFilter ConfigFilter EncodingConvertFilter Slf4jLogFilter Log4jFilter Log4j2Filter CommonsLogFilter
  不想使用内置的Filters,要想使自定义Filter配置生效需要将对应Filter的enabled设置为true,  Druid Spring Boot Starter  默认禁用StatFilter,可以将其enabled设置为true来启用它。  3 监控页面启动项目后,访问http://localhost:8081/druid/login.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监控
  配置Druid web监控filter(  WebStatFilter  )这个过滤器,作用就是统计web应用请求中所有的数据库信息,比如 发出的sql语句,sql执行的时间、请求次数、请求的url地址、以及seesion监控、数据库表的访问次数,如下配置:  spring:   datasource:     druid:       ########## 配置WebStatFilter,用于采集web关联监控的数据 ##########       web-stat-filter:         enabled: true                   # 启动 StatFilter         url-pattern: /*                 # 过滤所有url         exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" # 排除一些不必要的url         session-stat-enable: true       # 开启session统计功能         session-stat-max-count: 1000    # session的最大个数,默认100 5. 慢sql记录
  有时候,系统中有些SQL执行很慢,我们希望使用日志记录下来,可以开启Druid的慢SQL记录功能,如下配置:    spring:   datasource:     druid:       filter:         stat:           enabled: true         # 开启DruidDataSource状态监控           db-type: mysql        # 数据库的类型           log-slow-sql: true    # 开启慢SQL记录功能           slow-sql-millis: 2000 # 默认3000毫秒,这里超过2s,就是慢,记录到日志
  启动后,如果遇到执行慢的SQL,便会输出到日志中    6. spring 监控
  访问之后spring监控默认是没有数据的,但需要导入SprngBoot的AOP的Starter,如下所示:          org.springframework.boot     spring-boot-starter-aop 
  同时需要在application.yml按如下配置:
  Spring监控AOP切入点,如  com.springboot.template.dao.*  ,配置多个英文逗号分隔  spring.datasource.druid.aop-patterns="com.springboot.template.dao.*" 7. 去广告(Ad)
  访问监控页面的时候,你可能会在页面底部(footer)看到阿里巴巴的广告,如下所示:
  图片
  原因:引入的druid的jar包中的common.js(里面有一段js代码是给页面的footer追加广告的)
  如果想去掉,有两种方式:    1. 直接手动注释这段代码
  如果是使用Maven,直接到本地仓库中,查找这个jar包,注释如下代码:    // this.buildFooter();
  common.js的位置:    com/alibaba/druid/1.1.23/druid-1.1.23.jar!/support/http/resources/js/common.js 2. 使用过滤器过滤
  注册一个过滤器,过滤  common.js  的请求,使用正则表达式替换相关的广告内容,如下代码所示:  @Configuration @ConditionalOnWebApplication @AutoConfigureAfter(DruidDataSourceAutoConfigure.class) @ConditionalOnProperty(name = "spring.datasource.druid.stat-view-servlet.enabled", havingValue = "true", matchIfMissing = true) public class RemoveDruidAdConfig {      /**     * 方法名: removeDruidAdFilterRegistrationBean     * 方法描述 除去页面底部的广告     * @param properties com.alibaba.druid.spring.boot.autoconfigure.properties.DruidStatProperties     * @return org.springframework.boot.web.servlet.FilterRegistrationBean     */     @Bean     public FilterRegistrationBean removeDruidAdFilterRegistrationBean(DruidStatProperties properties) {          // 获取web监控页面的参数         DruidStatProperties.StatViewServlet config = properties.getStatViewServlet();         // 提取common.js的配置路径         String pattern = config.getUrlPattern() != null ? config.getUrlPattern() : "/druid/*";         String commonJsPattern = pattern.replaceAll("*", "js/common.js");          final String filePath = "support/http/resources/js/common.js";          //创建filter进行过滤         Filter filter = new Filter() {             @Override             public void init(FilterConfig filterConfig) throws ServletException {}              @Override             public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {                 chain.doFilter(request, response);                 // 重置缓冲区,响应头不会被重置                 response.resetBuffer();                 // 获取common.js                 String text = Utils.readFromResource(filePath);                 // 正则替换banner, 除去底部的广告信息                 text = text.replaceAll("
  ", "");                 text = text.replaceAll("powered.*?shrek.wang", "");                 response.getWriter().write(text);             }              @Override             public void destroy() {}         };          FilterRegistrationBean registrationBean = new FilterRegistrationBean();         registrationBean.setFilter(filter);         registrationBean.addUrlPatterns(commonJsPattern);         return registrationBean;     } }
  两种方式都可以,建议使用的是第一种,从根源解决。    8. 获取 Druid 的监控数据
  Druid的监控数据可以在开启  StatFilter  后,通过DruidStatManagerFacade  进行获取;
  DruidStatManagerFacade#getDataSourceStatDataList  该方法可以获取所有数据源的监控数据,除此之外DruidStatManagerFacade  还提供了一些其他方法,可以按需选择使用。  @RestController @RequestMapping(value = "/druid") public class DruidStatController {      @GetMapping("/stat")     public Object druidStat(){         // 获取数据源的监控数据         return DruidStatManagerFacade.getInstance().getDataSourceStatDataList();     } }

医生帮你盘点可以损害肝脏的6大食物上次发了一个微头条,简单地说了一下哪些食物可以损害肝脏,大家直呼不够详细,这次就给大家来详细地说一下。肝脏是我们人体的五大脏器之一,具有代谢体内的物质分泌和排泄胆汁解毒造血等功能,红粉宝宝16岁就开始整容,花400万动刀200次,结局太过凄惨这个女人被称为中国第一整容狂人,花费400万动刀200次,为了追求完美的身材,甚至还去做了胸部整形手术,结果因为整容过度,导致一度昏迷不醒。作为整容界的榜一大哥,红粉宝宝为了变美究人手一条的工装裤,魅力在哪?时尚是不分季节的。CropTop长裤的搭配霸占了2022的夏天。杨幂刘雯在多位时尚icon的带货下,工装裤再次回春,成为今年炙手可热的单品。炎热的天气也丝毫没有影响工装裤的出镜率。最近买的小白裙奶油半裙都好好看啊最近真的是连续高温预警,白天大太阳太毒根本没法出门,我自己拍穿搭的时候才发现自己手臂手脖子都晒黑了不少,跟我大腿简直就是两个色号。后来想想,总归冬天还是会捂白回来的,也就无所谓了,莱后一家四口逛街好养眼!却成全家最矮,大公主穿粉裙凸牙太明显西班牙王室最近在度假,而正好也是趁着两个公主放暑假的时间,所以这对姐妹花最近的亮相就比较多,而两个公主真是肉眼可见的长大了很多,姐妹花在假期的造型也是丰富多彩,而16岁的姐姐莱昂诺夏天穿鲨鱼裤太尴尬?那是因为不懂穿搭套路,真不是身材的锅为什么有些人在夏天穿鲨鱼裤,会显得特别尴尬?但是有些人却能够穿出时尚,又显身材的效果?鲨鱼裤到底怎么穿才能兼备舒爽又高级的感觉?其实之所以你穿不好鲨鱼裤,最大的原因就是不懂得穿搭套头发和脸经常出油?多半是这4个原因,或能帮您缓解尴尬许多人头发以及脸部油脂分泌旺盛,刚洗完脸不用两三个小时摸起来油腻,头发怎么清洗也无法保持干爽,而许多因素影响都会让身体多个部位油脂分泌量多,如果可以消除影响因素,有效控油,油脂分泌看了84岁琼瑶阿姨的穿搭,才发现女人端庄优雅比时髦扮嫩更迷人都说女人在少女阶段是一杯白开水,清纯干净不掺杂任何瑕疵而到了中年阶段,便犹如一杯咖啡,虽苦但香浓一旦踏入了中老年阶段,就像一杯茶,需要细细品味才可以感受到它的醇厚淡雅。如今84岁的不花钱变美30个优雅的小习惯坚持半年惊艳所有人1气质比样貌重要,气质与年龄无关。2保持整洁,不管是自己还是家里。3可以少买几件衣服,但买的质感一定要好。4鞋子一定要舒服。5少折腾头发,定期使用发膜护发。6尽可能地多微笑。7减少脚怎样美白最快最有效的方法这样做亲测有效纤纤玉足你值得拥有脚怎样美白最快最有效的方法,每每到夏季,很多小姐妹都会露腿露脚的穿的很清爽,但也有一部分人是长裤运动鞋等等,事实上并不是不热,而是没有勇气露脚。脚后跟干裂是很多人都存在的问题,而脚2年合同!费内巴切官宣签约!别利察正式离开NBA北京时间8月10日,土耳其费内巴切俱乐部官方宣布,球队已经和前勇士球员内马尼亚别利察签下一份2年合同!根据此前报道,勇士曾有意为别老师提供一份老将底薪合同,但他最终还是选择了离开N有了这个经典名方还怕入睡困难?总是想太多?失眠睡不着?经常半夜醒?其实用这一个经典方子就够了,当您肝血不足时,肝不能正常的疏泄气血,肝阴和肝阳强弱失衡,肝气升发太过,肝火上炎就导致心神不安,会引发失眠从而出现入防控近视八大注意事项一营养要均衡1。平时注意营养,多吃一些含维生素A的食物,如胡萝卜菠菜动物肝脏鱼肝油鱼卵禽蛋等。如果维生素A不足,则视紫红质的再生较慢而且不完全,暗适应时间延长,严重时造成夜盲症。2老人骨折后,一般寿命都不长?是真的吗?一文告诉你答案老人害怕的疾病不是癌症,而是骨折。为什么这样说呢?不知大家有没有听过这样一句话老人骨折后,长期卧床,寿命一般都不长。那么,对于老人而言,骨折后身体会怎么样?进入老年阶段后,人体的吸急救穴郄穴概念郄穴郄,空隙间隙。十二经脉各有一空隙较大的郄穴,加上阳跷脉阴跷脉阳维脉阴维脉各有一个郄穴,合称十六郄穴。除梁丘穴位于膝关节以上,其余十五郄穴均位于四肢肘膝关节以下。郄穴为人体重糖尿病吃什么安心?陆博士告诉你,这九大食物准没错患了糖尿病不知道吃什么?这是饮食九大最佳食物,安心吃。1绿叶蔬菜绿叶蔬菜含有丰富维生素与淀粉消化酶,对糖尿病稳定血糖很有帮助。2肥鱼肥鱼含有人体需要的一定数量脂肪和蛋白质,保证身体啤酒配小龙虾,痛风找上门?做好3点,减轻疼痛不适近几年来小龙虾这种食物风靡全球,许多人在吃宵夜时会选择小龙虾,有各种口味,其中十三香小龙虾麻辣小龙虾油焖小龙虾等最受欢迎,相比普通的虾肉来说吃起来更弹牙,味道鲜美。但有部分人长时间冠心病患者的护理方法,你知道吗?冠心病是一种慢性心脏病,其治疗需要长期进行。药物治疗可以防止疾病的进一步发展,防止血栓形成和血管狭窄的增加。长期高昂的治疗费用和药物的副作用,往往让患者无法坚持。更何况冠心病患者早夏季唯美连衣裙街拍,让整个夏天看起来很年轻的小姐姐夏季唯美连衣裙街拍,让整个夏天看起来很年轻的小姐姐如何在半年内快速逆袭呢1不要沉迷于爱情2学会存钱,半年内存够10万3关掉朋友圈卸载游戏少刷视频4拒绝拖延症,做事雷厉风行夏季唯美连那英新发型惊艳众人,齐刘海的温柔小姑娘,越活越年轻若是说起来那英,大家首先想到的就是歌坛天后圈内大姐大等标签。那英的风格,相信大家在中国好声音这档节目中都已经感受到了。在娱乐圈发展这么多年,那英还能够保持自己的性格,堪称是独树一帜乘风破浪造型师审美开挂,阿娇美王心凌绝郭采洁终于不丑了乘风破浪成团夜,10位姐姐顺利成团,有一说一,除了死亡芭比粉的那一套造型,其他的都很绝!一起来看看吧。先看看网友吐槽像火龙果的死亡芭比粉,对比之下才知道其他的造型有多美。王心凌组的脸上痘坑痘印是怎么形成的?修复后能恢复成正常肌肤吗长痘是让很多青年男女特别烦恼的事,平时发炎很难看,遮又遮不住。更让人窒息的是,如果处理不好,还会留下难看的痘坑痘印,让人苦恼不已。不少人曾经采用了不少方法,偏方药膏等试了个遍,脸上
111光年之外,一颗年轻的恒星正在经历太阳充满暴力的过去头条创作挑战赛1。太阳已约有46亿岁,现今这颗步入中年的古老恒星已经变得安静沉浮。通过研究发现,被认为对地球造成巨大影响的超级要斑现象似乎几千年才会发生一次。2。但如果是年轻时的太润百颜成就智造行业解密爆品新公式如今,国产消费品的竞争十分激烈,消费者产品选择的眼花缭乱,特别是护肤品领域。多重挑战之下,功能性护肤赛道上,品牌只有拿出真本事,才能突出重围。而面对愈发激烈的市场竞争,如何让产品被高中物理选择性必修一麦克斯韦电磁场理论与电磁场电磁波高中物理选择性必修一麦克斯韦电磁场理论与电磁场电磁波1。麦克斯韦电磁场理论变化的磁场产生电场,变化的电场产生磁场2电磁场变化的电场和变化的磁场总是相互联系的,形成一个不可分割的统一令人心碎的文案1。江湖规矩就是人走茶凉,默契散场,不要问,问就是不懂规矩。2。今天过得不错吧?离梦想是不是又远了?3。没人在看海,大家都在看自己破旧不堪的遗憾。4。现实虽残酷,但命运掌握在自己手最新唯美语录,励志早安心灵鸡汤问候语,句句激励人心的早安句子一每一个人的成功之路或许都不尽相同,但我相信,成功都需要每一位想成功的人去努力去奋斗,而每一条成功之路,都是充满坎坷的,只有那些坚信自己目标,不断努力不断奋斗的人,才能取得最终的成绝了,不买C罗还嘲讽!马赛主席C罗破坏我们氛围,谣言让人心烦C罗在转会窗口最后时刻和法甲豪门马赛也产生了相当多的联系。当时法国足球多位球员还有娱乐圈明星都公开表示了对C罗的欢迎。他们希望这位足坛顶级流量能够加盟马赛效力。随后网络上更是出现了原定禁言15天,结果提前解禁,目前司马南在旅游,是真的吗?司马南账号解禁以后,网友们都发现了一个奇怪的现象,那就是他在第一天发布了几个过去的视频和一个微头条之后,最近连续四五天没有任何动静。很多网友都问司马南老师目前在国内吗?他自由吗?安让马云疑惑的是为何小商贩大多喜欢微信收款,而不是支付宝?2017年,我国的移动用户规模约为5。6亿人,比2016年的用户规模同比增长21。据不完全统计,截至2020年底,我国移动支付行业,共有1232。2亿笔交易,交易金额高达432。2性价比最高的的四款天玑8100手机,配置出色体验极佳,闭眼买就行天玑8100处理器绝对是今年最受欢迎的一款次旗舰处理器,不仅拥有出色的性能表现,还有相当不错的功耗控制,堪比去年的骁龙870处理器。如果你近期有换手机的打算,强烈建议考虑这四款天玑拼多多刺入SHEIN腹地出品虎嗅商业消费组作者周月明题图视觉中国听说已经有人在拼多多出海平台上出单了。华南区资深跨境电商从业者王向向告诉虎嗅,此前,他也曾收到过拼多多出海项目的邀约,但目前还在观望。最近,美国全世界吸血,人民币贬值,别担心,该轮到中国出招了今天说点真实的啊,人民币贬值了。没错啊,人民币连续四个月贬值了7。5,从年初汇率的6。3跌到了今天的6。9,不出意外可能要破7了。当然了,大家不必过于担心,这事儿还算正常,原因自然