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

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();     } }

一直吃大豆,身体会发生什么变化?随着健康理念的深入,如今越来越多人开始重视饮食上的搭配和营养上的均衡,除了受人喜欢的肉类,各种富含植物营养与纤维的食物也被许多人纳入到饮食清单中,以避免摄入空缺的情况发生。除了藜麦因为灵动岛和条友发生的讨论此文献给喔嚯哈嘿哟灵动岛是苹果首创吗?很遗憾,不是。2018年荣耀V20就有灵动胶囊。但是iphone用户会因为灵动岛买iphone吗?这可不一定!iphone用户看中的是ios系今天印度打破一项亚洲纪录!我们从未输得如此开心文章作者北风雪林今天印度破了一项亚洲纪录!或者用更牛逼的说法,印度今天开创了一个从未有过的亚洲历史。既然亚洲从未有过,那就表示我们中国没做到过,所以一般情况下,这样的新闻我会心塞一著名演员于和伟我这辈子最正确的决定,就是娶了一个平凡的妻子不久前,于和伟作为嘉宾出现在开播的综艺节目我的青铜时代第二季,引发了一众热议。综艺节目我的青铜时代我的青铜时代是一档纪实访谈形式的综艺节目,第一季首播后即斩获多个奖项,豆瓣分高达9著名歌唱家李丹阳如今57岁仍单身,将一辈子奉献给舞台事业文Di编辑小情书她是个热情的川妹子,温柔大方歌声嘹亮她曾是个羞涩的小女孩却敢在万人剧场演唱她是朋友心中的仗义人,却让淡定的韦唯闹心在李丹阳自传书里,好友在简介里写下了这段对她的评价林民旺印度加入全球芯片制造竞赛来源环球时报近日,富士康公司印度企业瓦达塔(Vedanta)集团及印度古吉拉特邦政府签署三方联合协议,将共同投资195亿美元在古吉拉特邦建立半导体芯片制造厂。该企业将占地1000英11种著名商业分析模型战略决定布局,布局决定终局编者按有很多企业做到了近百亿的规模,但依然处于机会成长阶段,其原因为企业的战略选择决策制定和执行缺乏底层逻辑和数据支撑,也缺乏科学的流程和方法论。盲目的机会主义和短视现象,会导致决它是浙江著名的水乡集镇之一,距今2000多年历史,夜景似仙境这可能是我见过的最具有仙境的古镇夜色了。华灯初上,河道水雾缭绕,再以灯光秀的完美搭配,令人恍惚是在天上宫阙。这个地方便是柯桥古镇。据了解,柯桥古镇是绍兴市柯桥区的第一大镇,也是浙江比三峡电站还大,墨脱水电站我国上游建坝,为何遭到印度反对?西藏被誉为亚洲水塔,其含义有两层,一是地势高,位于我国的第一级阶梯上,平均海拔4000米以上,二是水资源丰富,储量占全国的14。5。两个条件结合则意味着丰富的水能资源,开发水电的优面对国外质疑,他用实力狠狠打了他们的脸第一个打破欧洲垄断,站在世界排名榜上的民族英雄陈镜开。苏炳添,我想大家对这个名字应该再熟悉不过了。在2021年的东京奥运会男子100米半决赛中,作为广东选手的他以9。83秒的成绩成为何说甘地死后,印度彻底被分裂了,永远无法复合1948年1月30日,甘地遭到印度教顽固教徒刺杀身亡。很多人对甘地的认识,就是知道他是印度的圣雄,是非暴力不合作的提倡者,仅此而已。事实上,甘地对印度的影响超出我们的想象。而且甘地
下周预判出炉,是涨是跌,我给大家一个明确的观点本周的剧本全对!上周末明确地说,本周走势冲高回落,周线收阳,最终市场按照我的预判落实到位。每次预判都是提前告诉大家,接受大家和市场的检验。我的预判不仅有大盘走势,还有板块方向更是不携程集团创新酒管SBU孙刚未来酒店行业更需要回归初心练好内功21世纪经济报道记者唐唯珂上海报道12月13日,由南方财经全媒体集团指导,21世纪经济报道主办的21世纪住宿业高峰论坛(2022)暨2022(第十九届)金枕头酒店大赏发布典礼在上海隐藏了手机APP,再也不怕女友查手机,效果惊艳女朋友总是喜欢查手机该怎么办,很多粉丝朋友给小君私信,自从有了女朋友之后都或多的有着这样的烦恼,女孩子一旦陷入爱情,就特别容易缺乏安全感。很多女孩子喜欢有意无意的看自己男朋友的手机3D暴龙模型塞进侏罗纪公园只需一部手机,拍摄角度360可选萧箫发自凹非寺量子位公众号QbitAI拍照想拍出大片效果,布置场景有多麻烦?例如光是一辆车一个人同时出现在一个草坪上的场景,就得同时找齐全这三样要素,在现场拍完后还得花费不少时间修北海市郑琦案一批包括茅台在内高端酒被拍卖,才10块钱起近日,在阿里法拍网上,北海市上新了一批高端白酒洋酒拍卖,起拍价是相当便宜,只要10块钱起。这些九的品牌有贵州茅台镇五十年珍藏酒陈自香浓香型白酒贵州茅台集团十六年(富贵)浓香型白酒一淮扬菜江苏省东临大海,西拥洪泽,南临太湖,长江横贯于中部,运河纵流于南北,境内有蛛网般的港湾,串珠似的湖泊,加以寒暖适宜,素有鱼米之乡之称。春有刀鲚夏有鲥,秋有肥鸭冬有蔬,一年四季,水产谁说早餐麻烦!这6道零难度快手又营养,天冷懒人必备没了烟火气,人生就是一段孤独的旅程。谁说早餐麻烦!这6道零难度快手又营养,天冷懒人必备,快快收藏吧!葱花饼学会这个家常葱花饼做法,早餐再也不用匆匆忙忙了!无需揉面,搅一搅就能做,睡大雪节气,进补正当时,这10道菜,驱寒又暖身,快为家人做起来大家好,欢迎大家来到我的美食自媒体,我是美食领域创作者锦绣V山东专注美食,让生活更有味。今天为大家带来了几道家常美食的做法,这几道美食也是深受大家的喜欢,而且是很常见的几道美食。天面粉里加5个鸡蛋,筷子一搅,这样做太香了,出锅全家人抢着吃国以民为本,民以食为天,各位老饕大家好!面食是中国人的主食之一,面食的种类繁多,十分美味,它不仅包括面条馒头之类的,还包括糕点类的食物。今天,我要教大家用面粉和鸡蛋,在家做美味的鸡想吃素包子的看过来,茄子青椒馅,馅料鲜美,面皮蓬松柔软,好吃大家好,我是舒晨,每天在这里分享各种家常美食,今天给大家分享美味的茄子馅包子。包子是很受欢迎的主食,是发面的,蓬松柔软,今天准备的是茄子和青椒制作的素馅,馅料鲜美,比肉馅还要好吃。冬天,韭菜和它是绝配,简单炒一盘,好吃不贵,解馋又开胃头条创作挑战赛进入十二月之后,国家放宽了防疫政策,对于很多地方都不需要健康码了,我们的生活越来越自由,但是为了家里人的健康,还是要注意安全防护和个人卫生。由于天气的转变,加上一些特