AOP@Work: 用AspectJ进行性能监视,第1部分 - 编程入门网
rationName()));
mBean.setManagedResource(this,
"ObjectReference");
return mBean;
} catch (Exception e) {
/* This is safe because @link ErrorHandling
* will resolve it. This is described later!
*/
throw new
AspectConfigurationException("can''t
register bean ", e);
}
}
/** Determine JMX operation name for this
* performance statistics bean.
*/
public String PerfStats.getOperationName() {
StringBuffer keyStr =
new StringBuffer("operation=\"");
int pos = keyStr.length();
if (key instanceof Class) {
keyStr.append(((Class)key).getName());
} else {
keyStr.append(key.toString());
}
JmxManagement.jmxEncode(keyStr, pos);
keyStr.append("\"");
return keyStr.toString();
}
private static Class[] managedInterfaces =
{ PerfStatsMBean.class };
/**
* Spring JMX utility MBean Info Assembler.
* Allows @link PerfStatsMBean to serve
* as the management interface of all performance
* statistics implementors.
*/
static InterfaceBasedMBeanInfoAssembler assembler;
static {
assembler = new InterfaceBasedMBeanInfoAssembler();
assembler.setManagedInterfaces(managedInterfaces);
}
}
AOP@Work: 用AspectJ进行性能监视,第1部分(7)时间:2011-09-07 IBM Ron Bodkin清单 3 包含 StatsJmxManagement 方面,它具体地定义了哪个对象应当公开 管理 bean。它描述了一个接口 PerfStatsMBean,这个接口定义了用于任何性能 统计实现的管理接口。其中包括计数、总时间、最大时间的统计值,还有重设操 作,这个接口是 PerfStats 接口的子集。 PerfStatsMBean 本身扩展了 ManagedBean,所以它的任何实现都会自动被 JmxManagement 方面登记成进行管理。我采用 AspectJ 的 declare parents 格 式让 PerfStats 接口扩展了一个特殊的管理接口 PerfStatsMBean。结果是 JMX Dynamic MBean 技术会管理这些对象,与使用 JMX 的标准 MBean 相比,我更喜 欢这种方式。 使用标准 MBean 会要求定义一个管理接口,接口名称基于每个性能统计的实 现类,例如 PerfStatsImplMBean。后来,当我向 Glassbox Inspector 添加 PerfStats 的子类时,情况变糟了,因为我被要求创建对应的接口(例如 OperationPerfStatsImpl)。标准 MBean 的约定使得接口依赖于实现,而且代 表 这个系统的继承层次出现不必要的重复。 这个方面剩下的部分负责用 JMX 创建正确的 MBean 和对象名称。我重用了 来 自 Spring 框架的 JMX 工具 InterfaceBasedMBeanInfoAssembler,用它可以更 容易地创建 JMX DynamicMBean(用 PerfStatsMBean 接口管理 PerfStats 实例 )。在这个阶段,我只公开了 PerfStats 实现。这个方面还用受管理 bean 类 上 的类型间声明定义了辅助方法。如果这些类中的任何一个的子类需要覆盖默认行 为,那么可以通过覆盖这个方法实现。 您可能想知道为什么我用方面进行管理而不是直接把支持添加到 PerfStatsImpl 的实现类中。虽然把管理添加到这个类中不会把代码分散,但是 它会把性能监视系统的实现与 JMX 混杂在一起。所以,如果我想把这个系统用 在 一个 没有 JMX 的系统中,就要被迫包含 JMX 的库,还要禁止有关服务。而且 , 当扩展系统的管理功能时,我还要公开更多的类用 JMX 进行管理。使用方面可 以 让系统的管理策略保持模块化。 数据库请求监视 分布式调用是应用程序性能低和出错误的一个常见源头。多数基于 Web 的应 用程序要做相当数量的数据库工作,所以对查询和其他数据库请求进行监视就成 为性能监 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |