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日

相关文章

  • SQL update select结合语句详解及应用

    “SQL update select结合语句详解及应用”是一种常用的SQL查询方式。它能够根据条件筛选出要更新的数据,然后更新到指定的列中。下面是详细的攻略: 1. 基本语法 SQL update select结合语句的基本语法如下: UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 其中,表名称是要更新的表的名称,列名称和新值是…

    database 2023年5月21日
    00
  • redis 参数详解

    #是否作为守护进程运行 yes 或者 no daemonize yes #监听IP,redis一般监听127.0.0.1 网段访问,集群模式需要指定IP地址。 bind 192.168.1.115 # 当 Redis 以守护进程的方式运行的时候,Redis 默认会把 pid 文件放在/var/run/redis.pid # 可配置到其他地址,当运行多个 re…

    Redis 2023年4月13日
    00
  • Linux下源码包安装Swoole及基本使用操作图文详解

    Linux下安装Swoole及基本使用操作 1. 安装Swoole源码包 1.1 下载Swoole源码包 在官网下载Swoole源码包,推荐下载最新版,下载链接为:https://github.com/swoole/swoole-src/releases 1.2 安装依赖库 Swoole编译需要openssl、pcre、zlib、libaio等依赖库,使用以…

    database 2023年5月22日
    00
  • php将数据库中所有内容生成静态html文档的代码

    生成静态 HTML 文档是提高网站性能的一种有效方法。PHP 通过操作数据库生成并存储静态 HTML 文档,可以显著减轻服务器的负载,同时提高页面响应速度。下面是生成静态 HTML 文档的完整攻略。 步骤一:连接数据库 在 PHP 中可以使用 mysqli 或者 PDO 等扩展库来连接数据库。本示例中我们使用 mysqli 来连接数据库,并将连接信息存储在 …

    database 2023年5月19日
    00
  • Linux下安装PHP MSSQL扩展教程

    下面是“Linux下安装PHP MSSQL扩展教程”的完整攻略。 准备工作 在安装 MSSQL 扩展之前必须先安装好其所依赖的环境。 安装FreeTDS FreeTDS是一个能够让 Linux 或类 Unix 系统作为客户端连接到远程的 MSSQL 或 Sybase 服务器的桥梁。 下载源码包: wget ftp://ftp.freetds.org/pub/…

    database 2023年5月22日
    00
  • MybatisPlusException:Failed to process,Error SQL异常报错的解决办法

    针对”MybatisPlusException: Failed to process, Error SQL异常报错”这种情况,可以采取以下步骤进行解决: 1.查看错误日志及异常信息 MybatisPlusException通常是由于SQL异常导致的,我们可以首先查看错误日志,了解具体的异常信息,判断问题出在哪里。常见的异常信息包括SQL语句错误、数据库表结构…

    database 2023年5月18日
    00
  • SQL 从一个表检索与另一个表不相关的行

    要从一个表检索与另一个表不相关的行,在SQL中可以使用外部连接(outer join)。以下是使用外部连接的两个实例: 示例一 我们有两个表:学生表和班级表。学生表包含学生的姓名、年龄和所在班级的ID。而班级表包含班级的ID和班级的名称。我们想要检索出所有没有分配到班级的学生。 首先,我们可以使用左外部连接(left outer join)将学生表和班级表连…

    database 2023年3月27日
    00
  • MySQL系列数据库设计三范式教程示例

    MySQL系列数据库设计三范式教程示例的完整攻略: 前言 本教程是一篇介绍MySQL系列数据库中的三范式设计的教程示例,通过本教程的学习,可以极大地提高我们设计数据库的能力和质量,同时在实际应用中也能提高数据库的性能。 一、什么是三范式? 三范式是指在设计关系型数据库时,需要满足的三个条件,它们分别是: 第一范式(1NF):关系表中的每个属性都是原子性的,即…

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