Druid基本配置及内置监控使用_动力节点Java学院整理

Druid基本配置及内置监控使用攻略

Druid是一个为数据库设计的连接池、SQL执行监控、分析工具。它使用Java的proxy技术来实现在JDBC层的透明处理和统计数据的展现。在使用前,需要进行一些基本配置。

基本配置

  1. 在项目的pom.xml中,引入Druid的依赖:
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.10</version>
</dependency>
  1. 在Spring配置文件中,定义Druid的数据源:
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
    <property name="url" value="${jdbc.url}" />
    <property name="username" value="${jdbc.username}" />
    <property name="password" value="${jdbc.password}" />
    <property name="initialSize" value="5" />
    <property name="maxActive" value="50" />
    <property name="minIdle" value="5" />
    <property name="maxWait" value="60000" />
    <property name="timeBetweenEvictionRunsMillis" value="60000" />
    <property name="minEvictableIdleTimeMillis" value="300000" />
    <property name="validationQuery" value="select 'x'" />
    <property name="testWhileIdle" value="true" />
    <property name="testOnBorrow" value="false" />
    <property name="testOnReturn" value="false" />
    <property name="poolPreparedStatements" value="true" />
    <property name="maxPoolPreparedStatementPerConnectionSize" value="20" />
    <property name="filters" value="stat,wall,log4j" />
    <property name="proxyFilters">
        <list>
            <bean class="com.alibaba.druid.filter.stat.StatFilter" init-method="init" destroy-method="close">
                <property name="logSlowSql" value="true" />
                <property name="slowSqlMillis" value="2000" />
            </bean>
        </list>
    </property>
</bean>
  1. 在web.xml中,配置DruidServlet和DruidFilter:
<servlet>
    <servlet-name>DruidServlet</servlet-name>
    <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>
    <init-param>
        <param-name>resetEnable</param-name>
        <param-value>false</param-value>
    </init-param>
    <init-param>
        <param-name>loginUsername</param-name>
        <param-value>admin</param-value>
    </init-param>
    <init-param>
        <param-name>loginPassword</param-name>
        <param-value>admin</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>DruidServlet</servlet-name>
    <url-pattern>/druid/*</url-pattern>
</servlet-mapping>

<filter>
    <filter-name>DruidFilter</filter-name>
    <filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class>
    <init-param>
        <param-name>exclusions</param-name>
        <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*</param-value>
    </init-param>
</filter>

<filter-mapping>
    <filter-name>DruidFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

内置监控使用

Druid提供内置的监控功能,我们只需要配置好Druid,并访问以下地址即可:

http://localhost:8080/druid/index.html

在页面上,我们可以查看连接池的情况、SQL执行情况等信息。

示例说明1

在Druid的配置文件中,我们配置了maxActive为50,表示该连接池最大同时连接数为50。我们可以在内置监控页面上,查看当前连接池的情况。当连接池中连接数过多时,需要调整maxActive的值。

示例说明2

Druid的内置监控还可以查看SQL的执行情况。在Druid的配置文件中,我们配置了logSlowSql为true,表示打印执行时间大于2秒的SQL。我们可以在内置监控页面的Sql监控 tab 页上,查看SQL的执行情况。当SQL执行时间过长时,需要对SQL进行优化。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Druid基本配置及内置监控使用_动力节点Java学院整理 - Python技术站

(0)
上一篇 2023年5月21日
下一篇 2023年5月21日

相关文章

  • 使用BAT批处理执行sql语句的代码

    使用BAT批处理执行SQL语句的过程可以分为以下几个步骤: 安装MySQL命令行工具批处理文件需要用到MySQL命令行工具,所以需要先安装MySQL数据库并配置好环境变量。 编写SQL语句在执行SQL语句之前,需要先编写好需要执行的SQL语句,并将其保存到文本文件中。 编写批处理脚本使用文本编辑器编写批处理脚本文件,例如“run_sql.bat”,可以参考以…

    database 2023年5月21日
    00
  • node使用mysql获取数据库数据中文乱码问题的解决

    下面是详细讲解“node使用mysql获取数据库数据中文乱码问题的解决”的完整攻略: 问题描述 在 node.js 应用中,获取 Mysql 数据库中的中文数据时,可能会出现乱码问题。 原因分析 Mysql 使用的是 Latin1 编码,而 node.js 默认使用的是 UTF-8 编码。当我们从 Mysql 中读取 Latin1 编码的数据时,node.j…

    database 2023年5月22日
    00
  • MySQL 5.7常见数据类型

    MySQL 5.7支持多种不同的数据类型,包括数值、日期/时间、字符串、JSON等类型。在本文中,我们将详细讲解MySQL 5.7常见的数据类型,包括每种类型的特点、用法以及示例说明。 数值类型 MySQL 5.7支持多个数值类型,包括整型、浮点型、定点型等。 整型 我们常用的整型有TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT。…

    database 2023年5月22日
    00
  • MySQL性能优化 出题业务SQL优化

    MySQL性能优化 出题业务SQL优化是一项非常重要的工作,能够有效提高网站的响应速度和用户体验,下面是一些具体步骤供参考: 第一步:确定问题 在进行任何优化之前,你首先需要确定问题所在。一些常见的MySQL性能问题包括响应时间过长、内存使用过高、查询慢等。你可以通过各种工具来分析MySQL运行状态,如SHOW STATUS、EXPLAIN等。 第二步:优化…

    database 2023年5月19日
    00
  • Oracle中SQL语句连接字符串的符号使用介绍

    当在Oracle中使用SQL语句拼接字符串时,可以使用“||”符号,也可以使用“CONCAT”函数。 使用“||”符号进行字符串拼接: 在Oracle中,使用“||”符号进行字符串拼接是非常常用的一种方式,语法如下: SELECT column_name1 || string || column_name2 AS result FROM table_name…

    database 2023年5月21日
    00
  • MySQL Database on Azure新功能

    本月中国版的MySQL Database on Azure发布了两项新功能: 1、主从复制——只读实例 在这之前Azure上的MySQL数据库也是支持主从复制的,但是只能作为on-premises部署的MySQL的slave实例——Azure上的MySQL数据库是不可以作为master来使用的。 经过本次更新,我们可以给Azure上的MySQL数据库创建一个…

    MySQL 2023年4月12日
    00
  • Spring Boot无缝集成MongoDB

    一、什么是Spring Boot和MongoDB? Spring Boot是一个基于Spring框架的快速开发极简化的框架,可以快速开发应用程序。 MongoDB是一个新型的文档型数据库,名字起源于humongous(巨大的)。MongoDB具有高性能、易于扩展、开源等特点,在大数据和云计算领域得到了广泛应用。 二、Spring Boot集成MongoDB的…

    database 2023年5月22日
    00
  • Linux高级篇学习手册(二)

    针对题目中提到的Linux高级篇学习手册(二),我将提供一个完整的学习攻略,帮助Linux爱好者更好地学习和掌握该书的内容。 一、准备工作 在开始之前,我们需要做以下准备工作。 1.1 确认学习环境 首先,需要确认自己的学习环境是否已经具备。比如,我们需要安装好Linux操作系统,对Linux基础知识已经有基本的了解。 1.2 确认学习时间 确定自己的学习时…

    database 2023年5月22日
    00
合作推广
合作推广
分享本页
返回顶部