前言:最近在做一个监控应用服务器(Tocmat、WebSphere、WebLogic)的项目,目前已小有规模,回头看看,一路走来,也算是磕磕绊绊,遇到过种种问题,走过不少弯路,不过程序员最不怕的就是遇到问题——有什么问题就解决什么问题。为了留下点印记,为后来人留下点经验之谈,助之少走弯路,特意把这些经验整理出来,与大家分享。
水平有限,难免疏漏,还望指正。如有疑问,可以Q我:562116039。
常见的有两种方案,如下:
方案一、通过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/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=&server=&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运行时性能数据:
View Source for full doctype...)>
在Java程序中对获得XML进行解析,即可获得相关的监控数据。
在Java程序中访问perfServletApp
通过浏览器访问perfServletApp时会提示输入用户名密码,那么在Java程序中又如何访问呢?
如果像访问一般的URL一样,直接访问,会提示鉴权错误,因为perfServletApp的URL是被保护的。
以下代码演示如何访问受保护的URL:
URL url = new URL(
"http://localhost:8080/manager/jmxproxy?qry=*%3Atype%3DManager%2C*");
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
相信有了以上的入门教程,加上这几个地址,剩下的就没有什么大的技术问题了,剩下的就是程序的架构和编码的实现了。希望对你有所帮助。