博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Druid Monitor监控JavaSE和JavaWeb
阅读量:6086 次
发布时间:2019-06-20

本文共 10517 字,大约阅读时间需要 35 分钟。

hot3.png

 

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

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

正式版本下载地址:

Druid是一个开源项目,源码托管在github上:
Druid 0.1.18之后版本都发布到maven中央仓库中,所以你只需要在项目的pom.xml中加上dependency就可以了。例如:

[html]  

  1. <dependency>  
  2.         <groupId>com.alibaba</groupId>  
  3.         <artifactId>druid</artifactId>  
  4.         <version>${druid-version}</version>  
  5. </dependency></span>  

 

也可以选择 Maven仓库查找公共的仓库地址:

好了,废话也说了一大堆了。接下来说明一下怎么查看DruidDataSource的监控数据。

对于web项目,使用起来很方便,只需要在web.xml中配置一下DruidStatView就行了。其它的Druid已经帮我们都实现了。

 

1.Druid Monitor监控Java Web项目

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

[html]  

  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.         <!-- 基本属性 url、user、password -->  
  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.             用来检测连接是否有效的sql,要求是一个查询语句。  
  42.             如果validationQuery为null,testOnBorrow、testOnReturn、  
  43.             testWhileIdle都不会其作用   
  44.         -->  
  45.         <property name="validationQuery" value="SELECT 1 FROM DUAL" />  
  46.         <property name="testWhileIdle" value="true" />  
  47.         <property name="testOnBorrow" value="false" />  
  48.         <property name="testOnReturn" value="false" />  
  49.       
  50.         <!--   
  51.             打开PSCache,并且指定每个连接上PSCache的大小   
  52.             如果用Oracle,则把poolPreparedStatements配置为true,mysql可以配置为false  
  53.         -->  
  54.         <property name="poolPreparedStatements" value="true" />  
  55.         <property name="maxPoolPreparedStatementPerConnectionSize" value="20" />  
  56.       
  57.         <!-- 配置监控统计拦截的filters,去掉后监控界面sql无法统计 -->  
  58.         <property name="filters" value="stat,wall,log4j" />  
  59.           
  60.         <!--   
  61.             如果配置了proxyFilters,此配置可以不配置  
  62.             druid.stat.mergeSql=true 合并执行的相同sql,避免因为参数不同而统计多条sql语句  
  63.             druid.stat.slowSqlMillis=10000 用来配置SQL慢的标准,执行时间超过slowSqlMillis的就是慢  
  64.               
  65.         <property name="connectionProperties" value="druid.stat.mergeSql=true;druid.stat.slowSqlMillis=10000" />  
  66.          -->  
  67.            
  68.         <!-- 监控统计拦截的filters -->  
  69.         <!-- 并在filters属性中配置了log4j -->  
  70.         <property name="proxyFilters">  
  71.             <list>  
  72.                 <ref bean="stat-filter" />  
  73.                 <ref bean="log-filter" />  
  74.             </list>  
  75.         </property>  
  76.     </bean>  
  77.       
  78.     <!-- 慢SQL记录-->  
  79.     <bean id="stat-filter" class="com.alibaba.druid.filter.stat.StatFilter">  
  80.         <property name="mergeSql" value="true" />  
  81.         <property name="slowSqlMillis" value="10000" />  
  82.         <property name="logSlowSql" value="true" />  
  83.     </bean>  
  84.       
  85.     <bean id="log-filter" class="com.alibaba.druid.filter.logging.Log4jFilter">  
  86.         <!-- <property name="resultSetLogEnabled" value="false" /> -->  
  87.         <!-- <property name="statementExecutableSqlLogEnable" value="true" /> -->  
  88.     </bean>  
  89.       
  90.     <!-- 配置druid监控spring jdbc -->  
  91.     <bean id="druid-stat-interceptor" class="com.alibaba.druid.support.spring.stat.DruidStatInterceptor" />  
  92.    
  93.     <bean id="druid-stat-pointcut" class="org.springframework.aop.support.JdkRegexpMethodPointcut" scope="prototype">  
  94.         <property name="patterns">  
  95.             <list>  
  96.                 <value>com.XXX.stat.service.*</value>  
  97.                 <value>com.XXX.stat.dao.*</value>  
  98.             </list>  
  99.         </property>  
  100.     </bean>  
  101.       
  102.     <aop:config proxy-target-class="true">  
  103.         <aop:advisor advice-ref="druid-stat-interceptor" pointcut-ref="druid-stat-pointcut" />  
  104.     </aop:config>  
  105. </beans>  

 

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

 

[plain]  

  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]  

  1. <filter>  
  2.         <filter-name>DruidWebStatFilter</filter-name>  
  3.         <filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class>  
  4.         <init-param>  
  5.             <!-- 经常需要排除一些不必要的url,比如.js,/jslib/等等。配置在init-param中 -->  
  6.             <param-name>exclusions</param-name>  
  7.             <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*</param-value>  
  8.         </init-param>  
  9.         <!-- 缺省sessionStatMaxCount是1000个。你可以按需要进行配置 -->  
  10.         <init-param>  
  11.             <param-name>sessionStatMaxCount</param-name>  
  12.             <param-value>1000</param-value>  
  13.         </init-param>  
  14.         <!-- druid 0.2.7版本开始支持profile,配置profileEnable能够监控单个url调用的sql列表 -->  
  15.         <init-param>  
  16.             <param-name>profileEnable</param-name>  
  17.             <param-value>true</param-value>  
  18.         </init-param>  
  19.         <init-param>  
  20.             <param-name>principalSessionName</param-name>  
  21.             <param-value>users.username</param-value>  
  22.         </init-param>  
  23.         <!-- 你可以关闭session统计功能   
  24.         <init-param>   
  25.             <param-name>sessionStatEnable</param-name>   
  26.             <param-value>true</param-value>  
  27.         </init-param> -->  
  28.     </filter>  
  29.        
  30.     <servlet>  
  31.         <servlet-name>DruidStatView</servlet-name>  
  32.         <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>  
  33.         <!--   
  34.             deny优先于allow,如果在deny列表中,就算在allow列表中,也会被拒绝。  
  35.             如果allow没有配置或者为空,则允许所有访问  
  36.          -->  
  37.         <init-param>  
  38.             <param-name>allow</param-name>  
  39.             <param-value>128.242.127.1/24,127.0.0.1</param-value>  
  40.         </init-param>  
  41.         <init-param>  
  42.             <param-name>deny</param-name>  
  43.             <param-value>192.168.1.118</param-value>  
  44.         </init-param>  
  45.         <!-- 在StatViewSerlvet输出的html页面中,有一个功能是Reset All,执行这个操作之后,会导致所有计数器清零,重新计数 -->  
  46.        <span style="white-space:pre"> </span><init-param>  
  47.             <span style="white-space:pre">    </span><param-name>resetEnable</param-name>  
  48.             <span style="white-space:pre">    </span><param-value>false</param-value>  
  49.         <span style="white-space:pre">    </span></init-param>  
  50.         <span style="white-space:pre">    </span><!--  用户名和密码 -->  
  51.         <span style="white-space:pre">    </span><init-param>  
  52.             <param-name>loginUsername</param-name>  
  53.             <param-value>druid</param-value>  
  54.         </init-param>  
  55.         <init-param>  
  56.             <param-name>loginPassword</param-name>  
  57.             <param-value>druid</param-value>  
  58.         </init-param>  
  59.     </servlet>  
  60.     <servlet-mapping>  
  61.         <servlet-name>DruidStatView</servlet-name>  
  62.         <url-pattern>/druid/*</url-pattern>  
  63.     </servlet-mapping>  

配置好web.xml之后,启动自己的JavaWeb服务,访问一下地址就可以看到Druid的监控界面。我在这里的访问地址是:http://192.168.1.118:8778/druid-monitor/druid/sql.html

   

输入用户名密码(druid/druid)就可以进入监控页面。

 

 

 

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的运行脚本

[plain]  

  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和端口。启动服务,检查我们的端口是否已经启动

 

 

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

 

[html]  

  1.    
  2. <servlet>  
  3.     <servlet-name>DruidStatView</servlet-name>  
  4.     <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class>  
  5.       
  6.     <!-- 远程访问JavaSE项目使用jmx连接 -->  
  7.     <init-param>  
  8.            <param-name>jmxUrl</param-name>  
  9.            <param-value>service:jmx:rmi:///jndi/rmi://192.168.1.76:9004/jmxrmi</param-value>  
  10.        </init-param>  
  11. </servlet>  
  12. <servlet-mapping>  
  13.     <servlet-name>DruidStatView</servlet-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]  

  1.  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]  

  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的目录和名称,然后放到自己的服务器上运行即可。先说明一下命令的使用方法吧。

 

 

看到了druidStat.sh的命令帮助,相信大家已经会了一多半了。接下来说明一下怎么使用。直接上图:

如果需要查看某一个ID的具体情况,可以使用-id -detail来查看sql的详情。

 

 

结尾:提供一个本项目的下载地址:

这个只是一个tomcat的运行项目包,而非源码包,所以直接复制到自己的tomcat中,然后修改其中的参数即可,不要导入到自己的eclipse中了。

转载于:https://my.oschina.net/weiweiblog/blog/1604635

你可能感兴趣的文章
要想成为高级Java程序员需要具备哪些知识呢?
查看>>
带着问题去学习--Nginx配置解析(一)
查看>>
onix-文件系统
查看>>
java.io.Serializable浅析
查看>>
我的友情链接
查看>>
多线程之线程池任务管理通用模板
查看>>
CSS3让长单词与URL地址自动换行——word-wrap属性
查看>>
CodeForces 580B Kefa and Company
查看>>
开发规范浅谈
查看>>
Spark Streaming揭秘 Day29 深入理解Spark2.x中的Structured Streaming
查看>>
鼠标增强软件StrokeIt使用方法
查看>>
本地连接linux虚拟机的方法
查看>>
某公司面试java试题之【二】,看看吧,说不定就是你将要做的题
查看>>
BABOK - 企业分析(Enterprise Analysis)概要
查看>>
Linux 配置vnc,开启linux远程桌面
查看>>
CentOS6.4关闭触控板
查看>>
React Native 极光推送填坑(ios)
查看>>
Terratest:一个用于自动化基础设施测试的开源Go库
查看>>
修改Windows远程终端默认端口,让服务器更安全
查看>>
扩展器必须,SAS 2.0未必(SAS挺进中端存储系统之三)
查看>>