`
xiao_jiang51
  • 浏览: 35771 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

多线程分析工具Mtrat使用

阅读更多
    一个非常不错的多线程分析工具,提供方是IBM,官方上的说明貌似是中国人开发的,NB,反编译看了下 用到了AOP的东东,对死锁的诊断非常有价值,官方地址http://www.alphaworks.ibm.com/tech/mtrat
   因在一个为两W人在线服务的保险销售系统中使用到了一个并非控制器,因生产环境是1.4的版本,无法使用最新的无锁定算法支持,Doug Lea 大牛的那个并发包也就是被JDK 1.5吸收的那个NB包的原子类其实还是全部锁定的(1.5及之后全部被重写为无锁定算法),本人觉得会降低该控制器的并发量,决定自己用volatile 和
synchronized 实现并发控制逻辑,要求很简单,业务请求不能超过并发量,超过并发量不处理。
   因这个功能结合的是业务的一个ajax定时刷新请求,PM 要求务必保证计数的正确与不产生死锁问题,这可不是闹着玩的,生产系统要是因为这个导致宕机,后果相当严重。为了保证质量,借助工具是非常必要的。
   在这个过程中引入了mtrat 来分析代码。网上貌似没发现有比较详细的中文使用说明,那个手册毕竟是英文版的,俺们就把自己使用的过程罗列下吧,防止忘记,这确实是个好东西。。
   首先到IBM官网下载mtrat 的最新包,需要有ibm id,没有需要注册
    其中的com.ibm.threadanalysis.dynamic.feature.zip 是eclipse 插件
   将其解压含 features 和plugins 两个文件夹,要是偷懒,直接将文件夹得内容复制到eclipse相应目录,重启eclipse 即可,不过最好还是用link 的方式比较好
   创建一个名为com.ibm.mtrat.link文件里面的内容是path=F:\\Mtrat\\doc\\plugin 这个目录下含一个eclipse 文件名 里面含上面的 features 和plugins 两个文件夹及相应内容,让后将link文件仍到ecipse 的links文件夹即可,没有就新建,如果不想要了将link 后缀名改掉或着删除这个文件即可,非常方便。

   安装好后,eclipse工具栏上会出现

   安装好后在windows(窗口)菜单的preferences(首选项)中会见到一个Thread Analysis 的项   ,如果点击出错提示什么bad version class 之类 说明eclipse jre版本低了 换到1.6才行,直接用1.6的jre 替换eclipse下的jre即可。


  将开关打开,并且设置mtrat目录,这个很重要,必须正确才能使用,这个目录的文件含从IBM 那下载来的mtrat-instrument-analysis-20090218.zip 解压文件
  本人解压后文件如图


图中有3个选择的对象不是解压后产生的,那个asm-all-3.0.jar 是下载的(http://download.forge.objectweb.org/asm/下面有)
那java 目录和target.jar是生成的,mtrat的说明文档很啰嗦,又是点击mtrat.bat 啊又是设置环境变量的 太麻烦,俺们直接反编译InstrumentClass了解机制,然后直接整了个类InstrumentClassImpl
 
package com.gm;

import java.io.File;

import com.ibm.threadanalysis.dynamic.tool.InstrumentClass;
/**
 * FOR SUN JDK 
 * @author [url=mailto:xiao_jiang51@163.com]xiao_jiang51[/url]
 * @version 1.0  Create on Dec 14, 2010 12:07:52 AM
 */
public class InstrumentClassImpl extends InstrumentClass{

	@Override
	protected String[] makeClassList() {
		return new String[] { "java/lang/ref/WeakReference.class", "java/lang/Thread.class", "java/lang/Class.class" };
	}
	
	public static void main(String[] args) {
		InstrumentClass ic=new InstrumentClassImpl();
		String path="F:"+File.separator+"Mtrat";
		ic.createJar(path);
	}

}

将asm-all-3.0.jar  和class.jar 拷贝到工程classpath下  运行,需要1.6以上的编译运行环境,就会多出java 和target.jar两个东东,如果首次运行的是1.6以下的,需要将java文件夹和target.jar先删除再次运行获得新的文件夹和jar



上面的过程其实就是mtrat 为了修改了部分jdk类的字节码,加入了自己的逻辑,AOP很强大
一切准备妥当,就得小白鼠上台
mtrat 准备了以个sample 位于com.ibm.threadanalysis.dynamic.feature.zip 中
在解压后的plugin文件夹中的com.ibm.threadanalysis.dynamic.examples_1.0.0.jar中 解压出来有个Sample.zip 解压后有个Samples工程,直接导入到eclipse 即可,其实呢mtrat的说明文档中不是这样用它的 说的是如果插件安装成功可以通过在eclipse 中的new 菜单中的example菜单中整出来的 反正我是没整出来,就自己去找了。
  导入后就2个类


将analysis视图打开


先在eclipse 中将2个类run一下 编译运行环境是1.6以上,再点击 analysis按钮,就能获得分析结果了
例子是多线程中的两种类型的问题
下面的是数据不一致的读写问题


下面的是死锁问题
  • 大小: 19 KB
3
1
分享到:
评论
1 楼 taosurf 2014-11-25  
下载在哪里,能给个具体点的么

相关推荐

    Java并发编程实践-电子书-05章.pdf

    MTRAT可以通过模拟多线程环境来检测潜在的数据冲突。以下是一个简单的例子: ```java class Account { private volatile double balance; public synchronized void withdraw(double amount) { if (balance >= ...

    java并发编程1-9

    java并发编程1-9,可解压,并发编程必看资料。 1 Java 并发编程实践基础 2 构建线程安全应用程序 ...5 数据冲突及诊断工具MTRAT 6 死锁 7 显示锁 ReentrantLock 8 原子变量与非阻塞算法 9 Java 内存模型

    七参数法空间坐标系变换VC源代码

    通过这些控制点,建立方程组,并使用最小二乘法来解算这些参数。 根据给定的部分代码示例,我们可以看到如何通过具体的编程语言(如C#)实现七参数法的空间坐标变换过程。 #### 四、七参数法的代码实现 ##### (1...

    java-programming-ii-submit:我的提交Java编程2-赫尔辛基大学的大规模在线公开课程

    java-programming-mooc-submit 我的提交Java编程2-来自java-programming.mooc.fi Java编程在线赫尔辛基大学(Linus Torvaldstố...tấtcảuđượckiểmtrabằngdịchvụkiểmtratựchitng,viếtbằngjUnit rttất

Global site tag (gtag.js) - Google Analytics