ドルイド接続プール
簡単な紹介
アリババは、オープンソースの接続プールによってドルイド最も顕著なデータベース接続プールの全体的な強さですが、また、SQL実装を分析するためにログ機能の監視を提供します。
ドルイド接続プールの紹介
pom.xmlを追加します
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.21</version>
</dependency>
application.propertiesを追加します
# druid
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
# 连接池初始化大小,最小,最大
spring.datasource.initialSize=10
spring.datasource.minIdle=10
spring.datasource.maxActive=30
# 连接等待超时时间
spring.datasource.maxWait=60000
# 多久检测需要关闭的空闲连接
spring.datasource.timeBetweenEvictionRunsMillis=60000
# 一个连接在池中最小生存的时间
spring.datasource.minEvictableIdleTimeMillis=300000
# 校验SQL,Oracle配置 spring.datasource.validationQuery=SELECT 1 FROM DUAL,如果不配validationQuery项,则下面三项配置无用
spring.datasource.validationQuery=SELECT 'x'
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
# 合并多个DruidDataSource的监控数据
spring.datasource.useGlobalDataSourceStat=true
注:あなたは、MySQL、MyBatisのを設定している前に、何の繰り返しはありません書きました
コードの戦闘
内蔵のモニタを設定するにはDruidFilter.javaを追加しました
DruidFilter.java
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;
@Configuration
public class DruidFilter {
@Bean
public ServletRegistrationBean druidStatView() {
//指定路径进入内置监控页面
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*");
//IP白名单:
servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
//IP黑名单
servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
//登录查看信息的账号密码.
//servletRegistrationBean.addInitParameter("loginUsername", "admin");
//servletRegistrationBean.addInitParameter("loginPassword", "123456");
//是否能够重置数据.
servletRegistrationBean.addInitParameter("resetEnable", "true");
return servletRegistrationBean;
}
@Bean
public FilterRegistrationBean druidWebStatFilter() {
FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
//添加过滤规则.
filterRegistrationBean.addUrlPatterns("/*");
//添加不需要忽略的格式信息.
filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
return filterRegistrationBean;
}
}
注:私はすでに春のセキュリティを構成していた、あなたは、同じコンフィギュレーション・ドルイドアカウントのパスワード場合は、モニターのページや他のチュートリアルの内蔵に飛び込むドルイドを入力することはできませんアカウントのパスワードをリードする、私は避けるために多くの方法がある知っているが、春のセキュリティ権限がアカウントを持っているので、なぜ追加のドルイドは、個々のアカウントへのアクセス許可のセットを追加する必要があるとし、裁判官バイパスにコードを追加する必要が、/druid/*
春のセキュリティでパス構成、パブリックには、より良いもののアカウントの権限を持っていません。だから私は、別々に設定されていません。
そして、これは、詳細な構成についての詳細を学ぶために必要がある必要性だけの一般的な構成であります
内蔵のコンフィギュレーションの詳細ページモニタリング、ウェブ関連する構成の詳細を
図の効果として、
祝福は、また、広告のアリ雲が付属して、それは本当にアリオープンソース製品であります