如何监视计算机的CPU,内存和磁盘使用情况在Java中

如何监视计算机的CPU,内存和磁盘使用情况在Java中,第1张

使用sigar来监控,简单方便!

使用说明:以下代码需要配合sigar的dll文件来用,需要将dll文件放到JDK下的bin文件夹下,供sigar程序调用,还需要sigar jar包。以下程序经过测试,完全可用!

 

有关jar包跟dll文件  我上传不了,私信我,我发你

 

 

 

import java.net.InetAddress

import java.net.UnknownHostException

import java.util.Map

import java.util.Properties

import java.util.Timer

import java.util.TimerTask

 

import org.hyperic.sigar.CpuInfo

import org.hyperic.sigar.CpuPerc

import org.hyperic.sigar.FileSystem

import org.hyperic.sigar.FileSystemUsage

import org.hyperic.sigar.Mem

import org.hyperic.sigar.NetFlags

import org.hyperic.sigar.NetInterfaceConfig

import org.hyperic.sigar.NetInterfaceStat

import org.hyperic.sigar.OperatingSystem

import org.hyperic.sigar.Sigar

import org.hyperic.sigar.SigarException

import org.hyperic.sigar.Swap

import org.hyperic.sigar.Who

 

public class RuntimeTest {

    public static void main(String[] args) {

        try { 

            Timer timer = new Timer()//定时器

            TimerTask task = new TimerTask(){

                public void run() {

                    try {

                        memory()

                    } catch (SigarException e) {

                        e.printStackTrace()

                    }

                }

            }

            try{

            timer.schedule(task, 0, 3000)//每3秒取一次

            }catch(Exception ex){

                ex.printStackTrace()

            }

            // System信息,从jvm获取

           // property()//根据自己的需求,都可以放到定时器中定时获取

            // cpu信息

            //cpu()

            // 内存信息

           // memory()

            //  *** 作系统信息

          //  os()

            // 用户信息

          //  who()

            

            

            

        } catch (Exception e1) {

            e1.printStackTrace()

        }

    }

  

    private static void property() throws UnknownHostException {

        Runtime r = Runtime.getRuntime()

        Properties props = System.getProperties()

        InetAddress addr

        addr = InetAddress.getLocalHost()

        String ip = addr.getHostAddress()

        Map<String, String> map = System.getenv()

        String userName = map.get("USERNAME")// 获取用户名

        String computerName = map.get("COMPUTERNAME")// 获取计算机名

        String userDomain = map.get("USERDOMAIN")// 获取计算机域名

        System.out.println("用户名:    " + userName)

        System.out.println("计算机名:   " + computerName)

        System.out.println("计算机域名:  " + userDomain)

        System.out.println("本地ip地址: " + ip)

        System.out.println("本地主机名:  " + addr.getHostName())

        System.out.println("JVM可以使用的总内存:    " + r.totalMemory())

        System.out.println("JVM可以使用的剩余内存:   " + r.freeMemory())

        System.out.println("JVM可以使用的处理器个数:  " + r.availableProcessors())

        System.out.println("Java的运行环境版本:    " + props.getProperty("java.version"))

        System.out.println("Java的运行环境供应商:   " + props.getProperty("java.vendor"))

        System.out.println("Java供应商的URL:    " + props.getProperty("java.vendor.url"))

        System.out.println("Java的安装路径:  " + props.getProperty("java.home"))

        System.out.println("Java的虚拟机规范版本:   " + props.getProperty("java.vm.specification.version"))

        System.out.println("Java的虚拟机规范供应商:  " + props.getProperty("java.vm.specification.vendor"))

        System.out.println("Java的虚拟机规范名称:   " + props.getProperty("java.vm.specification.name"))

        System.out.println("Java的虚拟机实现版本:   " + props.getProperty("java.vm.version"))

        System.out.println("Java的虚拟机实现供应商:  " + props.getProperty("java.vm.vendor"))

        System.out.println("Java的虚拟机实现名称:   " + props.getProperty("java.vm.name"))

        System.out.println("Java运行时环境规范版本:  " + props.getProperty("java.specification.version"))

        System.out.println("Java运行时环境规范供应商: " + props.getProperty("java.specification.vender"))

        System.out.println("Java运行时环境规范名称:  " + props.getProperty("java.specification.name"))

        System.out.println("Java的类格式版本号:    " + props.getProperty("java.class.version"))

        System.out.println("Java的类路径:   " + props.getProperty("java.class.path"))

        System.out.println("加载库时搜索的路径列表:    " + props.getProperty("java.library.path"))

        System.out.println("默认的临时文件路径:  " + props.getProperty("java.io.tmpdir"))

        System.out.println("一个或多个扩展目录的路径:   " + props.getProperty("java.ext.dirs"))

        System.out.println(" *** 作系统的名称:    " + props.getProperty("os.name"))

        System.out.println(" *** 作系统的构架:    " + props.getProperty("os.arch"))

        System.out.println(" *** 作系统的版本:    " + props.getProperty("os.version"))

        System.out.println("文件分隔符:  " + props.getProperty("file.separator"))

        System.out.println("路径分隔符:  " + props.getProperty("path.separator"))

        System.out.println("行分隔符:   " + props.getProperty("line.separator"))

        System.out.println("用户的账户名称:    " + props.getProperty("user.name"))

        System.out.println("用户的主目录: " + props.getProperty("user.home"))

        System.out.println("用户的当前工作目录:  " + props.getProperty("user.dir"))

    }

  

    private static void memory() throws SigarException {

        Sigar sigar = new Sigar()

        Mem mem = sigar.getMem()

        float total = mem.getTotal()

        float used = mem.getUsed()

        // 内存总量

        System.out.println("内存总量:   " + mem.getTotal() / 1024L/1024L + "M av")

        // 当前内存使用量

        System.out.println("当前内存使用量:    " + mem.getUsed() / 1024L/1024L + "M used")

        // 当前内存剩余量

        System.out.println("当前内存剩余量:    " + mem.getFree() / 1024L/1024L + "M free")

        // 当前内存使用率

        System.out.println("内存使用率:    " +used/total*100+"%")

        Swap swap = sigar.getSwap()

        // 交换区总量

        System.out.println("交换区总量:  " + swap.getTotal() / 1024L/1024L + "M av")

        // 当前交换区使用量

        System.out.println("当前交换区使用量:   " + swap.getUsed() / 1024L/1024L + "M used")

        // 当前交换区剩余量

        System.out.println("当前交换区剩余量:   " + swap.getFree() / 1024L/1024L + "M free")

    }

  

    private static void cpu() throws SigarException {

        Sigar sigar = new Sigar()

        CpuInfo infos[] = sigar.getCpuInfoList()

        CpuPerc cpuList[] = null

        cpuList = sigar.getCpuPercList()

        for (int i = 0 i < infos.length i++) {// 不管是单块CPU还是多CPU都适用

            CpuInfo info = infos[i]

            System.out.println("第" + (i + 1) + "块CPU信息")

            System.out.println("CPU的总量MHz:  " + info.getMhz())// CPU的总量MHz

            System.out.println("CPU生产商: " + info.getVendor())// 获得CPU的卖主,如:Intel

            System.out.println("CPU类别:  " + info.getModel())// 获得CPU的类别,如:Celeron

            System.out.println("CPU缓存数量:    " + info.getCacheSize())// 缓冲存储器数量

            printCpuPerc(cpuList[i])

        }

    }

  

    private static void printCpuPerc(CpuPerc cpu) {

        System.out.println("CPU用户使用率:   " + CpuPerc.format(cpu.getUser()))// 用户使用率

        System.out.println("CPU系统使用率:   " + CpuPerc.format(cpu.getSys()))// 系统使用率

        System.out.println("CPU当前等待率:   " + CpuPerc.format(cpu.getWait()))// 当前等待率

        System.out.println("CPU当前错误率:   " + CpuPerc.format(cpu.getNice()))//

        System.out.println("CPU当前空闲率:   " + CpuPerc.format(cpu.getIdle()))// 当前空闲率

        System.out.println("CPU总的使用率:   " + CpuPerc.format(cpu.getCombined()))// 总的使用率

    }

  

    private static void os() {

        OperatingSystem OS = OperatingSystem.getInstance()

        //  *** 作系统内核类型如: 386、486、586等x86

        System.out.println(" *** 作系统:   " + OS.getArch())

        System.out.println(" *** 作系统CpuEndian():    " + OS.getCpuEndian())//

        System.out.println(" *** 作系统DataModel():    " + OS.getDataModel())//

        // 系统描述

        System.out.println(" *** 作系统的描述:    " + OS.getDescription())

        //  *** 作系统类型

        // System.out.println("OS.getName():    " + OS.getName())

        // System.out.println("OS.getPatchLevel():  " + OS.getPatchLevel())//

        //  *** 作系统的卖主

        System.out.println(" *** 作系统的卖主:    " + OS.getVendor())

        // 卖主名称

        System.out.println(" *** 作系统的卖主名:   " + OS.getVendorCodeName())

        //  *** 作系统名称

        System.out.println(" *** 作系统名称: " + OS.getVendorName())

        //  *** 作系统卖主类型

        System.out.println(" *** 作系统卖主类型:   " + OS.getVendorVersion())

        //  *** 作系统的版本号

        System.out.println(" *** 作系统的版本号:   " + OS.getVersion())

    }

  

    private static void who() throws SigarException {

        Sigar sigar = new Sigar()

        Who who[] = sigar.getWhoList()

        if (who != null && who.length > 0) {

            for (int i = 0 i < who.length i++) {

                // System.out.println("当前系统进程表中的用户名" + String.valueOf(i))

                Who _who = who[i]

                System.out.println("用户控制台:  " + _who.getDevice())

                System.out.println("用户host: " + _who.getHost())

                // System.out.println("getTime():   " + _who.getTime())

                // 当前系统进程表中的用户名

                System.out.println("当前系统进程表中的用户名:   " + _who.getUser())

            }

        }

    }

  

   

  

    

  

    

}

看你的意思,主要是不想让程序A被修改,那么以下情况给你参考吧:

1、在当前的win中,程序A被系统加载并运行后,会有一部分基本上是固定不变的,这主要是代码区,还有一部分是根据需要不停地变的,这是变量区,及其它缓冲区。

2、如果你想的是让代码区不被改动,这个要求很容易达到,因为它是固定的,你只要把这个区域的数据时行一下MD5码的计算,或是使用更快速的某种方法进行一次校验便可。但是基本上你要进行一次完全校验,占用的时间一定是不短的(至少1秒以上),这种做法能保护程序的应有功能不被乱改,但不能保证变量不变乱改。此外相当的低效,很少有人这么做。

3、监视程序的启动,一旦启动把自己的dll hook进去 并拦截teProcessMemory API 看起来是有理的,但存在这样几个问题,首先这种程序一定需要管理员权下才能正常运行,其次,程序X可不可以先对付程序B,再对付程序A呢? 另外,程序B一但起动,某些正常的程序也可能受影响,比如金山快译等。

4、最常见的做法是针对程序X的行为对关键部分的代码进行监控,这样监控的范围就能大大地减少,可以达到0.01秒内完成任务,使用户不会感觉到什么,但这样做的前提是知道程序X的行为具体是什么。

5、其它的通用的做法是针对程序X的特点在内存现运行的程序中进行查找,一但发现进行处理。

6、以上两个方法是最常用的做法。

7、破解与反破解始终是一对死冤家,在当前来说,似乎没有好的解决方法,只能说设法让破解的难度加大!

PS:“程序运行后如何md5效验,这不开玩笑吗?”不是开玩笑,MD5码校验并不专指对一个未运行的文件,MD5码校验是一种算法。将内存中的数据抓出来进行MD5码计算也并不是不可以的,当然,上面说过了,这种计算对机器要求过高,在实时运行中是不科学的,也是不可取的。

getTotalPrivateDirty()就是获得自己进程所独占的内存

getTotalPss()意思就是假如有A,B,C,D,E 5个进程共享一片10kb的内存,A,B,F 3个进程又另外共享了30kb的内存,那么进程A调用这个函数返回就是10/5+30/3=12

所以理论上只要监视getTotalPrivateDirty()就能监视自己进程的内存变化

最后附上代码

public void getThisProcessMemeryInfo() {

int pid = Android.os.Process.myPid()

android.os.Debug.MemoryInfo[] memoryInfoArray = activityManager.getProcessMemoryInfo(new int[] {pid})

Log.d(TAG, "本应用当前使用了" + (float)memoryInfoArray[0].getTotalPrivateDirty() / 1024 + "mb的内存")

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/yw/8057377.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-13
下一篇2023-04-13

发表评论

登录后才能评论

评论列表(0条)

    保存