前言:做了一个监控应用服务器的项目(支持Tocmat、WebSphere、WebLogic各版本), 过程也算是磕磕绊绊,由于网上缺少相关资料,或者深陷于知识的海洋难以寻觅到有效的资料,因而走过不少弯路,遇过不少困难。为了留下点印记,给后来人留下 点经验之谈,助之少走弯路,故将这些经验整理出来,与大家分享。水平有限,难免疏漏,还望指正。如有疑问,欢迎留言
监控WebSphere常见的有两种方案,如下:
方案一、通过perfServletApp进行监控
perfServletApp项目是由WebSphere提供的(在安装目录下可以找到PerfServletApp.ear ,默认没有部署),用于简单的端对端检索性能数据, IBM或第三方供应商提供的任何工具都可以处理此性能数据。通过servlet访问,返回XML 格式的信息,然后解析XML即可获得相应的监控数据。
方案二、使用JMX 接口开发监控程序
通过使用PerfMBean或个别MBean,您可使用AdminClient API获取性能监控基础结构( PMI )数据。
两种方案优劣比较
通过 perfServletApp 进行监控 |
使用 JMX 接口开发监控程序 |
可以使用现有的成熟代码,减少工作量 |
全部代码需要从零开始 |
支持各不同版本时无差别 |
支持各不同版本比较麻烦,每个版本用的 JAR 包不一样,实现机制也不一样 |
可能存在特殊需求而 perfServlet 不能满足的情况 |
可支配性强,可以访问到 WAS 提供的所有 MBean |
一、 通过 perfServletApp 进行监控
perfServletApp 项目是由 WebSphere 提供的(在安装目录下可以找到 PerfServletApp.ear ,默认没有部署),用于简单的端对端检索性能数据, IBM 或第三方供应商提供的任何工具都可以处理此性能数据。通过 servlet 访问,返回 XML 格式的信息。
安装 perfServletApp
1. 安装 perfServletApp.ear
在管理控制台,点击左侧树中的应用程序 节点。点击企业应用程序 。
右侧的表中将列出已安装的所有应用程序。检查 perfServletApp 是否存在。如果不存在,则点击安装 以安装 perfServletApp.ear 文件(默认情况下该文件位于 <WebSphere Installed Location>/WebSphere/AppServer/installableApps 目录下,例如: D:/Program Files/WebSphere/AppServer/installableApps/perfServletApp.ear )。然后启动这个应用程序。
2. 在浏览器中打开 http://127.0.0.1:9080/wasPerfTool/servlet/perfservlet 链接,可以看到返回的 XML 文件,第一行是这样的格式:
< PerformanceMonitor responseStatus =" success " version =" 7.0.0 .5 "> ,这说明 perfServletApp 安装成功了。
配置 perfServletApp
如果是 WAS6.1 ,打开 http://127.0.0.1:9080/wasPerfTool/servlet/perfservlet 会返回 XML 格式的错误信息,第一行是这样的格式:
< PerformanceMonitor responseStatus =" failed " version =" 6.1.0 .0 "> ,
并且后面会带有“由于凭证不足或凭证为空”之类的错误提示。
这时需要进行一些配置:
1 ■ 启用应用程序安全性
2 ■ 在perfServletApp下进行安全用户的配置
3 ■ 保存修改后重启WAS即可
通过perfServletApp获取监控数据
启动WAS后打开下面的链接可以查看帮助文档:
http://127.0.0.1:9080/wasPerfTool/servlet/
获取监控数据的URL格式为:
http://perfServlet_Host:port/wasPerfTool/servlet/perfservlet[?node=<node>&server=<server>&module=<module>&version=5]
在浏览器地址栏中输入此 URL ,转向此地址后提示输入用户名密码,然后就可以看到返回了 XML格式的信息。
注意:加上 &version=5 则返回的格式是5.x ,如果不加,则返回的格式是6.0
例子:获取JVM运行时性能数据
URL 为,可以通过浏览器打开,项目中则通过Java代码访问URL:
http://127.0.0.1:9080/wasPerfTool/servlet/perfservlet?node=IE361-PCNode01&server=server1&module=jvmRuntimeModule
返回 XML 格式的 JVM 运行时性能数据:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE PerformanceMonitor (View Source for full doctype...)> <PerformanceMonitor responseStatus="success" version="7.0.0.5"> <Node name="IE361-PCNode01"> <Server name="server1"> <Stat name="JVM 运行时"> <BoundedRangeStatisticID="1" highWaterMark="91147" integral="0.0" lastSampleTime="1294795486836" lowWaterMark="51200" lowerBound="51200" mean="0.0" name="HeapSize" startTime="1294794248020" unit="千字节" upperBound="262144" value="91147" /> <CountStatisticID="3" count="57698" lastSampleTime="1294795830112" name="UsedMemory" startTime="1294794248020" unit="千字节" /> <CountStatisticID="4" count="1582" lastSampleTime="1294795830112" name="UpTime" startTime="1294794248020" unit="SECOND" /> <CountStatisticID="5" count="0" lastSampleTime="1294795830112" name="ProcessCpuUsage" startTime="1294794248020" unit="不适用" /> </Stat> </Server> </Node> </PerformanceMonitor>
在Java程序中对获得XML进行解析,即可获得相关的监控数据。
在Java程序中访问perfServletApp
通过浏览器访问perfServletApp时会提示输入用户名密码,那么在Java程序中又如何访问呢?
如果像访问一般的URL一样,直接访问,会提示鉴权错误,因为perfServletApp的URL是被保护的。
以下代码演示如何访问受保护的URL:
URL url = "http://127.0.0.1:9080/wasPerfTool/servlet/perfservlet?node=IE361-PCNode01&server=server1&module=jvmRuntimeModule"); URLConnection conn = (URLConnection) url.openConnection(); // URL授权访问 -- Begin String password = "admin:chenfeng"; // manager角色的用户 String encodedPassword = new BASE64Encoder() .encode(password.getBytes()); conn.setRequestProperty("Authorization", "Basic " + encodedPassword); // URL授权访问 -- End InputStream is = conn.getInputStream(); BufferedReader bufreader = new BufferedReader(new InputStreamReader(is)); String line = null; while ((line = bufreader.readLine()) != null) { System.out.println(line); }
二、使用JMX接口开发监控程序
通过使用 PerfMBean 或个别 MBean ,您可使用 AdminClient API 获取性能监控基础结构( PMI )数据。
所需要的JAR包:
◆ com.ibm.ws.admin.client_7.0.0.jar
◆ ibmjgssprovider.jar
◆ ibmkeycert.jar
1 . WebSphere不启用管理安全性
如果WebSphere不启用管理安全性的话很简单,直接就能访问AdminClient API,看下面的代码:
Properties adminProps = new Properties(); adminProps.setProperty("type", "soap"); adminProps.setProperty("host", "127.0.0.1"); adminProps.setProperty("port", "8880"); AdminClient adminClient = AdminClientFactory.createAdminClient(adminProps); String domainName = adminClient.getDomainName();
注意:要使上面的代码运行正确,必须关闭 WAS6.1 的管理安全性。
关闭WAS6.1的管理安全性的方法
登录 WebSphere 的集成解决方案控制台,进入安全性 --> 全局安全性 --> 去除“启用管理安全性”的勾选 --> 点击“应用” --> 保存到主配置 --> 重启 WAS
不过出于安全性考虑,一般实际环境下的WebSphere是不可能关闭管理安全性的。
2 . WebSphere启用管理安全性
如果WebSphere已启用管理安全性,则需要先配置证书才能访问AdminClient API。在WAS6.0 里面,这个步骤很简单,默认的证书能直接用,但是 WAS6.1 就不行,默认的证书不能用,必须生成自己的证书并配置到WAS6.1里面。
WAS6.1生成和配置证书的方法
该部分本来是直接加入到本文中的,但是导致文章太长,可读性差,所以单独分了出去,地址如下,请移驾:
http://yunzhu.iteye.com/blog/1825874
使用证书监控WebSphere的示例代码
Properties adminProps = new Properties(); adminProps.setProperty(AdminClient.CONNECTOR_TYPE, AdminClient.CONNECTOR_TYPE_SOAP); adminProps.setProperty(AdminClient.CONNECTOR_HOST, "localhost"); adminProps.setProperty(AdminClient.CONNECTOR_PORT, "8880"); adminProps.setProperty(AdminClient.USERNAME, "chenfeng"); adminProps.setProperty(AdminClient.PASSWORD, "chenfeng"); adminProps.setProperty(AdminClient.CACHE_DISABLED, "false"); // WebSphere服务器是否已启用管理安全性 adminProps.setProperty(AdminClient.CONNECTOR_SECURITY_ENABLED, "true"); adminProps.setProperty(AdminClient.CONNECTOR_AUTO_ACCEPT_SIGNER, "true"); adminProps.setProperty("javax.net.ssl.trustStore","D:/JavaTools/IBM/MyKey/trust.jks"); adminProps.setProperty("javax.net.ssl.keyStore","D:/JavaTools/IBM/MyKey/store.jks"); adminProps.setProperty("javax.net.ssl.trustStorePassword","chenfeng222"); adminProps.setProperty("javax.net.ssl.keyStorePassword", "chenfeng111"); AdminClient adminClient = AdminClientFactory.createAdminClient(adminProps); String domainName = adminClient.getDomainName(); System.out.println("domainName" + domainName ); ObjectName objName = new ObjectName("WebSphere:name=JVM,process=server1,platform=proxy,node=YNF-PCNode01,j2eeType=JVM,J2EEServer=server1,version=6.1.0.0,type=JVM,mbeanIdentifier=JVM,cell=YNF-PCNode01Cell,spec=1.0"); Object freeMemory= adminClient.getAttribute(objName, "freeMemory"); System.out.println("freeMemory" + freeMemory);
上面的例子只是简单地获取DomainName和空闲内存,实际开发中采集具体的数据,则需要查询API,以获得详细的ObjectName。
几个重要的官方文档地址
(注:如果网址变更了导致无法访问,请自行根据标题搜索)
一、官方教程:开发管理客户机程序
http://pic.dhe.ibm.com/infocenter/wasinfo/v6r1/index.jsp?topic=%2Fcom.ibm.websphere.nd.doc%2Finfo%2Fae%2Fae%2Ftjmx_develop.html
二、官方教程:使用JMX接口开发自己的监视应用程序
http://pic.dhe.ibm.com/infocenter/wasinfo/v6r1/index.jsp?topic=%2Fcom.ibm.websphere.express.doc%2Finfo%2Fexp%2Fae%2Ftprf_pmijmx.html
三、官方AdminClient接口文档
http://pic.dhe.ibm.com/infocenter/wasinfo/v6r1/index.jsp?topic=%2Fcom.ibm.websphere.javadoc.doc%2Fpublic_html%2Fapi%2Fcom%2Fibm%2Fwebsphere%2Fmanagement%2FAdminClient.html
四、官方Mbean接口API
http://pic.dhe.ibm.com/infocenter/wasinfo/v6r1/index.jsp?topic=/com.ibm.websphere.javadoc.doc/public_html/mbeandocs/index.html
相信有了以上的入门教程,加上这几个地址,剩下的就没有什么大的技术问题了,剩下的就是程序的架构和编码的实现了。希望对你有所帮助。