用到一个插件hyperic-sigar

1:下载hyperic-sigar后解压,把sigar-amd64-winnt.dll(64位机器,32位用sigar-x86-winnt.dll)放到你本机的jdk\bin、jdk\jre\bin、jre\bin目录下。

2:maven引入hyperic-sigar依赖,这样就可以用了。

         <dependency>
<groupId>org.fusesource</groupId>
<artifactId>sigar</artifactId>
<version>1.6.4</version>
</dependency>

3:hyperic-sigar解压后到hyperic-sigar-1.6.4\bindings\java\examples目录下这里面有很多官方提供的例子,可以直接复制到你的工程下运行测试。


我用的是websocket+java-timer做的。

 public class KeepRunTime extends TimerTask {

     private static Sigar sigar = new Sigar();  

     @Override
public void run() {
RunTime rt = new RunTime();
rt.setMem(mem());
rt.setCpus(cpu()); DataPushService.pushData(JSONObject.toJSONString(new WebMessage(rt, WebMessage.RUNTIME)));
} // CPU使用率
public static TreeSet<Cpu> cpu() {
try {
TreeSet<Cpu> cpus = new TreeSet<Cpu>();
CpuPerc[] list = sigar.getCpuPercList();
for (int i=1; i<list.length+1; i++) {
Cpu cpu = new Cpu();
cpu.setNo(i);
cpu.setCpuName("CPU-"+i);
cpu.setCpuCombined(CpuPerc.format(list[i-1].getCombined()));
cpus.add(cpu);
}
return cpus;
} catch (SigarException e) {
System.err.println("获取CPU使用率异常");
e.printStackTrace();
return null;
}
} // MEM使用率
public static String mem() {
try {
Mem mem = sigar.getMem();
// 内存总量
Long memTotal = mem.getTotal() / 1024L;
// 当前内存使用量
Long memUsed = mem.getUsed() / 1024L;
// 使用率
Double usePercent = ((memUsed*1.0)/memTotal)*100;
// 四舍五入
return String.format("%.2f", usePercent);
} catch (SigarException e) {
System.err.println("获取MEM使用率异常");
e.printStackTrace();
return null;
}
} }
 public class RunTime {

     // 内存使用率
private String mem;
// CPU使用率
private TreeSet<Cpu> cpus; public String getMem() {
return mem;
}
public void setMem(String mem) {
this.mem = mem;
}
public TreeSet<Cpu> getCpus() {
return cpus;
}
public void setCpus(TreeSet<Cpu> cpus) {
this.cpus = cpus;
} @Override
public String toString() {
return "RunTime [mem=" + mem + ", cpus=" + cpus + "]";
} }
 public class Cpu implements Comparable<Cpu>{

     private int no;

     private String cpuName;

     private String cpuCombined;

     public int getNo() {
return no;
} public void setNo(int no) {
this.no = no;
} public String getCpuName() {
return cpuName;
} public void setCpuName(String cpuName) {
this.cpuName = cpuName;
} public String getCpuCombined() {
return cpuCombined;
} public void setCpuCombined(String cpuCombined) {
this.cpuCombined = cpuCombined;
} // 正序
@Override
public int compareTo(Cpu o) {
return (this.no - o.no);
} @Override
public String toString() {
return "Cpu [no=" + no + ", cpuName=" + cpuName + ", cpuCombined="
+ cpuCombined + "]";
} }

js:

 var runtime = function(data) {
$("#mem").html(data.obj.mem + '%'); var cpus = data.obj.cpus;
var html = "<p>";
for (var i = 1; i < cpus.length + 1; i++) {
html += "<b>" + cpus[i-1].cpuName + ":</b>" +
"<span class='runtime' id='span-cpu'>"+ cpus[i-1].cpuCombined + "</span>";
if (i % 2 == 0) {
html += "</p><p>";
}
}
$("#cpu").html(html);
};

效果:

这里面用了websocket,没提出来具体的代码。

下次我写一个基于netty、websocket.io、springmvc、mybatis、h2database、httpclient、fastjson、https的整合,我现在就在写这样一个项目,等写好了做一个简化版的发上来。

java web 监控cpu、内存等。hyperic-sigar的更多相关文章

  1. centos8平台使用pidstat监控cpu/内存/io

    一,安装pidstat: 1,安装 [root@localhost yum.repos.d]# yum install sysstat 2,查看版本: [root@localhost ~]# pids ...

  2. shell脚本监控cpu/内存使用率 转

    该脚本检测cpu和内存的使用情况,只需要调整memorySetting.cpuSetting.userEmail要发邮件报警的email地址即可 如果没有配置发邮件参数的哥们,已配置了的,直接飞到代码 ...

  3. python监控CPU/内存/磁盘,超过指定百分比,发送邮件

    #!/usr/bin/python #coding:utf-8 #导入psutil模块 import psutil import yagmail def mail(subject,contents): ...

  4. python监控cpu 内存实现邮件微信报警

    # qianxiao996精心制作 #博客地址:https://blog.csdn.net/qq_36374896 import psutil, time,smtplib,socket import ...

  5. linux 监控CPU 内存情况

    htop

  6. Java系统监控(淘汰sigar)

    Sigar是Hyperic-hq产品的基础包,是Hyperic HQ主要的数据收集组件.它用来从许多平台收集系统和处理信息. 这些平台包括:Linux, Windows, Solaris, AIX, ...

  7. java使用siger 获取服务器硬件信息(CPU 内存 网络 io等)

    通过使用第三方开源jar包sigar.jar我们可以获得本地的信息 1.下载sigar.jar sigar官方主页 sigar-1.6.4.zip 2.按照主页上的说明解压包后将相应的文件copy到j ...

  8. java sigar获取本地信息以及org.hyperic.sigar.SigarException: The device is not ready报错解决

    window下,使用java sigar 获取磁盘使用率,cpu使用率以及内存使用情况等信息时. 一:首先需要下载jar包和相关文件 sigar-1.6.4.zip 如果想了解更多可以去 sigar官 ...

  9. Java虚拟机二:使用jvisualvm工具远程监控tomcat内存

    jdk中自带了很多工具可以用于性能分析,位于jdk的bin目录下,jvisualvm工具可以以图形化的方式更加直观的监控本地以及远程的java进程的内存占用,线程状态等信息. 一.配置tomcat 在 ...

随机推荐

  1. iOS textFiledView,label自适应高度

    CGSize constraintSize; constraintSize.width = 320; constraintSize.height = MAXFLOAT; CGSize sizeFram ...

  2. 数据标记系列——图像分割 & Curve-GCN

    在之前的文章中(参考:),我们提到了Polygon-RNN++在数据标注中的应用.今天不得不提到多伦多大学与英伟达联合公布的一项最新研究:Curve-GCN的应用结果显示图像标注速度提升10倍. Cu ...

  3. FormsAuthentication使用指南

    配置安全鉴别 鉴别是指鉴定来访用户是否合法的过程.ASP.NET Framework支持三种鉴别类型: Windows鉴别: NET Passport鉴别: Forms鉴别. 对于某一特定的应用程序, ...

  4. 【Leetcode_easy】1025. Divisor Game

    problem 1025. Divisor Game 参考 1. Leetcode_easy_1025. Divisor Game; 完

  5. IE6/IE7/IE8 JQuery下resize事件执行多次的解决方法

    在使用jQuery的resize事件时发现每次改变浏览器的窗口大小时resize时间会执行两次,百度搜索了一下找到一个解决的方法,使用setTimeout来解决这个问题代码如下: var resize ...

  6. 解决javascript - node and Error: EMFILE, too many open files

    For some days I have searched for a working solution to an error Error: EMFILE, too many open files ...

  7. CentOS8安装docker

    参考:https://www.cnblogs.com/ding2016/p/11592999.html 一,安装环境查看 二,下载docker-ce的repo curl https://downloa ...

  8. Word中如何加载EndNote

    在百度中搜索了很多解决方案,都不尽相同忙了一上午也没解决,然后搁浅,吃过午饭回来在安装目录下找到如下exe文件三四步点击搞定 所以,有时候问题出现了长时间没解决,可以换下环境出去溜达一圈说不定就茅塞顿 ...

  9. Charles 抓包配置

    本文参考:charles 抓包配置 proxy setting (代理设置) 设置的主界面如下: 动态端口 启用动态端口选项来监听动态端口,每次查询启动时选择.这样可以避免与计算机上可能运行的其他网络 ...

  10. 微信浏览器内建的WeixinJSBridge 实现“返回”操作

    微信浏览器内建的WeixinJSBridge 实现“返回”操作 WeixinJSBridge.call('closeWindow');