「イン深練習春ブーツ」第4章データベース・アクセスのパフォーマンスを改善

第4章改善データベース・アクセスのパフォーマンス

最終的にはデータベースのリレーショナル・データベース、アプリケーションシステムのパフォーマンスのボトルネックを使用してください。ビジネスの急速な成長によって、データの量が徐々に増加し、リレーショナル・データベース、すなわち、深刻なパフォーマンスの低下の弱点を公開していきます。喫緊の課題は、開発者のアクセスリレーショナルデータベースのパフォーマンスを向上させることです。データベースのアクセシビリティを向上させる開発の観点から以下の手順は、提示及び説明されます。

表4-1に示すように、モジュール設計のこの実施形態のためのサブプロジェクトの使用の例として、各モジュールの機能。

プロジェクト エンジニアリング タイプ 機能
拡張機能モジュール dpexpan プロセス統合 JPA拡張機能やRedisの設定など
データ管理モジュール mysqlの プロセス統合 MySQLのソリッドモデリングと持続性、など
Webアプリケーションモジュール ウェブサイト Webアプリケーション Webアプリケーションの例

4.1使用ドルイド

ドルイドは、アリババのオープンソースプロジェクトであり、リレーショナルデータベース接続プールです。ドルイドはそうでOracle、MySQLの、ダービー、PostgreSQLのは、SQL Server、H2とを含む、すべてのJDBC準拠のデータベースをサポートしています。ドルイドは、監視、スケーラビリティ、安定性とパフォーマンスに明らかな利点があります。ドルイド、リアルタイムデータベース接続プールによって提供される機能を監視し、SQLクエリの作業を観察します。ドルイド接続プールを使用して、ある程度、データベース・アクセスのパフォーマンスを向上させることができます。

4.1.1設定ドルイド依存性

https://mvnrepository.com/適切なバージョンを見つけるために、依存設定ドルイドを見つけ、その後、プロジェクトの拡張モジュールのMavenの構成例にコピーしてdpexpan。図4-1は、私たちが1.0.18のバージョンを使用して、見つかった結果を示しています。図4-1ホームページはドルイドソースリンクアドレスです。

XML設定について4.1.2

スプリング開発フレームワークを使用する場合、XMLコンフィギュレーションは、データ・ソースは、XML構成を使用して構成されている、請求しばしば使用される構成です。リスト4-1に、使用するXMLドルイド接続プールの構成です。XML構成を使用してスプリングブートフレームワークを使用することもできる、限り例えば@ImportResourceとして注釈、({「クラスパス:バネdatasource.xmlを」})を使用して、プログラムのエントリとして、XMLコンフィギュレーションに導入することができます。しかし、春ブーツは、そのような使用をお勧めしますが、application.propertiesを設定したりしてapplication.ymlするために、設定ファイルに集中していません。

4.1.3ドルイドデータソースの構成

データ・ソースのばねブートデフォルトタイプがorg.apache.tomcat.jdbc.pool.DataSource配置され、接続プールドルイドを使用するために、データ・ソースがリスト4-として、com.alibaba.druid.pool.DruidDataSourceの種類を変更することができ図2は、図1に示します。これは、URL、ユーザ名、パスワードのMySQLサーバーの構成パラメータを接続することで、他のパラメータは、ドルイドの仕事を設定します。

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

上記構成のフィルタ:STATモニタは時間フィルタを定義する組合​​せで、フィルタを使用する準備ができて示すが、データベースの使用を監視するために使用することができます。

注意:低春ブートデータソース構成のバージョンでは、あなたは上記のこの設定を使用したい場合は、その後、それを達成するためのパラメータを設定するカスタムを使用する必要があり、機能のこのタイプを提供するために、データソースのないセットがありません。

4.1.4オープンモニタリング

オープンドルイド監視機能は、アプリケーションがデータベースのパフォーマンスへのアクセスを最適化するように設計されたプログラムを調整することができるデータベースの使用を分析する監視動作によって提供される、多次元データを、実行されて処理することができます。

リスト4-3は、つまり訪問者が、データベースにアクセスするために、白と黒のリストを設定し、監視サーバアクセス制御アドレスは「/ドルイド/ *」の背景を設定し、監視サーバおよびフィルタを定義しますIPは、データベースのセキュリティ設定を増やす、ソースへのアクセスを制御するために対処し、それはまた、背景を監視し、パスワードを設定するには、ログインするために使用ドルイドユーザーが装備されている123456です。

package com.test.dbexpand;

import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.springframework.boot.context.embedded.FilterRegistrationBean;
import org.springframework.boot.context.embedded.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class DruidConfiguration {
    @Bean
    public ServletRegistrationBean statViewServle() {
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*");
        //白名单:
        servletRegistrationBean.addInitParameter("allow", "192.168.1.218,127.0.0.1");
        //IP黑名单 (存在共同时,deny优先于allow) : 如果满足deny的即提示:Sorry, you are not permitted to view this page.
        servletRegistrationBean.addInitParameter("deny", "192.168.1.100");
        //登录查看信息的账号密码.
        servletRegistrationBean.addInitParameter("loginUsername", "druid");
        servletRegistrationBean.addInitParameter("loginPassword", "123456");
        //是否能够重置数据.
        servletRegistrationBean.addInitParameter("resetEnable", "false");
        return servletRegistrationBean;
    }

    @Bean
    public FilterRegistrationBean statFilter() {
        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
        //添加过滤规则.
        filterRegistrationBean.addUrlPatterns("/*");
        //添加不需要忽略的格式信息.
        filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
        return filterRegistrationBean;
    }
}

おすすめ

転載: www.cnblogs.com/shenhuanjie/p/11434309.html
おすすめ