全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Spring Boot使用Druid进行维度的统计和监控

Druid

Druid:一款为监控而生的数据库连接池框架,整个项目由数据库连接池、插件框架和SQL解析器组成。

Druid功能介于PowerDrill和Dremel之间,它几乎实现了Dremel的所有功能,并且从PowerDrill吸收一些有趣的数据格式。Druid允许以类似Dremel和PowerDrill的方式进行单表查询,同时还增加了一些新特性,如为局部嵌套数据结构提供列式存储格式、为快速过滤做索引、实时摄取和查询、高容错的分布式体系架构等。

Spring Boot

spring框架作为JavaEE框架领域的一款重要的开源框架,在企业应用开发中有着很重要的作用,同时Spring框架及其子框架很多,所以知识量很广。

Spring Boot:一款Spring框架的子框架,也可以叫微框架,是2014年推出的一款使Spring框架开发变得容易的框架。学过Spring框架的都知识,Spring框架难以避免地需要配置不少XMl,而使用Spring Boot框架的话,就可以使用注解开发,极大地简化基于Spring框架的开发。

Spring Boot充分利用了JavaConfig的配置模式以及“约定优于配置”的理念,能够极大的简化基于Spring MVC的Web应用和REST服务开发。

然后通过本文给大家介绍基于IDEA编辑器的Spring Boot项目创建和部署。

Spring Boot使用Druid监控

maven配置

要配置spring Boot实现一个Demo的话,只要加入spring-boot-starter(核心模块)和spring-boot-starter-web(因为这个一个Web项目),可以参考我的配置,这里使用了Spring Boot热部署,需要去github上搜索jar:springloaded-1.2.4.RELEASE.jar,然后下载放在项目的lib文件夹里,可以参考我的配置

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
 <modelVersion>4.0.0</modelVersion>
 <groupId>com.example</groupId>
 <artifactId>demo</artifactId>
 <packaging>war</packaging>
 <version>1.0-SNAPSHOT</version>
 <name>demo Maven Webapp</name>
 <properties>
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  <java.version>1.8</java.version>
  <druid.version>1.0.24</druid.version>
  <mysql.version>5.1.27</mysql.version>
  <spring-boot-admin.version>1.4.5</spring-boot-admin.version>
 </properties>
 <parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-parent</artifactId>
  <version>1.5.1.RELEASE</version>
  <relativePath/>
 </parent>
 <dependencies>
  <dependency>
   <groupId>junit</groupId>
   <artifactId>junit</artifactId>
   <version>3.8.1</version>
   <scope>test</scope>
  </dependency>
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
  </dependency>
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-actuator</artifactId>
  </dependency>
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
  </dependency>
  <dependency>
   <groupId>de.codecentric</groupId>
   <artifactId>spring-boot-admin-starter-client</artifactId>
   <version>${spring-boot-admin.version}</version>
  </dependency>
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter</artifactId>
  </dependency>
  <dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>druid</artifactId>
   <version>${druid.version}</version>
  </dependency>
  <dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
   <version>${mysql.version}</version>
  </dependency>
 </dependencies>
 <build>
  <plugins>
   <plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
   </plugin>
   <plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin </artifactId>
    <dependencies>
     <!--springloaded hot deploy -->
     <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>springloaded</artifactId>
      <systemPath>${basedir}/src/main/webapp/WEB-INF/lib/springloaded-1.2.5.RELEASE.jar</systemPath>
     </dependency>
    </dependencies>
    <executions>
     <execution>
      <goals>
       <goal>repackage</goal>
      </goals>
      <configuration>
       <classifier>exec</classifier>
      </configuration>
     </execution>
    </executions>
   </plugin>
  </plugins>
 </build>
</project>

application.properties配置

server.context-path=/springbootdemo
#数据库访问配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/myblog
spring.datasource.username=root
spring.datasource.password=root
#数据源配置,初始化大小、最小、最大
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxActive=20
#连接等待超时时间
spring.datasource.maxWait=60000
#配置隔多久进行一次检测(检测可以关闭的空闲连接)
spring.datasource.timeBetweenEvictionRunsMillis=60000
#配置连接在池中的最小生存时间
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=SELECT 1 FROM DUAL
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
# 打开PSCache,并且指定每个连接上PSCache的大小
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
spring.datasource.filters=stat,wall,log4j
# 通过connectProperties属性来打开mergeSql功能;慢SQL记录
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

方式一原生的servlet和filter方式

编写Servlet类:

package com.example.web.servlet;
import com.alibaba.druid.support.http.StatViewServlet;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
/**
 * Created by Administrator on 2017/4/28.
 */
@WebServlet(urlPatterns = "/druid/*",
    initParams = {
        @WebInitParam(name = "allow", value = "192.168.10.25,127.0.0.1"),// IP白名单 (没有配置或者为空,则允许所有访问)
        @WebInitParam(name = "deny", value = "192.168.1.73"),// IP黑名单 (存在共同时,deny优先于allow)
        @WebInitParam(name = "loginUsername", value = "admin"),// 用户名
        @WebInitParam(name = "loginPassword", value = "123"),// 密码
        @WebInitParam(name = "resetEnable", value = "false")// 禁用HTML页面上的“Reset All”功能)
    }
)
public class DruidStatViewServlet extends StatViewServlet{
}

Filter类:

package com.example.web.filter;
import com.alibaba.druid.support.http.WebStatFilter;
import javax.servlet.annotation.WebFilter;
import javax.servlet.annotation.WebInitParam;
/**
 * Created by Administrator on 2017/4/28.
 */
@WebFilter(filterName="druidWebStatFilter",urlPatterns="/*",
    initParams={
        @WebInitParam(name="exclusions",value="*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*")// 忽略资源
    }
)
public class DruidWebStatFilter extends WebStatFilter{
}

然后,需要在Spring Boot启动类里设置Servlet自动扫描,不然会出现404页面找不到错误,使用

@ServletComponentScan注解

package com;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.context.embedded.ConfigurableEmbeddedServletContainer;
import org.springframework.boot.context.embedded.EmbeddedServletContainerCustomizer;
import org.springframework.boot.web.servlet.ServletComponentScan;
import org.springframework.boot.web.support.SpringBootServletInitializer;
import org.springframework.scheduling.annotation.EnableAsync;
@SpringBootApplication
@ServletComponentScan
@EnableAsync
public class Application implements EmbeddedServletContainerCustomizer {
  public static void main(String[] args) {
    SpringApplication.run(Application.class, args);
  }
  @Override
  public void customize(ConfigurableEmbeddedServletContainer configurableEmbeddedServletContainer) {
    configurableEmbeddedServletContainer.setPort(8087);
  }
}

方式二使用代码注册Servlet和Filter

package com.example.config;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
 * Created by Administrator on 2017/4/28.
 */
@Configuration
public class DruidConfiguration {
  /**
   * 注册ServletRegistrationBean
   * @return
   */
  @Bean
  public ServletRegistrationBean registrationBean() {
    ServletRegistrationBean bean = new ServletRegistrationBean(new StatViewServlet(), "/druid1/*");
    /** 初始化参数配置,initParams**/
    //白名单
    bean.addInitParameter("allow", "127.0.0.1");
    //IP黑名单 (存在共同时,deny优先于allow) : 如果满足deny的话提示:Sorry, you are not permitted to view this page.
    bean.addInitParameter("deny", "192.168.1.73");
    //登录查看信息的账号密码.
    bean.addInitParameter("loginUsername", "admin2");
    bean.addInitParameter("loginPassword", "123");
    //是否能够重置数据.
    bean.addInitParameter("resetEnable", "false");
    return bean;
  }
  /**
   * 注册FilterRegistrationBean
   * @return
   */
  @Bean
  public FilterRegistrationBean druidStatFilter() {
    FilterRegistrationBean bean = new FilterRegistrationBean(new WebStatFilter());
    //添加过滤规则.
    bean.addUrlPatterns("/*");
    //添加不需要忽略的格式信息.
    bean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid2/*");
    return bean;
  }
}

项目监控

然后输入url访问,我的项目访问路径:http://localhost:8087/springbootdemo/druid/login.html,这个需要自己修改,我的Context配置为springbootdemo,端口配置为8087,这些可以参考我上一篇博客

通过平台进行监控 

以上所述是小编给大家介绍的Spring Boot使用Druid进行维度的统计和监控,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# spring  # boot  # druid  # springboot  # druid监控  # SpringBoot配置Druid数据监控代码实例  # 使用SpringBoot简单了解Druid的监控系统的配置方法  # spring boot基于DRUID实现数据源监控过程解析  # eBay 打造基于 Apache Druid 的大数据实时监控系统  # SpringBoot集成阿里巴巴Druid监控的示例代码  # Druid基本配置及内置监控使用_动力节点Java学院整理  # Spring Boot使用Druid和监控配置方法  # Druid监控分布式实现过程解析  # 给大家  # 小编  # 连接池  # 放在  # 在此  # 不需要  # 找不到  # 数据结构  # 很重要  # 充分利用  # 我上  # 学过  # 而生  # 所述  # 编辑器  # 给我留言  # 开源  # 感谢大家  # 就可以  # 为空 


相关文章: 如何规划企业建站流程的关键步骤?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  建站之星如何助力网站排名飙升?揭秘高效技巧  公司网站制作价格怎么算,公司办个官网需要多少钱?  代购小票制作网站有哪些,购物小票的简要说明?  Android使用GridView实现日历的简单功能  如何通过cPanel快速搭建网站?  如何使用Golang table-driven基准测试_多组数据测量函数效率  视频网站app制作软件,有什么好的视频聊天网站或者软件?  简单实现Android验证码  个人网站制作流程图片大全,个人网站如何注销?  已有域名如何免费搭建网站?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  javascript基本数据类型及类型检测常用方法小结  ,想在网上投简历,哪几个网站比较好?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何快速搭建高效可靠的建站解决方案?  广东企业建站网站优化与SEO营销核心策略指南  岳西云建站教程与模板下载_一站式快速建站系统操作指南  建站之星如何优化SEO以实现高效排名?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  如何选择网络建站服务器?高效建站必看指南  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  ,怎么在广州志愿者网站注册?  建站主机选购指南:核心配置与性价比推荐解析  Swift中循环语句中的转移语句 break 和 continue  建站之星与建站宝盒如何选择最佳方案?  建站主机解析:虚拟主机配置与服务器选择指南  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  制作网站的软件免费下载,免费制作app哪个平台好?  建站之星导航菜单设置与功能模块配置全攻略  高性能网站服务器配置指南:安全稳定与高效建站核心方案  如何在Windows环境下新建FTP站点并设置权限?  在线教育网站制作平台,山西立德教育官网?  建站之星体验版:智能建站系统+响应式设计,多端适配快速建站  如何快速启动建站代理加盟业务?  网站网页制作专业公司,怎样制作自己的网页?  ,网页ppt怎么弄成自己的ppt?  ,柠檬视频怎样兑换vip?  python的本地网站制作,如何创建本地站点?  如何登录建站主机?访问步骤全解析  建站之星如何开启自定义404页面避免用户流失?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  临沂网站制作企业,临沂第三中学官方网站?  网站制作多少钱一个,建一个论坛网站大约需要多少钱? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。