MyEclipse性能调优初体验

简介一下工作环境,MyEclipse2014,你懂的

项目中有一个基于web的工作流引擎,仅仅要执行起来就CPU差点儿耗尽(尽管看似27%,事实上已经把俺4核的CPU当中一个核给全然占光了)


启动性能分析的简要方法:

项目根文件夹上右键

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2F0Y2hlcg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">


在MyEclipse Server Application的项目下新建一个配置

main的tab页中能够看到prject和server的选择,我这里仅仅有一个tomcat7支持的web项目

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2F0Y2hlcg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">


点击右下角的 Profilebutton。

则会在tomcat中启动自己的web项目而且自己主动启动性能工具进行监视。笔者这里自己主动启动的是visualVM 1.3.6,您自己安装的版本号可能会不太一样

工具启动之后。就能够看到关于是CPU监视还是内存监视的部分了。

我这里项目因为是CPU占用的问题。所以选择CPU


在监视界面上能够看到下面的热点方法

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2F0Y2hlcg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

除开系统的API类的方法(它们一般是被业务方法调用多次导致消耗CPU的),找到了ExecutorEngine.execute()方法是罪魁祸首
好了。直奔这种方法,发现里面仅仅有一个轮询的代码段
  while(true){
   // 获取队列中的一条事件
   EventInfo eventInfo = eventMangeCenter.takeEvent();
   if(eventInfo != null){
    // 首先将事件插入数据库
    insertHistoryEvent(eventInfo);
    // 运行按事件类型注冊的监听器的处理程序
    executeProcessByEventType(eventInfo);
    // 运行按事件编码注冊的监听器的处理程序
    executeProcessByEventCode(eventInfo);
    // 运行按事件类型和事件编码注冊的监听器的处理程序
    executeProcess(eventInfo);
       }    
  }
而eventMangeCenter.takeEvent();方法例如以下
  */
 public EventInfo takeEvent(){
  EventInfo info = null;
  if(queueEventInfo.peek() != null){
   // 取出第一条,而且删除
   info = queueEventInfo.poll();
  }
  return info;
 }
继续深入,takeevent并没有完毕它应该具有的功能:堵塞
 public EventInfo takeEvent(){
  EventInfo info = null;
  if(queueEventInfo.peek() != null){
   // 取出第一条,而且删除
   info = queueEventInfo.poll();
  }
  return info;
 }

至此。问题原因找到了,然后将定义为 private Queue<EventInfo> queueEventInfo 改动为private BlockingQueue<EventInfo> queueEventInfo; 利用java本身的BlockingQueue来实现轮训的时候,有数据才開始动,没数据就等着

public EventInfo takeEvent() throws InterruptedException {
  return queueEventInfo.take();
}

再次启动tomcat server的项目,CPU在没有服务里请求的时候,保持0%的理论值,这才是一个服务应该具有的气质嘛。哈哈

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2F0Y2hlcg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">


到这里告一段落吧,深入的东西下次再说

MyEclipse性能调优初体验的更多相关文章

  1. 初窥MySQL性能调优

    本文涉及:MySQL自带的性能测试工具mysqlslap的使用及几个性能调优的方法 性能测试工具—mysqlslap mysqlslap是MySQL自带的一款非常优秀的性能测试工具.使用它可以 模拟多 ...

  2. MySQL性能调优与架构设计——第9章 MySQL数据库Schema设计的性能优化

    第9章 MySQL数据库Schema设计的性能优化 前言: 很多人都认为性能是在通过编写代码(程序代码或者是数据库代码)的过程中优化出来的,其实这是一个非常大的误区.真正影响性能最大的部分是在设计中就 ...

  3. MySQL性能调优与架构设计——第8章 MySQL数据库Query的优化

    第8章 MySQL数据库Query的优化 前言: 在之前“影响 MySQL 应用系统性能的相关因素”一章中我们就已经分析过了Query语句对数据库性能的影响非常大,所以本章将专门针对 MySQL 的 ...

  4. MySQL性能调优与架构设计——第6章 MySQL Server 性能的相关因素

    第6章 MySQL Server 性能的相关因素 前言 大部分人都一致认为一个数据库应用系统(这里的数据库应用系统概指所有使用数据库的系统)的性能瓶颈最容易出现在数据的操作方面,而数据库应用系统的大部 ...

  5. iOS-------应用性能调优的25个建议和技巧

    性能对 iOS 应用的开发尤其重要,如果你的应用失去反应或者很慢,失望的用户会把他们的失望写满App Store的评论.然而由于iOS设备的限制,有时搞好性能是一件难事.开发过程中你会有很多需要注意的 ...

  6. iOS应用性能调优建议

    本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/,你还可以 ...

  7. iOS应用性能调优的25个建议和技巧

    本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/,你还可以 ...

  8. linux概念之性能调优

    目前,对系统进行性能调试的工具有很多,这些可以两大类:一类是标准的分析工具,即所有的UNIX都会带的分析工具: 另一类是不同厂商的UNIX所特有的性能分析工具,比如HP-UX就有自己的增值性能分析工具 ...

  9. [转]iOS应用性能调优的25个建议和技巧

    写在前面 本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/ ...

随机推荐

  1. ProcessBuilder 和 Runtime(转)

    ProcessBuilder.start() 和 Runtime.exec() 方法都被用来创建一个操作系统进程(执行命令行操作),并返回 Process 子类的一个实例,该实例可用来控制进程状态并获 ...

  2. poj1799---解析几何

    sin(a)=r/R-r,反三角asin(r/R-r),乘以2n=2pi,去化简,得到r 收获:define pi acos(-1) 这样pi的精度会高很多<math.h>(cos,sin ...

  3. umount.nfs device busy day virsh extend diskSpace, attachDisk

    KVM中linux虚拟机的硬盘添加方法 最近虚拟机中运行的东西比较多,很多.而刚启动的时候虚拟机分配的磁盘比较少,随着日志还有平时的上传文件的积累,磁盘空间报警了.网上查了下资料,自己也做了下实验.总 ...

  4. Qt通过Http上传文件(路过)

    web端: <?php $c = $GLOBALS['HTTP_RAW_POST_DATA']; $n = $_GET["filename"]; $fp = fopen($n ...

  5. 将外部准备好的sqlite导入到项目当中

    首先,将sqlite数据库文件放在Resource文件夹下,并且允许其编译到项目当中. 之后在AppDelegate当中执行一些代码,这里将代码封装了一个Helper: #import "R ...

  6. mysql 权限控制具体解释

    概述 mysql权限控制在不同的上下文和不同的操作水平上都能够进行控制,他们包括例如以下几个 ** 管理权限能够同意用户管理mysql server的操作. 这些权限控制是全局的,不是针对某个特定的数 ...

  7. Dyanmics CRM您无法登陆系统。原因可能是您的用户记录或所属的业务部门在Microoft Dynamics CRM中已被禁用

    当在操作CRM时,做不论什么的写操作包含创建数据.更新数据.都会提示以下截图中的错误:"您无法登陆系统.原因可能是您的用户记录或所属的业务部门在Microoft Dynamics CRM中已 ...

  8. TIMESTEN安装配置指南-中文版

    TimesTen内存数据库 第一章 Cache Connect to Oracle概念 TimesTen数据交换技术提供在Oracle数据库和TimesTen数据管理器之间进行连接和双向数据传送.数据 ...

  9. android插件化-apkplugdemo源代码阅读指南-10

    阅读本节内容前可先了解 apkplug基础教程 本教程是基于apkplug V1.6.8 版本号编写  最新开发方式以官网为准 可下载最新的apkplugdemo源代码http://git.oschi ...

  10. 用ADB(Android Debug Bridge)实时监测Android程序的运行

      监控Android设备上程序的运行,需要ADB的配合,具体ADB工具的介绍以及命令选项可见博客: http://blog.csdn.net/mliubing2532/article/details ...