??ν???Java EE????????????
???????????? ???????[ 2012/4/23 9:39:52 ] ????????
?????????????????
??????????????????????????????product???????????????????????????????????????????product ????copy????????????У??????????????????????????????????????????????????????????????????????????????????????????????????Щ??????????????????????????????????????????????????????????????????????ο???
import org.slf4j.Logger;   
     
  public class TraceUtil {   
      final Logger logger;   
      final long threshold = 1000;   
      private long begin;   
      private long offtime = 0;   
      private String threadInfo;   
      private String targetId;   
     
      public TraceUtil(Logger logger?? Thread thread?? String targetId?? long begin) {   
          this.logger = logger;   
          this.threadInfo = thread.getId() + "-" + thread.toString();   
          this.targetId = targetId;   
          this.begin = begin;   
      }   
     
      public void trace(String targetEvent) {   
          long duration = System.currentTimeMillis() - begin;   
          long increment = duration - offtime;   
          offtime = duration;   
          float percentage = (float) increment / (float) duration * 100;   
          if (duration > threshold && percentage > 20) {   
              logger.error(   
                      "Response time is too large: [{}]?? {}/{} ({})?? {}?? {}"??   
                      new String[] { threadInfo + ""?? increment + ""??   
                              duration + ""?? percentage + "%"?? targetEvent??   
                              targetId });   
          }   
     
      }   
     
  }
 ????????JVM??MXBean???blocked???
??????????JVM????cpu????????????????????????????IO??????????????豸????????п??????????????????????????????????????????????????????????????JVM????monitor API??????
<%@ page import="java.lang.management.*?? java.util.*" %>    
    <%!    
        Map cpuTimes = new HashMap();    
        Map cpuTimeFetch = new HashMap();    
    %>    
        
    <%    
    out.println("Threads Monitoring");    
    long cpus = Runtime.getRuntime().availableProcessors();    
    ThreadMXBean threads = ManagementFactory.getThreadMXBean();    
    threads.setThreadContentionMonitoringEnabled(true);    
    long now = System.currentTimeMillis();    
    ThreadInfo[] t = threads.dumpAllThreads(false?? false);    
    for (int i = 0; i < t.length; i++) {    
        long id = t[i].getThreadId();    
        Long idObj = new Long(id);    
        long current = 0;    
        if (cpuTimes.get(idObj) != null) {    
            long prev = ((Long) cpuTimes.get(idObj)).longValue();    
            current = threads.getThreadCpuTime(t[i].getThreadId());    
            long catchTime = ((Long) cpuTimeFetch.get(idObj)).longValue();    
            double percent = (double)(current - prev) / (double)((now - catchTime) * cpus * 1000);    
            if (percent > 0 && prev > 0) {   
    out.println("<li>" + t[i].getThreadName()+"#"+t[i].getThreadId() + " Time: " + percent + " (" + prev + "?? " + current + ") ");   
    String locked = t[i].getLockInfo()==null?"":t[i].getLockInfo().getClassName();   
    out.println(" Blocked: (" + t[i].getBlockedTime() + "?? " + t[i].getBlockedCount() + "?? " + locked + ")</li>");   
    }   
        }    
        cpuTimes.put(idObj?? new Long(current));      
        cpuTimeFetch.put(idObj?? new Long(now));    
    }    
    %>
 
????????????????????
?????????????????????block???????????????????cpu?????????????????????????IO????????????豸???????????????ü??????????????????????????????synchronizae???????????????????????????jar????????????????????????????£????????????????????????д????????????????????????????????
??????
 
					
					???·???
App??С????H5?????????????????Щ??
2024/9/11 15:34:34?????????????????????????
2024/9/10 11:13:49P-One ???????????????????????????????????????
2024/9/10 10:14:12???????????????????????????
2024/9/9 18:04:26??????????????????
2023/3/23 14:23:39???д?ò??????????
2023/3/22 16:17:39????????????????????Щ??
2022/6/14 16:14:27??????????????????????????
2021/10/18 15:37:44 
					
 
			 
								 
								 
								 
								 
								 
								 
								 
								 
								 
								 
				 sales@spasvo.com
sales@spasvo.com