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监控分布式实现过程解析
# 给大家
# 小编
# 连接池
# 放在
# 在此
# 不需要
# 找不到
# 数据结构
# 很重要
# 充分利用
# 我上
# 学过
# 而生
# 所述
# 编辑器
# 给我留言
# 开源
# 感谢大家
# 就可以
# 为空
相关文章:
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
教程网站设计制作软件,怎么创建自己的一个网站?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
如何在阿里云ECS服务器部署织梦CMS网站?
官网网站制作腾讯审核要多久,联想路由器newifi官网
微信小程序 input输入框控件详解及实例(多种示例)
免费公司网站制作软件,如何申请免费主页空间做自己的网站?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
高端智能建站公司优选:品牌定制与SEO优化一站式服务
高端建站如何打造兼具美学与转化的品牌官网?
用v-html解决Vue.js渲染中html标签不被解析的问题
小程序网站制作需要准备什么资料,如何制作小程序?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
制作网站的模板软件,网站怎么建设?
如何快速查询网址的建站时间与历史轨迹?
临沂网站制作企业,临沂第三中学官方网站?
如何通过主机屋免费建站教程十分钟搭建网站?
建站之星如何实现五合一智能建站与营销推广?
建站主机SSH密钥生成步骤及常见问题解答?
如何选择CMS系统实现快速建站与SEO优化?
5种Android数据存储方式汇总
如何在宝塔面板中修改默认建站目录?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
建站之星导航菜单设置与功能模块配置全攻略
企业网站制作公司网页,推荐几家专业的天津网站制作公司?
如何通过VPS搭建网站快速盈利?
如何在云主机上快速搭建网站?
ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?
如何快速搭建支持数据库操作的智能建站平台?
如何彻底删除建站之星生成的Banner?
建设网站制作价格,怎样建立自己的公司网站?
开封网站制作公司,网络用语开封是什么意思?
重庆市网站制作公司,重庆招聘网站哪个好?
制作网站怎么制作,*游戏网站怎么搭建?
活动邀请函制作网站有哪些,活动邀请函文案?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
建站之星如何保障用户数据免受黑客入侵?
建站主机类型有哪些?如何正确选型
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何通过可视化优化提升建站效果?
网站制作模板下载什么软件,ppt模板免费下载网站?
购物网站制作公司有哪些,哪个购物网站比较好?
建站之星安装失败:服务器环境不兼容?
实例解析Array和String方法
香港网站服务器数量如何影响SEO优化效果?
网站制作员失业,怎样查看自己网站的注册者?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
*请认真填写需求信息,我们会在24小时内与您取得联系。