Druid Monitor

Druid Monitor

对于数据源,相信大家已经接触了不少了。比如c3p0、dhcp、proxool等,之后又发现使用tomcat-jdbc可以大大的提高性能。但是针对于我们的高并发的系统来说,总希望能找到一个性能更好、更稳定的产品来代替。在开源中国上偶然发现了很多公司都在使用Druid这个数据源,然后搜索了一些相关资料,有人提供了这几个数据源的性能测试报告,突然发现这个数据源以很好的性能已经被大家普遍使用了。于是自己也把项目中的jdbc数据源替换为Druid了,然后让测试人员帮忙压了一下系统,发现性能有所提高。于是就想深入的研究一下这个数据源了。其实很多项目都是JavaSE的,但是官网针对于JavaSE的项目又没有具体说明应该怎么使用其监控统计功能。于是自己就看了一下源码发现了有配置jmxUrl的地方,可以想想这个应该就是针对于远程监控项目的配置了。在这里我就整理一下自己的使用情况供以后的人员参考,如果有错误的地方,也请大牛指证,我也多学习学习。

首先说明一下大家都知道的几个地址吧,也省的访客来回搜索了。

正式版本下载地址:http://repo1.maven.org/maven2/com/alibaba/druid/
Druid是一个开源项目,源码托管在github上:https://github.com/alibaba/druid
Druid 0.1.18之后版本都发布到maven中央仓库中,所以你只需要在项目的pom.xml中加上dependency就可以了。例如:

[html] view plain copy
  1. <dependency>  
  2.         <groupId>com.alibabagroupId>  
  3.         <artifactId>druidartifactId>  
  4.         <version>${druid-version}version>  
  5. dependency>span>  

也可以选择 Maven仓库查找公共的仓库地址: http://www.mvnrepository.com/artifact/com.alibaba/druid

好了,废话也说了一大堆了。接下来说明一下怎么查看DruidDataSource的监控数据。
对于web项目,使用起来很方便,只需要在web.xml中配置一下DruidStatView就行了。其它的Druid已经帮我们都实现了。


1.Druid Monitor监控Java Web项目

先说明一下数据源的配置情况吧,例:

[html] view plain copy
  1. xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:aop="http://www.springframework.org/schema/aop"  
  6.     xmlns:tx="http://www.springframework.org/schema/tx"  
  7.     xsi:schemaLocation="http://www.springframework.org/schema/beans  
  8.            http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
  9.            http://www.springframework.org/schema/aop   
  10.            http://www.springframework.org/schema/aop/spring-aop-3.0.xsd  
  11.            http://www.springframework.org/schema/tx  
  12.            http://www.springframework.org/schema/tx/spring-tx-3.0.xsd  
  13.            http://www.springframework.org/schema/context  
  14.            http://www.springframework.org/schema/context/spring-context-3.0.xsd">  
  15.       
  16.       
  17.     <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init"  
  18.         destroy-method="close">  
  19.            
  20.           
  21.         <property name="driverClassName" value="oracle.jdbc.OracleDriver" />  
  22.         <property name="url" value="jdbc:oracle:thin:@192.168.102.93:1521:mydb1" />  
  23.         <property name="username" value="my_v31" />  
  24.         <property name="password" value="my_v31" />  
  25.       
  26.           
  27.         <property name="initialSize" value="1" />  
  28.         <property name="minIdle" value="1" />  
  29.         <property name="maxActive" value="20" />  
  30.       
  31.           
  32.         <property name="maxWait" value="60000" />  
  33.       
  34.           
  35.         <property name="timeBetweenEvictionRunsMillis" value="60000" />  
  36.       
  37.           
  38.         <property name="minEvictableIdleTimeMillis" value="300000" />  
  39.           
  40.           
  41.         <property name="filters" value="stat,wall,log4j" />  
  42.           
  43.           
  44.           
  45.         <property name="proxyFilters">  
  46.             <list>  
  47.                 <ref bean="stat-filter" />  
  48.                 <ref bean="log-filter" />  
  49.             list>  
  50.         property>  
  51.     bean>  
  52.       
  53.       
  54.     <bean id="stat-filter" class="com.alibaba.druid.filter.stat.StatFilter">  
  55.         <property name="mergeSql" value="true" />  
  56.         <property name="slowSqlMillis" value="10000" />  
  57.         <property name="logSlowSql" value="true" />  
  58.     bean>  
  59.       
  60.     <bean id="log-filter" class="com.alibaba.druid.filter.logging.Log4jFilter">  
  61.           
  62.           
  63.     bean>  
  64.       
  65.       
  66.     <bean id="druid-stat-interceptor" class="com.alibaba.druid.support.spring.stat.DruidStatInterceptor" />  
  67.    
  68.     <bean id="druid-stat-pointcut" class="org.springframework.aop.support.JdkRegexpMethodPointcut" scope="prototype">  
  69.         <property name="patterns">  
  70.             <list>  
  71.                 <value>com.XXX.stat.service.*value>  
  72.                 <value>com.XXX.stat.dao.*value>  
  73.             list>  
  74.         property>  
  75.     bean>  
  76.       
  77.     <aop:config proxy-target-class="true">  
  78.         <aop:advisor advice-ref="druid-stat-interceptor" pointcut-ref="druid-stat-pointcut" />  
  79.     aop:config>  
  80. beans>  

尽管Druid已经说明只需要配置数据库中的url地址就可以帮我们自动来匹配driverClassName,但是发现如果不配置这个,日志中总是有一些警告,所以就配置了一下。官网提供了一下他自己的driverClassName有:

[plain] view plain copy
  1. jdbc:derby:=org.apache.derby.jdbc.EmbeddedDriver       
  2. jdbc:mysql:=com.mysql.jdbc.Driver  
  3. jdbc:log4jdbc:=net.sf.log4jdbc.DriverSpy  
  4. jdbc:oracle:=oracle.jdbc.driver.OracleDriver  
  5. jdbc:microsoft:=com.microsoft.jdbc.sqlserver.SQLServerDriver       
  6. jdbc:jtds:=net.sourceforge.jtds.jdbc.Driver    
  7. jdbc:postgresql:=org.postgresql.Driver     
  8. jdbc:fake:=com.alibaba.druid.mock.MockDriver       
  9. jdbc:hsqldb:=org.hsqldb.jdbcDriver     
  10. jdbc:db2:=COM.ibm.db2.jdbc.app.DB2Driver  
  11. jdbc:sqlite:=org.sqlite.JDBC       
  12. jdbc:ingres:=com.ingres.jdbc.IngresDriver      
  13. jdbc:h2:=org.h2.Driver     
  14. jdbc:mckoi:=com.mckoi.JDBCDriver  
接下来说一下web.xml中的配置参数都有什么,这里你也可以配置loginUserName和loginPassword,避免所有的人都可以看到你自己的数据库情况。这样子在你登录监控页面的时候就必须输入密码才可以访问了。当然也可以把你的IP加到allow之中,这样就只有你自己的机器可以访问这个监控界面了。例:
[html] view plain copy
  1. <filter>  
  2.         <filter-name>DruidWebStatFilterfilter-name>  
  3.         <filter-class>com.alibaba.druid.support.http.WebStatFilterfilter-class>  
  4.         <init-param>  
  5.               
  6.             <param-name>exclusionsparam-name>  
  7.             <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*param-value>  
  8.         init-param>  
  9.           
  10.         <init-param>  
  11.             <param-name>sessionStatMaxCountparam-name>  
  12.             <param-value>1000param-value>  
  13.         init-param>  
  14.           
  15.         <init-param>  
  16.             <param-name>profileEnableparam-name>  
  17.             <param-value>trueparam-value>  
  18.         init-param>  
  19.         <init-param>  
  20.             <param-name>principalSessionNameparam-name>  
  21.             <param-value>users.usernameparam-value>  
  22.         init-param>  
  23.           
  24.        <span style="white-space:pre"> span><init-param>  
  25.             <span style="white-space:pre">    span><param-name>resetEnableparam-name>  
  26.             <span style="white-space:pre">    span><param-value>falseparam-value>  
  27.         <span style="white-space:pre">    span>init-param>  
  28.         <span style="white-space:pre">    span>  
  29.         <span style="white-space:pre">    span><init-param>  
  30.             <param-name>loginUsernameparam-name>  
  31.             <param-value>druidparam-value>  
  32.         init-param>  
  33.         <init-param>  
  34.             <param-name>loginPasswordparam-name>  
  35.             <param-value>druidparam-value>  
  36.         init-param>  
  37.     servlet>  
  38.     <servlet-mapping>  
  39.         <servlet-name>DruidStatViewservlet-name>  
  40.         <url-pattern>/druid/*url-pattern>  
  41.     servlet-mapping>  
配置好web.xml之后,启动自己的JavaWeb服务,访问一下地址就可以看到Druid的监控界面。我在这里的访问地址是:http://192.168.1.118:8778/druid-monitor/druid/sql.html
    Druid Monitor_第1张图片
输入用户名密码(druid/druid)就可以进入监控页面。
 Druid Monitor_第2张图片


2.Druid Monitor监控JavaSE项目


监控javaSE项目可以通过jmx访问远程服务端,也可以通过到服务端运行官网提供的druidStat.sh命令。先说明一下怎么通过Jmx来访问,这一种既方便也不至于登录生产环境的服务器。
首先既然需要使用Jmx来访问,那么服务端就必须提供Jmx的访问端口和IP地址。那么需要在我们的启动文件中增加java的运行参数。需要添加-Dcom.sun.management.jmxremote -Djava.rmi.server.hostname -Dcom.sun.management.jmxremote.port -Dcom.sun.management.jmxremote.authenticate -Dcom.sun.management.jmxremote.ssl参数来暴漏自己的服务器地址。例:linux的运行脚本
Druid Monitor_第3张图片
[plain] view plain copy
  1. RESINWEBINF=/home/v31/common-biz  
  2. LIBDIRS=${RESINWEBINF}/lib  
  3. CP=.:${RESINWEBINF}/resources  
  4. for Jars in `ls ${LIBDIRS}`  
  5. do  
  6. CP=${CP}:${LIBDIRS}/${Jars}  
  7. done  
  8.   
  9. java  -Xms2048m -Xmx2048m -cp ${CP}   -Djava.net.preferIPv4Stack=true -Dcom.sun.management.jmxremote -Djava.rmi.server.hostname=192.168.1.76  -Dcom.sun.management.jmxremote.port=9004  -Dcom.sun.management.jmxremote.authenticate=false  -Dcom.sun.management.jmxremote.ssl=false  com.company.main.StartMain  >>logs/error.log 2>&1 &  

然后再部署一个web项目来访问这个JMX的IP和端口。启动服务,检查我们的端口是否已经启动

Druid Monitor_第4张图片

最后在我们本地的web.xml中配置jmxUrl地址来访问就可以查看到数据源的监控数据。例

[html] view plain copy
  1.    
  2. <servlet>  
  3.     <servlet-name>DruidStatViewservlet-name>  
  4.     <servlet-class>com.alibaba.druid.support.http.StatViewServletservlet-class>  
  5.       
  6.       
  7.     <init-param>  
  8.            <param-name>jmxUrlparam-name>  
  9.            <param-value>service:jmx:rmi:///jndi/rmi://192.168.1.76:9004/jmxrmiparam-value>  
  10.        init-param>  
  11. servlet>  
  12. <servlet-mapping>  
  13.     <servlet-name>DruidStatViewservlet-name>  
  14.     <url-pattern>/druid/*url-pattern>  
  15. servlet-mapping>  


配置好这些之后访问我们自己的web容器,发现果然可以查看统计信息了。还有人使用jconsole来访问,这个我没有尝试过,因为觉得那个操作对我来说太麻烦了。

3.Druid Monitor监控,使用druidStat.sh

这个命令脚本在git源码的druid\src\main\scripts目录下,
druidStat.bat脚本为:

[plain] view plain copy
  1. @echo off  
  2.   
  3. rem Copyright 1999-2011 Alibaba Group Holding Ltd.  
  4. rem   
  5. rem Licensed under the Apache License, Version 2.0 (the "License");  
  6. rem you may not use this file except in compliance with the License.  
  7. rem You may obtain a copy of the License at  
  8. rem   
  9. rem      http://www.apache.org/licenses/LICENSE-2.0  
  10. rem   
  11. rem Unless required by applicable law or agreed to in writing, software  
  12. rem distributed under the License is distributed on an "AS IS" BASIS,  
  13. rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  
  14. rem See the License for the specific language governing permissions and  
  15. rem limitations under the License.  
  16.   
  17.   
  18. set _RUNJAVA="%JAVA_HOME%\bin\java.exe"  
  19. set _TOOLSJAR="%JAVA_HOME%\lib\tools.jar"  
  20.   
  21. %_RUNJAVA% -classpath "./druid-0.2.6.jar;%_TOOLSJAR%" com.alibaba.druid.support.console.DruidStat %*  
druidStat.sh脚本为:
[plain] view plain copy
  1. #!/bin/sh  
  2.   
  3. if [ -z "$JAVA_HOME" ] ; then  
  4.   echo "Error: JAVA_HOME is not defined."  
  5.   exit 1  
  6. fi  
  7.   
  8. "$JAVA_HOME/bin/java" -Dfile.encoding="UTF-8" -cp "./druid-0.2.6.jar:$JAVA_HOME/lib/tools.jar" com.alibaba.druid.support.console.DruidStat  $@  

有了这个脚本,我们就可以直接在服务器上运行看到统计信息。这里我只说明一下linux的查看方式。我们修改一下druidStat.sh的druid-0.2.6.jar的目录和名称,然后放到自己的服务器上运行即可。先说明一下命令的使用方法吧。

Druid Monitor_第5张图片

看到了druidStat.sh的命令帮助,相信大家已经会了一多半了。接下来说明一下怎么使用。直接上图:
Druid Monitor_第6张图片
如果需要查看某一个ID的具体情况,可以使用-id -detail来查看sql的详情。

Druid Monitor_第7张图片

结尾:提供一个本项目的下载地址:http://download.csdn.net/detail/binglovezi/9422882
这个只是一个tomcat的运行项目包,而非源码包,所以直接复制到自己的tomcat中,然后修改其中的参数即可,不要导入到自己的eclipse中了。

你可能感兴趣的:(JAVA)