probe stubs added.
This commit is contained in:
parent
eefbd4aee6
commit
4adc8ec00f
|
@ -0,0 +1,25 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<assembly
|
||||
xmlns="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.0 http://maven.apache.org/xsd/assembly-1.1.0.xsd">
|
||||
<id>dir</id>
|
||||
<formats>
|
||||
<format>dir</format>
|
||||
</formats>
|
||||
<includeBaseDirectory>false</includeBaseDirectory>
|
||||
<dependencySets>
|
||||
<dependencySet>
|
||||
<outputDirectory>lib</outputDirectory>
|
||||
<useProjectArtifact>false</useProjectArtifact>
|
||||
<unpack>false</unpack>
|
||||
<scope>runtime</scope>
|
||||
</dependencySet>
|
||||
</dependencySets>
|
||||
<files>
|
||||
<file>
|
||||
<source>target/bench4q-monitor.jar</source>
|
||||
<outputDirectory>/</outputDirectory>
|
||||
</file>
|
||||
</files>
|
||||
</assembly>
|
117
pom.xml
117
pom.xml
|
@ -1,44 +1,75 @@
|
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<groupId>org.bench4q</groupId>
|
||||
<artifactId>bench4q-monitor</artifactId>
|
||||
<packaging>jar</packaging>
|
||||
<version>0.0.1-SNAPSHOT</version>
|
||||
<name>Bench4Q Monitor</name>
|
||||
<description>Bench4Q Monitor</description>
|
||||
<organization>
|
||||
<name>TCSE, ISCAS</name>
|
||||
</organization>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>4.11</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-server</artifactId>
|
||||
<version>8.1.11.v20130520</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-servlet</artifactId>
|
||||
<version>8.1.11.v20130520</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework</groupId>
|
||||
<artifactId>spring-webmvc</artifactId>
|
||||
<version>3.2.3.RELEASE</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.codehaus.jackson</groupId>
|
||||
<artifactId>jackson-mapper-asl</artifactId>
|
||||
<version>1.9.12</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
<build>
|
||||
<finalName>bench4q-monitor</finalName>
|
||||
</build>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<groupId>org.bench4q</groupId>
|
||||
<artifactId>bench4q-monitor</artifactId>
|
||||
<packaging>jar</packaging>
|
||||
<version>0.0.1-SNAPSHOT</version>
|
||||
<name>Bench4Q Monitor</name>
|
||||
<description>Bench4Q Monitor</description>
|
||||
<organization>
|
||||
<name>TCSE, ISCAS</name>
|
||||
</organization>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>4.11</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-server</artifactId>
|
||||
<version>8.1.11.v20130520</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-servlet</artifactId>
|
||||
<version>8.1.11.v20130520</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework</groupId>
|
||||
<artifactId>spring-webmvc</artifactId>
|
||||
<version>3.2.3.RELEASE</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.codehaus.jackson</groupId>
|
||||
<artifactId>jackson-mapper-asl</artifactId>
|
||||
<version>1.9.12</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<artifactId>maven-jar-plugin</artifactId>
|
||||
<configuration>
|
||||
<archive>
|
||||
<manifest>
|
||||
<mainClass>org.bench4q.monitor.Main</mainClass>
|
||||
<addClasspath>true</addClasspath>
|
||||
<classpathPrefix>lib/</classpathPrefix>
|
||||
</manifest>
|
||||
</archive>
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<artifactId>maven-assembly-plugin</artifactId>
|
||||
<executions>
|
||||
<execution>
|
||||
<id>make-zip</id>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>single</goal>
|
||||
</goals>
|
||||
<configuration>
|
||||
<descriptors>
|
||||
<descriptor>descriptor.xml</descriptor>
|
||||
</descriptors>
|
||||
</configuration>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
</plugins>
|
||||
<finalName>bench4q-monitor</finalName>
|
||||
</build>
|
||||
</project>
|
|
@ -1,67 +1,68 @@
|
|||
package org.bench4q.monitor;
|
||||
|
||||
import org.eclipse.jetty.server.Connector;
|
||||
import org.eclipse.jetty.server.Server;
|
||||
import org.eclipse.jetty.server.bio.SocketConnector;
|
||||
import org.eclipse.jetty.servlet.ServletContextHandler;
|
||||
import org.eclipse.jetty.servlet.ServletHolder;
|
||||
import org.springframework.web.servlet.DispatcherServlet;
|
||||
|
||||
public class MonitorServer {
|
||||
private Server server;
|
||||
private int port;
|
||||
|
||||
private Server getServer() {
|
||||
return server;
|
||||
}
|
||||
|
||||
private void setServer(Server server) {
|
||||
this.server = server;
|
||||
}
|
||||
|
||||
private int getPort() {
|
||||
return port;
|
||||
}
|
||||
|
||||
private void setPort(int port) {
|
||||
this.port = port;
|
||||
}
|
||||
|
||||
public MonitorServer(int port) {
|
||||
this.setPort(port);
|
||||
}
|
||||
|
||||
public boolean start() {
|
||||
try {
|
||||
this.setServer(new Server());
|
||||
Connector connector = new SocketConnector();
|
||||
connector.setPort(this.getPort());
|
||||
this.getServer().addConnector(connector);
|
||||
ServletContextHandler servletContextHandler = new ServletContextHandler();
|
||||
ServletHolder servletHolder = servletContextHandler.addServlet(
|
||||
DispatcherServlet.class, "/");
|
||||
servletHolder.setInitParameter("contextConfigLocation",
|
||||
"classpath*:/application-context.xml");
|
||||
this.getServer().setHandler(servletContextHandler);
|
||||
this.getServer().start();
|
||||
return true;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean stop() {
|
||||
try {
|
||||
if (this.getServer() != null) {
|
||||
this.getServer().stop();
|
||||
}
|
||||
return true;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return false;
|
||||
} finally {
|
||||
this.setServer(null);
|
||||
}
|
||||
}
|
||||
}
|
||||
package org.bench4q.monitor;
|
||||
|
||||
import org.eclipse.jetty.server.Connector;
|
||||
import org.eclipse.jetty.server.Server;
|
||||
import org.eclipse.jetty.server.bio.SocketConnector;
|
||||
import org.eclipse.jetty.servlet.ServletContextHandler;
|
||||
import org.eclipse.jetty.servlet.ServletHolder;
|
||||
import org.springframework.web.servlet.DispatcherServlet;
|
||||
|
||||
public class MonitorServer {
|
||||
private Server server;
|
||||
private int port;
|
||||
|
||||
private Server getServer() {
|
||||
return server;
|
||||
}
|
||||
|
||||
private void setServer(Server server) {
|
||||
this.server = server;
|
||||
}
|
||||
|
||||
private int getPort() {
|
||||
return port;
|
||||
}
|
||||
|
||||
private void setPort(int port) {
|
||||
this.port = port;
|
||||
}
|
||||
|
||||
public MonitorServer(int port) {
|
||||
this.setPort(port);
|
||||
}
|
||||
|
||||
public boolean start() {
|
||||
try {
|
||||
this.setServer(new Server());
|
||||
Connector connector = new SocketConnector();
|
||||
connector.setPort(this.getPort());
|
||||
this.getServer().addConnector(connector);
|
||||
ServletContextHandler servletContextHandler = new ServletContextHandler();
|
||||
ServletHolder servletHolder = servletContextHandler.addServlet(
|
||||
DispatcherServlet.class, "/");
|
||||
servletHolder
|
||||
.setInitParameter("contextConfigLocation",
|
||||
"classpath*:org/bench4q/monitor/config/application-context.xml");
|
||||
this.getServer().setHandler(servletContextHandler);
|
||||
this.getServer().start();
|
||||
return true;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean stop() {
|
||||
try {
|
||||
if (this.getServer() != null) {
|
||||
this.getServer().stop();
|
||||
}
|
||||
return true;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return false;
|
||||
} finally {
|
||||
this.setServer(null);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxCpuProbe {
|
||||
// /proc/stat
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxCpuProbeInfo {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxDiskProbe {
|
||||
// /proc/diskstats
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxDiskProbeInfo {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxMemoryProbe {
|
||||
// /proc/meminfo
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxMemoryProbeInfo {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxNetworkProbe {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.probe;
|
||||
|
||||
public class LinuxNetworkProbeInfo {
|
||||
|
||||
}
|
|
@ -1,180 +1,180 @@
|
|||
package org.bench4q.monitor.service;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.InputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import java.io.LineNumberReader;
|
||||
import java.util.StringTokenizer;
|
||||
|
||||
import sun.management.ManagementFactory;
|
||||
import com.sun.management.OperatingSystemMXBean;
|
||||
|
||||
import org.bench4q.monitor.entity.MonitorInfo;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component
|
||||
public class MonitorService {
|
||||
|
||||
private static final int CPUTIME = 30;
|
||||
private static final int PERCENT = 100;
|
||||
private static final int FAULTLENGTH = 10;
|
||||
|
||||
public MonitorInfo getMonitorInfo() {
|
||||
MonitorInfo monitorInfo = new MonitorInfo();
|
||||
monitorInfo.setTotalVirtualMachineMemory(Runtime.getRuntime()
|
||||
.totalMemory());
|
||||
monitorInfo.setFreeVirtualMachineMemory(Runtime.getRuntime()
|
||||
.freeMemory());
|
||||
monitorInfo
|
||||
.setMaxVirtualMachineMemory(Runtime.getRuntime().maxMemory());
|
||||
monitorInfo.setOperationSystem(System.getProperty("os.name"));
|
||||
OperatingSystemMXBean operatingSystemMXBean = (OperatingSystemMXBean) ManagementFactory
|
||||
.getOperatingSystemMXBean();
|
||||
monitorInfo.setTotalPhysicsMemory(operatingSystemMXBean
|
||||
.getTotalPhysicalMemorySize());
|
||||
monitorInfo.setFreePhysicsMemory(operatingSystemMXBean
|
||||
.getFreePhysicalMemorySize());
|
||||
monitorInfo.setUsedPhysicsMemory(monitorInfo.getTotalPhysicsMemory()
|
||||
- monitorInfo.getFreePhysicsMemory());
|
||||
ThreadGroup parentThread;
|
||||
for (parentThread = Thread.currentThread().getThreadGroup(); parentThread
|
||||
.getParent() != null; parentThread = parentThread.getParent())
|
||||
;
|
||||
double cpuRatio = 0;
|
||||
if (monitorInfo.getOperationSystem().toLowerCase()
|
||||
.startsWith("windows")) {
|
||||
cpuRatio = this.getCpuRatioForWindows();
|
||||
} else {
|
||||
cpuRatio = this.getCpuRatioForLinux();
|
||||
}
|
||||
monitorInfo.setCpuRatio(cpuRatio);
|
||||
return monitorInfo;
|
||||
}
|
||||
|
||||
private double getCpuRatioForLinux() {
|
||||
InputStream is = null;
|
||||
InputStreamReader isr = null;
|
||||
BufferedReader br = null;
|
||||
StringTokenizer tokenStat = null;
|
||||
try {
|
||||
Process process = Runtime.getRuntime().exec("top -b -n 1");
|
||||
is = process.getInputStream();
|
||||
isr = new InputStreamReader(is);
|
||||
br = new BufferedReader(isr);
|
||||
br.readLine();
|
||||
br.readLine();
|
||||
tokenStat = new StringTokenizer(br.readLine());
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
String cpuUsage = tokenStat.nextToken();
|
||||
Float usage = new Float(
|
||||
cpuUsage.substring(0, cpuUsage.indexOf("%")));
|
||||
return (1 - usage.floatValue() / 100);
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return -1;
|
||||
} finally {
|
||||
try {
|
||||
if (is != null) {
|
||||
is.close();
|
||||
}
|
||||
if (isr != null) {
|
||||
isr.close();
|
||||
}
|
||||
if (br != null) {
|
||||
br.close();
|
||||
}
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private double getCpuRatioForWindows() {
|
||||
try {
|
||||
String procCmd = System.getenv("windir")
|
||||
+ "\\system32\\wbem\\wmic.exe process get Caption,CommandLine,"
|
||||
+ "KernelModeTime,ReadOperationCount,ThreadCount,UserModeTime,WriteOperationCount";
|
||||
// È¡½ø³ÌÐÅÏ¢
|
||||
long[] c0 = readCpu(Runtime.getRuntime().exec(procCmd));
|
||||
Thread.sleep(CPUTIME);
|
||||
long[] c1 = readCpu(Runtime.getRuntime().exec(procCmd));
|
||||
if (c0 != null && c1 != null) {
|
||||
long idletime = c1[0] - c0[0];
|
||||
long busytime = c1[1] - c0[1];
|
||||
return Double.valueOf(
|
||||
PERCENT * (busytime) / (busytime + idletime))
|
||||
.doubleValue();
|
||||
} else {
|
||||
return 0.0;
|
||||
}
|
||||
} catch (Exception ex) {
|
||||
ex.printStackTrace();
|
||||
return 0.0;
|
||||
}
|
||||
}
|
||||
|
||||
private long[] readCpu(final Process proc) {
|
||||
long[] retn = new long[2];
|
||||
try {
|
||||
proc.getOutputStream().close();
|
||||
InputStreamReader ir = new InputStreamReader(proc.getInputStream());
|
||||
LineNumberReader input = new LineNumberReader(ir);
|
||||
String line = input.readLine();
|
||||
if (line == null || line.length() < FAULTLENGTH) {
|
||||
return null;
|
||||
}
|
||||
int capidx = line.indexOf("Caption");
|
||||
int cmdidx = line.indexOf("CommandLine");
|
||||
int rocidx = line.indexOf("ReadOperationCount");
|
||||
int umtidx = line.indexOf("UserModeTime");
|
||||
int kmtidx = line.indexOf("KernelModeTime");
|
||||
int wocidx = line.indexOf("WriteOperationCount");
|
||||
long idletime = 0;
|
||||
long kneltime = 0;
|
||||
long usertime = 0;
|
||||
while ((line = input.readLine()) != null) {
|
||||
if (line.length() < wocidx) {
|
||||
continue;
|
||||
}
|
||||
|
||||
String caption = line.substring(capidx, cmdidx - 1).trim();
|
||||
String cmd = line.substring(cmdidx, kmtidx - 1).trim();
|
||||
if (cmd.indexOf("wmic.exe") >= 0) {
|
||||
continue;
|
||||
}
|
||||
if (caption.equals("System Idle Process")
|
||||
|| caption.equals("System")) {
|
||||
idletime += Long.valueOf(
|
||||
line.substring(kmtidx, rocidx - 1).trim())
|
||||
.longValue();
|
||||
idletime += Long.valueOf(
|
||||
line.substring(umtidx, wocidx - 1).trim())
|
||||
.longValue();
|
||||
continue;
|
||||
}
|
||||
kneltime += Long.valueOf(
|
||||
line.substring(kmtidx, rocidx - 1).trim()).longValue();
|
||||
usertime += Long.valueOf(
|
||||
line.substring(umtidx, wocidx - 1).trim()).longValue();
|
||||
}
|
||||
retn[0] = idletime;
|
||||
retn[1] = kneltime + usertime;
|
||||
return retn;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return null;
|
||||
} finally {
|
||||
try {
|
||||
proc.getInputStream().close();
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
package org.bench4q.monitor.service;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.InputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import java.io.LineNumberReader;
|
||||
import java.lang.management.ManagementFactory;
|
||||
import java.util.StringTokenizer;
|
||||
|
||||
import com.sun.management.OperatingSystemMXBean;
|
||||
|
||||
import org.bench4q.monitor.entity.MonitorInfo;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component
|
||||
public class MonitorService {
|
||||
|
||||
private static final int CPUTIME = 30;
|
||||
private static final int PERCENT = 100;
|
||||
private static final int FAULTLENGTH = 10;
|
||||
|
||||
public MonitorInfo getMonitorInfo() {
|
||||
MonitorInfo monitorInfo = new MonitorInfo();
|
||||
monitorInfo.setTotalVirtualMachineMemory(Runtime.getRuntime()
|
||||
.totalMemory());
|
||||
monitorInfo.setFreeVirtualMachineMemory(Runtime.getRuntime()
|
||||
.freeMemory());
|
||||
monitorInfo
|
||||
.setMaxVirtualMachineMemory(Runtime.getRuntime().maxMemory());
|
||||
monitorInfo.setOperationSystem(System.getProperty("os.name"));
|
||||
OperatingSystemMXBean operatingSystemMXBean = (OperatingSystemMXBean) ManagementFactory
|
||||
.getOperatingSystemMXBean();
|
||||
monitorInfo.setTotalPhysicsMemory(operatingSystemMXBean
|
||||
.getTotalPhysicalMemorySize());
|
||||
monitorInfo.setFreePhysicsMemory(operatingSystemMXBean
|
||||
.getFreePhysicalMemorySize());
|
||||
monitorInfo.setUsedPhysicsMemory(monitorInfo.getTotalPhysicsMemory()
|
||||
- monitorInfo.getFreePhysicsMemory());
|
||||
ThreadGroup parentThread;
|
||||
for (parentThread = Thread.currentThread().getThreadGroup(); parentThread
|
||||
.getParent() != null; parentThread = parentThread.getParent())
|
||||
;
|
||||
double cpuRatio = 0;
|
||||
if (monitorInfo.getOperationSystem().toLowerCase()
|
||||
.startsWith("windows")) {
|
||||
cpuRatio = this.getCpuRatioForWindows();
|
||||
} else {
|
||||
cpuRatio = this.getCpuRatioForLinux();
|
||||
}
|
||||
monitorInfo.setCpuRatio(cpuRatio);
|
||||
return monitorInfo;
|
||||
}
|
||||
|
||||
private double getCpuRatioForLinux() {
|
||||
InputStream is = null;
|
||||
InputStreamReader isr = null;
|
||||
BufferedReader br = null;
|
||||
StringTokenizer tokenStat = null;
|
||||
try {
|
||||
Process process = Runtime.getRuntime().exec("top -b -n 1");
|
||||
is = process.getInputStream();
|
||||
isr = new InputStreamReader(is);
|
||||
br = new BufferedReader(isr);
|
||||
br.readLine();
|
||||
br.readLine();
|
||||
tokenStat = new StringTokenizer(br.readLine());
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
tokenStat.nextToken();
|
||||
String cpuUsage = tokenStat.nextToken();
|
||||
Float usage = new Float(
|
||||
cpuUsage.substring(0, cpuUsage.indexOf("%")));
|
||||
return (1 - usage.floatValue() / 100);
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return -1;
|
||||
} finally {
|
||||
try {
|
||||
if (is != null) {
|
||||
is.close();
|
||||
}
|
||||
if (isr != null) {
|
||||
isr.close();
|
||||
}
|
||||
if (br != null) {
|
||||
br.close();
|
||||
}
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private double getCpuRatioForWindows() {
|
||||
try {
|
||||
String procCmd = System.getenv("windir")
|
||||
+ "\\system32\\wbem\\wmic.exe process get Caption,CommandLine,"
|
||||
+ "KernelModeTime,ReadOperationCount,ThreadCount,UserModeTime,WriteOperationCount";
|
||||
// È¡½ø³ÌÐÅÏ¢
|
||||
long[] c0 = readCpu(Runtime.getRuntime().exec(procCmd));
|
||||
Thread.sleep(CPUTIME);
|
||||
long[] c1 = readCpu(Runtime.getRuntime().exec(procCmd));
|
||||
if (c0 != null && c1 != null) {
|
||||
long idletime = c1[0] - c0[0];
|
||||
long busytime = c1[1] - c0[1];
|
||||
return Double.valueOf(
|
||||
PERCENT * (busytime) / (busytime + idletime))
|
||||
.doubleValue();
|
||||
} else {
|
||||
return 0.0;
|
||||
}
|
||||
} catch (Exception ex) {
|
||||
ex.printStackTrace();
|
||||
return 0.0;
|
||||
}
|
||||
}
|
||||
|
||||
private long[] readCpu(final Process proc) {
|
||||
long[] retn = new long[2];
|
||||
try {
|
||||
proc.getOutputStream().close();
|
||||
InputStreamReader ir = new InputStreamReader(proc.getInputStream());
|
||||
LineNumberReader input = new LineNumberReader(ir);
|
||||
String line = input.readLine();
|
||||
if (line == null || line.length() < FAULTLENGTH) {
|
||||
return null;
|
||||
}
|
||||
int capidx = line.indexOf("Caption");
|
||||
int cmdidx = line.indexOf("CommandLine");
|
||||
int rocidx = line.indexOf("ReadOperationCount");
|
||||
int umtidx = line.indexOf("UserModeTime");
|
||||
int kmtidx = line.indexOf("KernelModeTime");
|
||||
int wocidx = line.indexOf("WriteOperationCount");
|
||||
long idletime = 0;
|
||||
long kneltime = 0;
|
||||
long usertime = 0;
|
||||
while ((line = input.readLine()) != null) {
|
||||
if (line.length() < wocidx) {
|
||||
continue;
|
||||
}
|
||||
|
||||
String caption = line.substring(capidx, cmdidx - 1).trim();
|
||||
String cmd = line.substring(cmdidx, kmtidx - 1).trim();
|
||||
if (cmd.indexOf("wmic.exe") >= 0) {
|
||||
continue;
|
||||
}
|
||||
if (caption.equals("System Idle Process")
|
||||
|| caption.equals("System")) {
|
||||
idletime += Long.valueOf(
|
||||
line.substring(kmtidx, rocidx - 1).trim())
|
||||
.longValue();
|
||||
idletime += Long.valueOf(
|
||||
line.substring(umtidx, wocidx - 1).trim())
|
||||
.longValue();
|
||||
continue;
|
||||
}
|
||||
kneltime += Long.valueOf(
|
||||
line.substring(kmtidx, rocidx - 1).trim()).longValue();
|
||||
usertime += Long.valueOf(
|
||||
line.substring(umtidx, wocidx - 1).trim()).longValue();
|
||||
}
|
||||
retn[0] = idletime;
|
||||
retn[1] = kneltime + usertime;
|
||||
return retn;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
return null;
|
||||
} finally {
|
||||
try {
|
||||
proc.getInputStream().close();
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<beans xmlns="http://www.springframework.org/schema/beans"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
|
||||
xmlns:mvc="http://www.springframework.org/schema/mvc"
|
||||
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
|
||||
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
|
||||
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">
|
||||
<context:component-scan base-package="org.bench4q" />
|
||||
<mvc:annotation-driven />
|
||||
</beans>
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<beans xmlns="http://www.springframework.org/schema/beans"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
|
||||
xmlns:mvc="http://www.springframework.org/schema/mvc"
|
||||
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
|
||||
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
|
||||
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">
|
||||
<context:component-scan base-package="org.bench4q" />
|
||||
<mvc:annotation-driven />
|
||||
</beans>
|
|
@ -0,0 +1,5 @@
|
|||
package org.bench4q.monitor.test;
|
||||
|
||||
public class MonitorServiceTest {
|
||||
|
||||
}
|
Loading…
Reference in New Issue