欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java?oshi如何查看cpu信息

 更新時間:2022年01月25日 10:36:30   作者:占星安啦  
這篇文章主要介紹了java?oshi如何查看cpu信息,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

oshi查看cpu信息

OSHI可以跨平臺查看服務器信息,其中cpu負載信息為當前占用CPU的時間。需要在一段時間內獲取兩次,然后相減得出這段時間內所占用的時間。這段時間除以總占用時間就是占用百分比。

pom引入依賴

<dependency>
? ? ? <groupId>com.github.oshi</groupId>
? ? ? <artifactId>oshi-core</artifactId>
? ? ? <version>3.12.2</version>
</dependency>

測試類

package io.greatcolin.jvmMessage;
import oshi.SystemInfo;
import oshi.hardware.CentralProcessor;
import oshi.hardware.GlobalMemory;
import java.text.DecimalFormat;
import java.util.Properties;
import java.util.concurrent.TimeUnit;

/**
 * @author colin.cheng
 * @version V1.0
 * @date Created In 16:04 2019/8/16
 */
public class OshiTest {
    public static void main(String[] args) {
        while (true){
            try {
                OshiTest.printlnCpuInfo();
                OshiTest.MemInfo();
                OshiTest.getThread();
                OshiTest.setSysInfo();
                OshiTest.setJvmInfo();
                TimeUnit.SECONDS.sleep(5);
            }catch (Exception e){
                e.printStackTrace();
            }
        }
    }

    private static void printlnCpuInfo() throws InterruptedException {
        //System.out.println("----------------cpu信息----------------");
        SystemInfo systemInfo = new SystemInfo();
        CentralProcessor processor = systemInfo.getHardware().getProcessor();
        long[] prevTicks = processor.getSystemCpuLoadTicks();
        // 睡眠1s
        TimeUnit.SECONDS.sleep(1);
        long[] ticks = processor.getSystemCpuLoadTicks();
        long nice = ticks[CentralProcessor.TickType.NICE.getIndex()] - prevTicks[CentralProcessor.TickType.NICE.getIndex()];
        long irq = ticks[CentralProcessor.TickType.IRQ.getIndex()] - prevTicks[CentralProcessor.TickType.IRQ.getIndex()];
        long softirq = ticks[CentralProcessor.TickType.SOFTIRQ.getIndex()] - prevTicks[CentralProcessor.TickType.SOFTIRQ.getIndex()];
        long steal = ticks[CentralProcessor.TickType.STEAL.getIndex()] - prevTicks[CentralProcessor.TickType.STEAL.getIndex()];
        long cSys = ticks[CentralProcessor.TickType.SYSTEM.getIndex()] - prevTicks[CentralProcessor.TickType.SYSTEM.getIndex()];
        long user = ticks[CentralProcessor.TickType.USER.getIndex()] - prevTicks[CentralProcessor.TickType.USER.getIndex()];
        long iowait = ticks[CentralProcessor.TickType.IOWAIT.getIndex()] - prevTicks[CentralProcessor.TickType.IOWAIT.getIndex()];
        long idle = ticks[CentralProcessor.TickType.IDLE.getIndex()] - prevTicks[CentralProcessor.TickType.IDLE.getIndex()];
        long totalCpu = user + nice + cSys + idle + iowait + irq + softirq + steal;
        System.out.println("----------------cpu信息----------------");
        System.out.println("cpu核數:" + processor.getLogicalProcessorCount());
        System.out.println("cpu系統使用率:" + new DecimalFormat("#.##%").format(cSys * 1.0 / totalCpu));
        System.out.println("cpu用戶使用率:" + new DecimalFormat("#.##%").format(user * 1.0 / totalCpu));
        System.out.println("cpu當前等待率:" + new DecimalFormat("#.##%").format(iowait * 1.0 / totalCpu));
        System.out.println("cpu當前使用率:" + new DecimalFormat("#.##%").format(1.0-(idle * 1.0 / totalCpu)));
    }

    public static void MemInfo(){
        System.out.println("----------------主機內存信息----------------");
        SystemInfo systemInfo = new SystemInfo();
        GlobalMemory memory = systemInfo.getHardware().getMemory();
        //總內存
        long totalByte = memory.getTotal();
        //剩余
        long acaliableByte = memory.getAvailable();
        System.out.println("總內存 = " + formatByte(totalByte));
        System.out.println("使用" + formatByte(totalByte-acaliableByte));
        System.out.println("剩余內存 = " + formatByte(acaliableByte));
        System.out.println("使用率:" + new DecimalFormat("#.##%").format((totalByte-acaliableByte)*1.0/totalByte));
    }

    public static void setSysInfo(){
        System.out.println("----------------操作系統信息----------------");
        Properties props = System.getProperties();
        //系統名稱
        String osName = props.getProperty("os.name");
        //架構名稱
        String osArch = props.getProperty("os.arch");
        System.out.println("操作系統名 = " + osName);
        System.out.println("系統架構 = " + osArch);
    }

    public static void setJvmInfo(){
        System.out.println("----------------jvm信息----------------");
        Properties props = System.getProperties();
        Runtime runtime = Runtime.getRuntime();
        //jvm總內存
        long jvmTotalMemoryByte = runtime.totalMemory();
        //jvm最大可申請
        long jvmMaxMoryByte = runtime.maxMemory();
        //空閑空間
        long freeMemoryByte = runtime.freeMemory();
        //jdk版本
        String jdkVersion = props.getProperty("java.version");
        //jdk路徑
        String jdkHome = props.getProperty("java.home");
        System.out.println("jvm內存總量 = " + formatByte(jvmTotalMemoryByte));
        System.out.println("jvm已使用內存 = " + formatByte(jvmTotalMemoryByte-freeMemoryByte));
        System.out.println("jvm剩余內存 = " + formatByte(freeMemoryByte));
        System.out.println("jvm內存使用率 = " + new DecimalFormat("#.##%").format((jvmTotalMemoryByte-freeMemoryByte)*1.0/jvmTotalMemoryByte));
        System.out.println("java版本 = " + jdkVersion);
        //System.out.println("jdkHome = " + jdkHome);
    }

    public static void getThread(){
        System.out.println("----------------線程信息----------------");
        ThreadGroup currentGroup =Thread.currentThread().getThreadGroup();

        while (currentGroup.getParent()!=null){
          // 返回此線程組的父線程組
          currentGroup=currentGroup.getParent();
        }
        //此線程組中活動線程的估計數
        int noThreads = currentGroup.activeCount();

        Thread[] lstThreads = new Thread[noThreads];
        //把對此線程組中的所有活動子組的引用復制到指定數組中。
        currentGroup.enumerate(lstThreads);
        for (Thread thread : lstThreads) {
          System.out.println("線程數量:"+noThreads+" 線程id:" + thread.getId() + " 線程名稱:" + thread.getName() + " 線程狀態(tài):" + thread.getState());
        }
    }

    public static String formatByte(long byteNumber){
        //換算單位
        double FORMAT = 1024.0;
        double kbNumber = byteNumber/FORMAT;
        if(kbNumber<FORMAT){
            return new DecimalFormat("#.##KB").format(kbNumber);
        }
        double mbNumber = kbNumber/FORMAT;
        if(mbNumber<FORMAT){
            return new DecimalFormat("#.##MB").format(mbNumber);
        }
        double gbNumber = mbNumber/FORMAT;
        if(gbNumber<FORMAT){
            return new DecimalFormat("#.##GB").format(gbNumber);
        }
        double tbNumber = gbNumber/FORMAT;
        return new DecimalFormat("#.##TB").format(tbNumber);
    }
}

輸出結果

# 沒添加slf4j的依賴,不影響
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
----------------cpu信息----------------
cpu核數:4
cpu系統使用率:1.88%
cpu用戶使用率:2.73%
cpu當前等待率:0%
cpu當前使用率:4.71%
----------------主機內存信息----------------
總內存 = 7.88GB
使用5.89GB
剩余內存 = 1.99GB
使用率:74.72%
----------------線程信息----------------
線程數量:5 線程id:2 線程名稱:Reference Handler 線程狀態(tài):WAITING
線程數量:5 線程id:3 線程名稱:Finalizer 線程狀態(tài):WAITING
線程數量:5 線程id:4 線程名稱:Signal Dispatcher 線程狀態(tài):RUNNABLE
線程數量:5 線程id:5 線程名稱:Attach Listener 線程狀態(tài):RUNNABLE
線程數量:5 線程id:1 線程名稱:main 線程狀態(tài):RUNNABLE
----------------操作系統信息----------------
操作系統名 = Windows 7
系統架構 = amd64
----------------jvm信息----------------
jvm內存總量 = 123MB
jvm已使用內存 = 20.46MB
jvm剩余內存 = 102.54MB
jvm內存使用率 = 16.64%
java版本 = 1.8.0_65

oshi獲取cpu/內存使用率前十的進程

CPU

@Override
public void getFirstCpuUsed() {
? ? OperatingSystem windowsOperatingSystem = new WindowsOperatingSystem();
? ? List<OSProcess> processList = windowsOperatingSystem.getProcesses(10, OperatingSystem.ProcessSort.CPU);
? ? for (OSProcess process : processList) {
? ? ? ? //進程名,進程ID,進程CPU使用率
? ? ? ? System.out.println(String.format("name:%s PID: %d CPU:%.3f",
? ? ? ? ? ? ? ? process.getName(),process.getProcessID(),
? ? ? ? ? ? ? ? process.getProcessCpuLoadCumulative()));
? ? }
}

內存

public void getFirstMemUsed(){
? ? OperatingSystem windowsOperatingSystem = new WindowsOperatingSystem();
? ? List<OSProcess> processList = windowsOperatingSystem.getProcesses(10, OperatingSystem.ProcessSort.MEMORY);
? ? for (OSProcess process : processList) {
? ? ? ? //進程名,京城ID,進程CPU使用率
? ? ? ? System.out.println(String.format("name:%s PID: %d CPU:%.3f",
? ? ? ? ? ? ? ? process.getName(),process.getProcessID(),
? ? ? ? ? ? ? ? process.getProcessCpuLoadCumulative()));
? ? }
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • SSM框架下如何實現數據從后臺傳輸到前臺

    SSM框架下如何實現數據從后臺傳輸到前臺

    這篇文章主要介紹了SSM框架下如何實現數據從后臺傳輸到前臺,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Spring 4 支持的 Java 8 特性

    Spring 4 支持的 Java 8 特性

    Spring 框架 4 支持 Java 8 語言和 API 功能。在本文中,我們將重點放在 Spring 4 支持新的 Java 8 的功能。最重要的是 Lambda 表達式,方法引用,JSR-310的日期和時間,和可重復注釋。下面跟著小編一起來看下吧
    2017-03-03
  • 淺談一下JVM垃圾回收算法

    淺談一下JVM垃圾回收算法

    這篇文章主要介紹了一下JVM垃圾回收算法,Java有著自己一套的內存管理機制,不需要開發(fā)者去手動釋放內存,開發(fā)者只需要寫好代碼即可,運行過程中產生的垃圾都由JVM回收,需要的朋友可以參考下
    2023-04-04
  • Java實現常見排序算法的優(yōu)化

    Java實現常見排序算法的優(yōu)化

    今天給大家?guī)淼氖顷P于Java的相關知識,文章圍繞著Java實現常見排序算法的優(yōu)化展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下
    2021-01-01
  • springboot獲取URL請求參數的多種方式

    springboot獲取URL請求參數的多種方式

    這篇文章主要介紹了springboot獲取URL請求參數的多種方式,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Java多線程實現之Callable詳解

    Java多線程實現之Callable詳解

    這篇文章主要介紹了Java多線程實現之Callable詳解,Callable是一個接口,用于實現多線程,與實現Runnable類似,但是功能更強大,通過實現Callable接口,我們需要重寫call()方法,該方法可以在任務結束后提供一個返回值,需要的朋友可以參考下
    2023-08-08
  • Java的四種引用方式

    Java的四種引用方式

    這篇文章主要介紹了Java的四種引用方式,Java的引用方式主要包括強引用、軟引用、弱引用、虛引用;下面文章便來詳細介紹這四種引用方式,需要的朋友可以參考一下
    2021-10-10
  • JAVA實現較完善的布隆過濾器的示例代碼

    JAVA實現較完善的布隆過濾器的示例代碼

    這篇文章主要介紹了JAVA實現較完善的布隆過濾器的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • 詳解Spring中bean生命周期回調方法

    詳解Spring中bean生命周期回調方法

    本篇文章主要介紹了詳解Spring中bean生命周期回調方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • java中的日期和時間比較大小

    java中的日期和時間比較大小

    這篇文章主要介紹了java中的日期和時間比較大小,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論