关于UtilTimerStack类的使用--XWork2、Struts2内置性能诊断类
关于UtilTimerStack类的使用--XWork2、Struts2内置性能诊断类
一、UtilTimerStack做什么用的?
这个本来是Xwork2(Struts2的核心)的相关的工具类,可以用来测试一些逻辑操作所消耗的时间(以毫秒为单位),其本身使用一个
ArrayList作为存放ProfilingTimerBean的容器,而行为以Stack栈(后入先出)为主。在打印的时候支持缩进显示,显示相关的
调用关系。类ProfilingTimerBean主要是用来记录一些相关的信息,例如主要标识、开始时间、结束时间。
二、UtilTimerStack如何使用?
UtilTimerStack的调用方法不多且都为静态函数,但在调用之前必须先开启诊断功能,
主要有以下三种方法开启:
- 在启动时加入参数: -Dxwork.profile.activate=true
- 在使用前、或者静态代码区、或者Servlet的初始化、或者Filter的初始化 加入代码:
UtilTimerStack.setActivate(true);
或者 System.setProperty("xwork.profile.activate", "true");
或者 System.setProperty(UtilTimerStack.ACTIVATE_PROPERTY, "true");
- 也支持xml来定义相关拦截器(必须开启dev模式和加入Profiling拦截器):
<action ... >
...
<interceptor-ref name="profiling">
<param name="profilingKey">profiling</param>
</interceptor-ref>
...
</action>
再通过URL访问: http://host:port/context/namespace/someAction.action?profiling=true
或者通过代码加入请求参数: ActionContext.getContext().getParameters().put("profiling", "true);
指定超时打印功能,只有当运行时间超过时才会进行记录,开启方法:
- 在启动时加入参数: -Dxwork.profile.mintime=1000
- 或者代码加入:System.setProperty(UtilTimerStack.MIN_TIME, "" + 1000);
例子代码:
- public static void main(String[] args) throws InterruptedException {
- String name = "test used time:";
- UtilTimerStack.setActive(true); //开启诊断功能
- System.setProperty(UtilTimerStack.MIN_TIME, "" + 1000); //设置最小的超时记录时间
- UtilTimerStack.push(name); //顶节点的记录Bean
- subMethod(0);
- UtilTimerStack.pop(name);//对应的出栈操作,名称与入栈时相同
- }
- public static void subMethod(int i) throws InterruptedException{
- System.out.println(i + "");
- UtilTimerStack.push(i + " times");
- if(i<3) subMethod(i+1); //递归调用,会产生缩进,最后调用i=3时不足1000,不记录
- Thread.sleep(i * 300);
- UtilTimerStack.pop(i + " times");
- }
代码输出:
0
1
2
3
2010-3-21 16:16:52 com.opensymphony.xwork2.util.logging.commons.CommonsLogger info
信息: [1828ms] - test used time:
[1828ms] - 0 times
[1828ms] - 1 times
[1516ms] - 2 times
三、UtilTimerStack内部机制?
ProfilingTimerBean类结构
主要成员:
List<ProfilingTimerBean> children;//记录子节点为,打印时需要
ProfilingTimerBean parent = null;//记录父节点,顶点的父节点为null
String resource;//主要标识,名称
long startTime;//开始时间
long totalTime;//结束时间
UtilTimerStack的压栈(push)动作:
- public static void push(String name)
- {
- if (!isActive()) //判断是否开启诊断功能
- return;
- //创建新的记录Bean,并用setStartTime方法开始记录
- ProfilingTimerBean newTimer = new ProfilingTimerBean(name);
- newTimer.setStartTime();
- //判断如果有父节点,则添加到父节点的Child中.
- ProfilingTimerBean currentTimer = (ProfilingTimerBean) current.get();
- if (currentTimer != null)
- {
- currentTimer.addChild(newTimer);
- }
- //再把新建的节点设置为当前的线程的局部变量current中.
- current.set(newTimer);
- }
UtilTimerStack的出栈(pop)动作:
- public static void pop(String name)
- {
- if (!isActive())
- return;
- //获取当前线程的变量current.get()返回顶部记录Bean
- ProfilingTimerBean currentTimer = (ProfilingTimerBean) current.get();
- //if the timers are matched up with each other (ie push("a"); pop("a"));
- //测试出栈的记录Bean是否与要求的对应,如果不对应则log下错误,并打印栈里的记录Bean信息
- //如果与要求的标识对应,则把父节点设置为当前节点.
- if (currentTimer != null && name != null && name.equals(currentTimer.getResource()))
- {
- currentTimer.setEndTime();
- ProfilingTimerBean parent = currentTimer.getParent();
- //如果当前节点为根节点,则开始打印这个栈里面的记录Bean信息
- if (parent == null)
- {
- printTimes(currentTimer);
- //清理当前的线程局部变量,防止一些容器使用线程池的方式处理请求.
- current.set(null);
- }
- else
- {
- //设置父节点为当前节点.
- current.set(parent);
- }
- }
- else
- {
- //当出栈的顺序不对称时,把剩下的都打印出来
- if (currentTimer != null)
- {
- printTimes(currentTimer);
- current.set(null);
- LOG.warn("Unmatched Timer. Was expecting " + currentTimer.getResource() + ", instead got " + name);
- }
- }
- }
关于UtilTimerStack类的使用--XWork2、Struts2内置性能诊断类的更多相关文章
- struts2内置拦截器和自定义拦截器详解(附源码)
一.Struts2内置拦截器 Struts2中内置类许多的拦截器,它们提供了许多Struts2的核心功能和可选的高级特 性.这些内置的拦截器在struts-default.xml中配置.只有配置了拦截 ...
- 扩展PHP内置的异常处理类
在try代码块中,需要使用throw语句抛出一个异常对象,才能跳到转到catch代码块中执行,并在catch代码块中捕获并使用这个异常类的对象.虽然在PHP中提供的内置异常处理类Exception,已 ...
- day28 面向对象:反射,内置函数,类的内置方法
面向对象进阶博客地址链接: http://www.cnblogs.com/Eva-J/articles/7351812.html 复习昨日内容: # 包 # 开发规范 # # hashlib # 登录 ...
- 2018.11.20 Struts2中对结果处理方式分析&struts2内置的方式底层源码剖析
介绍一下struts2内置帮我们封装好的处理结果方式也就是底层源码分析 这是我们的jar包里面找的位置目录 打开往下拉看到result-type节点 name那一列就是我们的type类型取值 上一篇博 ...
- Struts2内置校验器——完整实例代码
一.校验器的配置风格 1.字段校验器: <field name="被校验的字段"> <field-validator type="校验器名"& ...
- 洗礼灵魂,修炼python(42)--巩固篇—type内置函数与类的千丝万缕关系
type函数的隐藏属性 相信大家都知道内置函数type是用来查看对象的数据类型的.例: 那比如我对int类查看类型呢? 有朋友会说,int是内置类啊,用自定义的应该不会这样,我们自定义一个类呢? 还是 ...
- python基础之反射内置方法元类
补充内置函数 isinstance(obj,Foo) # 判断obj是不是foo的实例 issubclass() # 判断一个类是不是另一个类的子类 反射 什么是反射? 通过字符串来操作 ...
- python类详细说明、常用内置方法和self的作用
一.类的定义 在Python中,一切皆对象,即便是类本身,也是一种type类型的特殊对象. class Person: def __init__(self, name, age): self.name ...
- python类与对象-如何派生内置不可变类型并修其改实例化行为
如何派生内置不可变类型并修其改实例化行为 问题举例 自定义一种新类型的元组,对传入的可迭代对象,我们只保留 其中int类型且值大于0的元素,例如 IntTuple([1, -1, 'abc', 6, ...
随机推荐
- 《Tips for Optimizing C/C++ Code》译文
前不久在微博上看到一篇非常好的短文讲怎样对C/C++进行性能优化,尽管其面向的领域是图形学中的光线跟踪,可是还是具有普遍的意义,将其翻译成中文,希望对大家写高质量代码有帮助. 1. 牢记阿姆达 ...
- 开放Nginx在文件夹列表功能
nginx在列出的默认同意整个文件夹.你怎么转Nginx在文件夹列表功能?打开nginx.conf文件.在location server 要么 http段增加 autoindex on;另外两个參数最 ...
- SQL -- 是否或推断线相交以在其内部的平面
SQL如下面: update mapping_nj_roads set municipality='227' from mapping_geodata_boundary a where a.suppo ...
- Codeforces 442B Andrey and Problem(贪婪)
题目链接:Codeforces 442B Andrey and Problem 题目大意:Andrey有一个问题,想要朋友们为自己出一道题,如今他有n个朋友.每一个朋友想出题目的概率为pi,可是他能够 ...
- 将android界面背景设置为黑色
屏幕背景设置为黑色的几种方式: 新建项目时候 第二次next之后(不同sdk版本号可能不同),Background Color项点击可选. 开公布局文件,选择视图查看 就是下边二个选项卡中的第一个(G ...
- 开玩笑html5(五岁以下儿童)---绕地球月球,地球绕太阳运动(canvas实现,同样可以移动哦)
请珍惜劳动小编成果,这篇文章是原来小编,转载请注明出处. 速度的參数与真实速度有点差距.大家能够自行调整 <!DOCTYPE html> <html> <head> ...
- Repository、IUnitOfWork和IDbContext
DDD 领域驱动设计-谈谈Repository.IUnitOfWork和IDbContext的实践 上一篇:<DDD 领域驱动设计-谈谈 Repository.IUnitOfWork 和 IDb ...
- passenger nginx
sudo dd if=/dev/zero of=/swap bs=1M count=1024 sudo mkswap /swap sudo swapon /swap Nginx with Passen ...
- Codeforces Round #267 (Div. 2) A
题目: A. George and Accommodation time limit per test 1 second memory limit per test 256 megabytes inp ...
- Zero Downtime Upgrade of Oracle 10g to Oracle 11g Using GoldenGate — 3
DDL Setup Steps SQL> grant execute on utl_file to ggs; Grant succeeded. Create GLOBALS file [orac ...