利用java程序实现获取计算机cpu利用率和内存使用信息。
1、
创建一个Bean用来存贮要得到的信
public
class
MonitorInfoBean {
/** 可使用内存. */
private
long
totalMemory;
/** 剩余内存. */
private
long
freeMemory;
/** 最大可使用内存. */
private
long
maxMemory;
/** 操作系统. */
private
String osName;
/** 总的物理内存. */
private
long
totalMemorySize;
/** 剩余的物理内存. */
private
long
freePhysicalMemorySize;
/** 已使用的物理内存. */
private
long
usedMemory;
/** 线程总数. */
private
int
totalThread;
/** cpu使用率. */
private
double
cpuRatio;
public
long
getFreeMemory() {
return
freeMemory;
}
public
void
setFreeMemory(
long
freeMemory) {
this
.freeMemory = freeMemory;
}
public
long
getFreePhysicalMemorySize() {
return
freePhysicalMemorySize;
}
public
void
setFreePhysicalMemorySize(
long
freePhysicalMemorySize) {
this
.freePhysicalMemorySize = freePhysicalMemorySize;
}
public
long
getMaxMemory() {
return
maxMemory;
}
public
void
setMaxMemory(
long
maxMemory) {
this
.maxMemory = maxMemory;
}
public
String getOsName() {
return
osName;
}
public
void
setOsName(String osName) {
this
.osName = osName;
}
public
long
getTotalMemory() {
return
totalMemory;
}
public
void
setTotalMemory(
long
totalMemory) {
this
.totalMemory = totalMemory;
}
public
long
getTotalMemorySize() {
return
totalMemorySize;
}
public
void
setTotalMemorySize(
long
totalMemorySize) {
this
.totalMemorySize = totalMemorySize;
}
public
int
getTotalThread() {
return
totalThread;
}
public
void
setTotalThread(
int
totalThread) {
this
.totalThread = totalThread;
}
public
long
getUsedMemory() {
return
usedMemory;
}
public
void
setUsedMemory(
long
usedMemory) {
this
.usedMemory = usedMemory;
}
public
double
getCpuRatio() {
return
cpuRatio;
}
public
void
setCpuRatio(
double
cpuRatio) {
this
.cpuRatio = cpuRatio;
}
}
之后,建立bean的接口
public
interface
IMonitorService {
public
MonitorInfoBean getMonitorInfoBean()
throws
Exception;
}
然后,就是最关键的,得到cpu的利用率,已用内存,可用内存,最大内存等信息。
import
java.io.InputStreamReader;
import
java.io.LineNumberReader;
import
sun.management.ManagementFactory;
import
com.sun.management.OperatingSystemMXBean;
import
java.io.*;
import
java.util.StringTokenizer;
/**
* 获取系统信息的业务逻辑实现类.
* @author GuoHuang
*/
public
class
MonitorServiceImpl
implements
IMonitorService {
private
static
final
int
CPUTIME =
30
;
private
static
final
int
PERCENT =
100
;
private
static
final
int
FAULTLENGTH =
10
;
private
static
final
File versionFile =
new
File(
"/proc/version"
);
private
static
String linuxVersion =
null
;
/**
* 获得当前的监控对象.
* @return 返回构造好的监控对象
* @throws Exception
* @author GuoHuang
*/
public
MonitorInfoBean getMonitorInfoBean()
throws
Exception {
int
kb =
1024
;
// 可使用内存
long
totalMemory = Runtime.getRuntime().totalMemory() / kb;
// 剩余内存
long
freeMemory = Runtime.getRuntime().freeMemory() / kb;
// 最大可使用内存
long
maxMemory = Runtime.getRuntime().maxMemory() / kb;
OperatingSystemMXBean osmxb = (OperatingSystemMXBean) ManagementFactory
.getOperatingSystemMXBean();
// 操作系统
String osName = System.getProperty(
"os.name"
);
// 总的物理内存
long
totalMemorySize = osmxb.getTotalPhysicalMemorySize() / kb;
// 剩余的物理内存
long
freePhysicalMemorySize = osmxb.getFreePhysicalMemorySize() / kb;
// 已使用的物理内存
long
usedMemory = (osmxb.getTotalPhysicalMemorySize() - osmxb
.getFreePhysicalMemorySize())
/ kb;
// 获得线程总数
ThreadGroup parentThread;
for
(parentThread = Thread.currentThread().getThreadGroup(); parentThread
.getParent() !=
null
; parentThread = parentThread.getParent())
;
int
totalThread = parentThread.activeCount();
double
cpuRatio =
0
;
if
(osName.toLowerCase().startsWith(
"windows"
)) {
cpuRatio =
this
.getCpuRatioForWindows();
}
else
{
cpuRatio =
this
.getCpuRateForLinux();
}
// 构造返回对象
MonitorInfoBean infoBean =
new
MonitorInfoBean();
infoBean.setFreeMemory(freeMemory);
infoBean.setFreePhysicalMemorySize(freePhysicalMemorySize);
infoBean.setMaxMemory(maxMemory);
infoBean.setOsName(osName);
infoBean.setTotalMemory(totalMemory);
infoBean.setTotalMemorySize(totalMemorySize);
infoBean.setTotalThread(totalThread);
infoBean.setUsedMemory(usedMemory);
infoBean.setCpuRatio(cpuRatio);
return
infoBean;
}
private
static
double
getCpuRateForLinux(){
InputStream is =
null
;
InputStreamReader isr =
null
;
BufferedReader brStat =
null
;
StringTokenizer tokenStat =
null
;
try
{
System.out.println(
"Get usage rate of CUP , linux version: "
+linuxVersion);
Process process = Runtime.getRuntime().exec(
"top -b -n 1"
);
is = process.getInputStream();
isr =
new
InputStreamReader(is);
brStat =
new
BufferedReader(isr);
if
(linuxVersion.equals(
"2.4"
)){
brStat.readLine();
brStat.readLine();
brStat.readLine();
brStat.readLine();
tokenStat =
new
StringTokenizer(brStat.readLine());
tokenStat.nextToken();
tokenStat.nextToken();
String user = tokenStat.nextToken();
tokenStat.nextToken();
String system = tokenStat.nextToken();
tokenStat.nextToken();
String nice = tokenStat.nextToken();
System.out.println(user+
" , "
+system+
" , "
+nice);
user = user.substring(
0
,user.indexOf(
"%"
));
system = system.substring(
0
,system.indexOf(
"%"
));
nice = nice.substring(
0
,nice.indexOf(
"%"
));
float
userUsage =
new
Float(user).floatValue();
float
systemUsage =
new
Float(system).floatValue();
float
niceUsage =
new
Float(nice).floatValue();
return
(userUsage+systemUsage+niceUsage)/
100
;
}
else
{
brStat.readLine();
brStat.readLine();
tokenStat =
new
StringTokenizer(brStat.readLine());
tokenStat.nextToken();
tokenStat.nextToken();
tokenStat.nextToken();
tokenStat.nextToken();
tokenStat.nextToken();
tokenStat.nextToken();
tokenStat.nextToken();
String cpuUsage = tokenStat.nextToken();
System.out.println(
"CPU idle : "
+cpuUsage);
Float usage =
new
Float(cpuUsage.substring(
0
,cpuUsage.indexOf(
"%"
)));
return
(
1
-usage.floatValue()/
100
);
}
}
catch
(IOException ioe){
System.out.println(ioe.getMessage());
freeResource(is, isr, brStat);
return
1
;
}
finally
{
freeResource(is, isr, brStat);
}
}
private
static
void
freeResource(InputStream is, InputStreamReader isr, BufferedReader br){
try
{
if
(is!=
null
)
is.close();
if
(isr!=
null
)
isr.close();
if
(br!=
null
)
br.close();
}
catch
(IOException ioe){
System.out.println(ioe.getMessage());
}
}
/**
* 获得CPU使用率.
* @return 返回cpu使用率
* @author GuoHuang
*/
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
;
}
}
/**
* 读取CPU信息.
* @param proc
* @return
* @author GuoHuang
*/
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
;
}
// 字段出现顺序:Caption,CommandLine,KernelModeTime,ReadOperationCount,
// ThreadCount,UserModeTime,WriteOperation
String caption = Bytes.substring(line, capidx, cmdidx -
1
)
.trim();
String cmd = Bytes.substring(line, cmdidx, kmtidx -
1
).trim();
if
(cmd.indexOf(
"wmic.exe"
) >=
0
) {
continue
;
}
// log.info("line="+line);
if
(caption.equals(
"System Idle Process"
)
|| caption.equals(
"System"
)) {
idletime += Long.valueOf(
Bytes.substring(line, kmtidx, rocidx -
1
).trim())
.longValue();
idletime += Long.valueOf(
Bytes.substring(line, umtidx, wocidx -
1
).trim())
.longValue();
continue
;
}
kneltime += Long.valueOf(
Bytes.substring(line, kmtidx, rocidx -
1
).trim())
.longValue();
usertime += Long.valueOf(
Bytes.substring(line, umtidx, wocidx -
1
).trim())
.longValue();
}
retn[
0
] = idletime;
retn[
1
] = kneltime + usertime;
return
retn;
}
catch
(Exception ex) {
ex.printStackTrace();
}
finally
{
try
{
proc.getInputStream().close();
}
catch
(Exception e) {
e.printStackTrace();
}
}
return
null
;
}
/** 测试方法.
* @param args
* @throws Exception
* @author GuoHuang
*/
public
static
void
main(String[] args)
throws
Exception {
IMonitorService service =
new
MonitorServiceImpl();
MonitorInfoBean monitorInfo = service.getMonitorInfoBean();
System.out.println(
"cpu占有率="
+ monitorInfo.getCpuRatio());
System.out.println(
"可使用内存="
+ monitorInfo.getTotalMemory());
System.out.println(
"剩余内存="
+ monitorInfo.getFreeMemory());
System.out.println(
"最大可使用内存="
+ monitorInfo.getMaxMemory());
System.out.println(
"操作系统="
+ monitorInfo.getOsName());
System.out.println(
"总的物理内存="
+ monitorInfo.getTotalMemorySize() +
"kb"
);
System.out.println(
"剩余的物理内存="
+ monitorInfo.getFreeMemory() +
"kb"
);
System.out.println(
"已使用的物理内存="
+ monitorInfo.getUsedMemory() +
"kb"
);
System.out.println(
"线程总数="
+ monitorInfo.getTotalThread() +
"kb"
);
}
}
其中,Bytes类用来处理字符串
public
class
Bytes {
public
static
String substring(String src,
int
start_idx,
int
end_idx){
byte
[] b = src.getBytes();
String tgt =
""
;
for
(
int
i=start_idx; i<=end_idx; i++){
tgt +=(
char
)b[i];
}
return
tgt;
}
}
相关推荐
java 获取计算机cpu利用率和内存使用信息,需要的自己下载测试吧。
Java 程序实现获取计算机 CPU 利用率和内存使用信息 本篇文章主要讲述了使用 Java 语言实现获取计算机 CPU 利用率和内存使用信息的方法。下面将详细介绍如何使用 Java 程序获取计算机的 CPU 利用率和内存使用信息。...
java程序实现获取计算机cpu利用率和内存使用信息
在Java编程中,获取计算机的硬件信息,如CPU使用率和内存使用情况,是一项常见的需求。这主要应用于系统监控、性能分析以及资源管理等方面。Java虽然不像C++或C#那样可以直接调用操作系统API,但它提供了Java ...
通过上述步骤,我们可以在不使用JNI的情况下,利用Java语言本身的能力获取到系统的CPU使用率及内存使用情况。这种方式不仅简单高效,而且对于开发者的技能要求相对较低,非常适合用于日常的应用程序监控场景。需要...
在IT领域,实时监控系统资源,尤其是CPU使用率和内存使用情况,对于开发者和系统管理员来说至关重要。这有助于诊断性能瓶颈、优化代码以及确保系统的稳定运行。以下是对标题和描述中涉及的知识点的详细说明: 1. **...
本文将深入探讨如何利用C#编程语言,通过WMI来获取远程服务器的CPU和内存使用率,以解决Win32_LogicalMemoryConfiguration类可能存在的问题。 首先,我们要了解WMI的工作原理。WMI是基于Common Information Model ...
首先,CPU利用率是指CPU在单位时间内处于忙碌状态的比例,它反映了系统处理任务的能力。如果CPU利用率过高,可能会导致系统响应变慢,因为CPU无法及时处理新的请求。而内存利用率则是指系统中被分配并使用的物理内存...
System.out.println("CPU利用率: " + cpu.getTotal() + "%"); ``` 接着,我们来看如何获取内存信息。Java的`com.sun.management.OperatingSystemMXBean`类提供了一些方法来获取系统内存和Java堆内存的信息。例如,...
"模拟CPU利用率的曲线"这个项目提供了一个直观的工具,其效果与Windows系统内置的性能监视器相似,允许用户自定义显示样式,以满足不同的监控需求。 首先,我们需要理解CPU利用率的概念。CPU利用率是指CPU在一段...
通过SIGAR,开发者可以轻松地获取到关于CPU利用率、内存状态、磁盘使用、网络流量等多种系统信息。这对于系统管理员来说,是一个极其便利的工具,能够帮助他们实时监控系统的运行状况,及时发现和处理问题。 CPU...
此方法适用于JDK 1.6及更高版本,可以获取更详细的系统信息,如CPU使用率、内存使用情况和文件系统状态等。 ```java import java.io.InputStreamReader; import java.io.LineNumberReader; import java.util....
在IT领域,CPU使用率是衡量计算机性能的重要指标之一,特别是在服务器管理和系统优化的过程中。本文将深入探讨如何在Windows操作系统中计算每个CPU的核心使用率,以及这个知识点在实际应用中的重要性。 首先,CPU...
- GPU占用率:NVIDIA和AMD提供了各自的SDK,如NVIDIA的NVAPI和AMD的AMDKMT,可以获取GPU利用率信息。对于非专业开发者,也可以使用WMI(Windows Management Instrumentation)查询GPU状态。 3. **风扇转速监控**:...
CPU利用率是指CPU在一段时间内处于忙碌状态的比例,高利用率可能意味着系统负载过重。负载则是指系统在特定时间内处理的任务数量,如果负载过高,可能导致响应速度变慢。上下文切换是指CPU在不同进程间切换,频繁的...
通过这些基础知识点的学习,网络管理员可以利用Java语言和SNMP4J库完成服务器监控的工作,比如监控服务器的CPU负载、内存使用情况、磁盘空间以及各种网络接口的状态等。这对于维护服务器的稳定运行和及时发现网络...
在硬件信息获取方面,Java提供了一些库和API,例如Java Management Extensions (JMX) 和 sun.misc包,这些可以帮助开发者获取CPU使用率、内存使用情况等硬件信息。通过这些工具,用户可以监控系统的健康状况,分析...
在Kubernetes集群中,可以借助`kubectl top`命令或Prometheus监控系统获取节点和Pod的内存使用信息。 理解内存使用状态不仅仅是查看总的使用量,还包括空闲内存、缓存内存、交换空间等细节。缓存内存是操作系统用于...
通过Sigar,我们可以获取每个CPU核心的使用时间,以及整体的CPU利用率。此外,还可以监控进程级别的CPU使用,找出消耗CPU资源最多的进程。 2. **内存使用情况**:内存是计算机临时存储数据的地方,内存使用情况直接...
3. **内存监控**:通过内置的系统调用或者第三方库(如Python的`psutil`库),程序可以获取和记录内存使用情况,包括总内存、已用内存、空闲内存和交换内存等信息。 4. **性能指标**:可能包含计算和显示内存和缓存...