當前位置: 首頁>>代碼示例>>Java>>正文


Java OperatingSystemMXBean類代碼示例

本文整理匯總了Java中com.sun.management.OperatingSystemMXBean的典型用法代碼示例。如果您正苦於以下問題:Java OperatingSystemMXBean類的具體用法?Java OperatingSystemMXBean怎麽用?Java OperatingSystemMXBean使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


OperatingSystemMXBean類屬於com.sun.management包,在下文中一共展示了OperatingSystemMXBean類的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public static void main(String[] argv) throws Exception {
    OperatingSystemMXBean mbean = (com.sun.management.OperatingSystemMXBean)
        ManagementFactory.getOperatingSystemMXBean();
    double load;
    for(int i=0; i<10; i++) {
        load = mbean.getProcessCpuLoad();
        if((load<0.0 || load>1.0) && load != -1.0) {
            throw new RuntimeException("getProcessCpuLoad() returns " + load
                   +   " which is not in the [0.0,1.0] interval");
        }
        try {
            Thread.sleep(200);
        } catch(InterruptedException e) {
            e.printStackTrace();
        }
    }
}
 
開發者ID:aducode,項目名稱:openjdk-source-code-learn,代碼行數:18,代碼來源:GetProcessCpuLoad.java

示例2: start

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
@Override
public void start() throws Exception {
  systemMBean = ManagementFactory.getPlatformMXBean(OperatingSystemMXBean.class);

  // A random identifier
  String pid = UUID.randomUUID().toString();

  // Get the kafka producer config
  JsonObject config = config();

  // Create the producer
  producer = KafkaWriteStream.create(vertx.getDelegate(), config.getMap(), String.class, JsonObject.class);

  // Publish the metircs in Kafka
  vertx.setPeriodic(1000, id -> {
    JsonObject metrics = new JsonObject();
    metrics.put("CPU", systemMBean.getProcessCpuLoad());
    metrics.put("Mem", systemMBean.getTotalPhysicalMemorySize() - systemMBean.getFreePhysicalMemorySize());
    producer.write(new ProducerRecord<>("the_topic", new JsonObject().put(pid, metrics)));
  });
}
 
開發者ID:FroMage,項目名稱:redpipe,代碼行數:22,代碼來源:MetricsVerticle.java

示例3: getCpuUsage

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public synchronized double getCpuUsage() {
    if(lastSystemTime == 0) {
        baselineCounters();
        return 0;
    }

    long systemTime = System.nanoTime();
    long processCpuTime = 0;

    if(ManagementFactory.getOperatingSystemMXBean() instanceof OperatingSystemMXBean) {
        processCpuTime = ((OperatingSystemMXBean)ManagementFactory.getOperatingSystemMXBean()).getProcessCpuTime();
    }

    double cpuUsage = (double) (processCpuTime - lastProcessCpuTime) / (systemTime - lastSystemTime);

    lastSystemTime = systemTime;
    lastProcessCpuTime = processCpuTime;

    return cpuUsage / availableProcessors;
}
 
開發者ID:vangav,項目名稱:vos_backend,代碼行數:21,代碼來源:CPU.java

示例4: getPhysicalMemory

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
/**
 * Gets the amount of physical memory (RAM) in this machine, in bytes.
 *
 * @return the amount of RAM, in bytes; or -1 if the amount of RAM
 * cannot be queried.
 */
public static long getPhysicalMemory() {
  final Object o = ManagementFactory.getOperatingSystemMXBean();

  try {
    if (o instanceof OperatingSystemMXBean) {
      final OperatingSystemMXBean osb = (OperatingSystemMXBean) o;
      return osb.getTotalPhysicalMemorySize();
    }
  }
  catch (NoClassDefFoundError e) {
    // com.sun.management.OperatingSystemMXBean doesn't exist in this JVM
  }

  // We didn't get a com.sun.management.OperatingSystemMXBean.
  return -1;
}
 
開發者ID:ajmath,項目名稱:VASSAL-src,代碼行數:23,代碼來源:MemoryUtils.java

示例5: reportCPU

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
private Optional<Double> reportCPU(OperatingSystemMXBean operatingSystemMXBean, RuntimeMXBean runtimeMXBean) {
    int availableProcessors = divideByNbCores ? operatingSystemMXBean.getAvailableProcessors() : 1;
    long upTime = runtimeMXBean.getUptime();
    long processCpuTime = operatingSystemMXBean.getProcessCpuTime();

    if (lastMeasures == null
            || lastMeasures.availableProcessors != availableProcessors
            || lastMeasures.processCpuTime < 0) {
        lastMeasures = new Measures(availableProcessors, upTime, processCpuTime);
        return Optional.empty();
    }

    long elapsedCpu = processCpuTime - lastMeasures.processCpuTime;
    long elapsedTime = upTime - lastMeasures.upTime;
    lastMeasures = new Measures(availableProcessors, upTime, processCpuTime);

    return Optional.of(Math.min(99D, elapsedCpu / (elapsedTime * 10000D * availableProcessors)));
}
 
開發者ID:jotak,項目名稱:hawkular-java-toolbox,代碼行數:19,代碼來源:CPUMonitoring.java

示例6: getSystemStats

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
Map<String, Object> getSystemStats() {
    Map<String, Object> stats = new HashMap<>();
    OperatingSystemMXBean osBean = ManagementFactory.getPlatformMXBean(OperatingSystemMXBean.class);
    double cpuUsage = osBean.getProcessCpuLoad() < 0 ? 0 : osBean.getProcessCpuLoad() * 100.0;

    stats.put("javaVersion", System.getProperty("java.version"));
    stats.put("osName", System.getProperty("os.name"));
    stats.put("osArch", System.getProperty("os.arch"));
    stats.put("osVersion", System.getProperty("os.version"));
    stats.put("maxMemory", Runtime.getRuntime().maxMemory());
    stats.put("totalMemory", Runtime.getRuntime().totalMemory());
    stats.put("freeMemory", Runtime.getRuntime().freeMemory());
    stats.put("cores", Long.parseLong(String.valueOf(Runtime.getRuntime().availableProcessors()))); // Is this really necessary?
    stats.put("cpuUsage", Math.min(round(cpuUsage), 100.0));

    return stats;
}
 
開發者ID:MinecraftMarket,項目名稱:MinecraftMarket-Plugin,代碼行數:18,代碼來源:MCMarketStats.java

示例7: main

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public static void main(String[] argv) throws Exception {
    OperatingSystemMXBean mbean = (com.sun.management.OperatingSystemMXBean)
        ManagementFactory.getOperatingSystemMXBean();
    double load;
    for(int i=0; i<10; i++) {
        load = mbean.getSystemCpuLoad();
        if((load<0.0 || load>1.0) && load != -1.0) {
            throw new RuntimeException("getSystemCpuLoad() returns " + load
                   +  " which is not in the [0.0,1.0] interval");
        }
        try {
            Thread.sleep(200);
        } catch(InterruptedException e) {
            e.printStackTrace();
        }
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:18,代碼來源:GetSystemCpuLoad.java

示例8: main

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public static void main(String... args) throws Exception {
    OperatingSystemMXBean bean = (OperatingSystemMXBean)
            ManagementFactory.getOperatingSystemMXBean();
    List<String> failedGetterNames = new ArrayList<String>();
    List<String> testedGetterNames = Arrays.asList(
            "getTotalSwapSpaceSize",      "getFreeSwapSpaceSize",
            "getTotalPhysicalMemorySize", "getFreePhysicalMemorySize");
    for (String getterName : testedGetterNames) {
        Method getter = OperatingSystemMXBean.class.getMethod(getterName);
        long value = (Long) getter.invoke(bean);
        if (value == MEMORYSTATUS_OVERFLOW) {
            failedGetterNames.add(getterName);
        }
    }
    if (!failedGetterNames.isEmpty()) {
        throw new AssertionError(failedGetterNames);
    }
    System.out.println("Test passed.");
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:20,代碼來源:MemoryStatusOverflow.java

示例9: main

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public static void main(String[] args) {
    OperatingSystemMXBean operatingSystemMXBean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
    System.out.println("Platform: " + operatingSystemMXBean.getArch());
    System.out.println("Name: " + operatingSystemMXBean.getName());
    System.out.println("Version: " + operatingSystemMXBean.getVersion());
    System.out.println("Available processors: " + operatingSystemMXBean.getAvailableProcessors());
    System.out.println("Average load: " + operatingSystemMXBean.getSystemLoadAverage());

    System.out.println("Committed virtual memory : " + operatingSystemMXBean.getCommittedVirtualMemorySize());

    System.out.println("Total physical memory: " + operatingSystemMXBean.getTotalPhysicalMemorySize());
    System.out.println("Free physical memory: " + operatingSystemMXBean.getFreePhysicalMemorySize());

    System.out.println("Total swap space: " + operatingSystemMXBean.getTotalSwapSpaceSize());
    System.out.println("Free swap space: " + operatingSystemMXBean.getFreeSwapSpaceSize());

    System.out.println("Process CPU load: " + operatingSystemMXBean.getProcessCpuLoad() + "%");
    System.out.println("Process CPU time: " + operatingSystemMXBean.getProcessCpuTime());
    System.out.println("System CPU load: " + operatingSystemMXBean.getSystemCpuLoad() + "%");
}
 
開發者ID:kslisenko,項目名稱:java-performance,代碼行數:21,代碼來源:OS.java

示例10: showCPU

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public static void showCPU() {
		OperatingSystemMXBean osbean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();
		RuntimeMXBean runbean = ManagementFactory.getRuntimeMXBean();
		long bfprocesstime = osbean.getProcessCpuTime();
		long bfuptime = runbean.getUptime();
		long ncpus = osbean.getAvailableProcessors();
//		for (int i = 0; i < 1000000; ++i) {
//			ncpus = osbean.getAvailableProcessors();
//		}
		long afprocesstime = osbean.getProcessCpuTime();
		long afuptime = runbean.getUptime();
		float cal = (afprocesstime - bfprocesstime) / ((afuptime - bfuptime) * 10000f);
		float usage = Math.min(99f, cal);
		System.out.println("Calculation: " + cal);
		System.out.println("CPU Usage: " + usage);
	}
 
開發者ID:callakrsos,項目名稱:Gargoyle,代碼行數:17,代碼來源:CPUUsageTest.java

示例11: getProcessTime

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
public int getProcessTime()
{
    int cpuPercent = 0;

    if ( (bean instanceof com.sun.management.OperatingSystemMXBean) )
    {
        currCPUMilliesUsed = (bean.getProcessCpuTime()/1000000);

        currCPUCalendar = Calendar.getInstance();
        long milliesPassed = (currCPUCalendar.getTimeInMillis() - lastCPUCalendar.getTimeInMillis());
        long cpuMilliesDiff = (currCPUMilliesUsed - lastCPUMilliesUsed);
        cpuPercent = (int)Math.round((cpuMilliesDiff / (milliesPassed * 0.001))/10);
        if (cpuPercent > 100) {cpuPercent = 100;}
        lastCPUMilliesUsed = currCPUMilliesUsed;
        lastCPUCalendar.setTimeInMillis(currCPUCalendar.getTimeInMillis());
    }
    else
    {
        cpuPercent = 50;
    }
    return cpuPercent;
}
 
開發者ID:ron-from-nl,項目名稱:DataCenterManager,代碼行數:23,代碼來源:DCMSysMonitor.java

示例12: instantiateCPUMetrics

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
private static void instantiateCPUMetrics(MetricGroup metrics) {
	try {
		final OperatingSystemMXBean mxBean = (OperatingSystemMXBean) ManagementFactory.getOperatingSystemMXBean();

		metrics.<Double, Gauge<Double>>gauge("Load", new Gauge<Double> () {
			@Override
			public Double getValue() {
				return mxBean.getProcessCpuLoad();
			}
		});
		metrics.<Long, Gauge<Long>>gauge("Time", new Gauge<Long> () {
			@Override
			public Long getValue() {
				return mxBean.getProcessCpuTime();
			}
		});
	} catch (Exception e) {
		LOG.warn("Cannot access com.sun.management.OperatingSystemMXBean.getProcessCpuLoad()" +
			" - CPU load metrics will not be available.", e);
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:22,代碼來源:TaskExecutorMetricsInitializer.java

示例13: execute

import com.sun.management.OperatingSystemMXBean; //導入依賴的package包/類
@Override
public void execute(AgentOrder agentOrder) {
    OperatingSystemMXBean operatingSystemMXBean = ManagementFactory.getPlatformMXBean(OperatingSystemMXBean.class);
    if (operatingSystemMXBean == null) {
        return;
    }

    long totalSwapSpace = operatingSystemMXBean.getTotalSwapSpaceSize();
    long freeSwapSpace = operatingSystemMXBean.getFreeSwapSpaceSize();
    long usedSwapSpace = totalSwapSpace - freeSwapSpace;

    OsEventBuilder eventBuilder = OsEventBuilder.createSwapBuilder(this.getEventBuilderData());

    eventBuilder.setTotalSwapSpace(totalSwapSpace);
    eventBuilder.setFreeSwapSpace(freeSwapSpace);
    eventBuilder.setUsedSwapSpace(usedSwapSpace);

    this.sendEvent(eventBuilder.toEvent());
}
 
開發者ID:Indoqa,項目名稱:logspace,代碼行數:20,代碼來源:SwapAgent.java


注:本文中的com.sun.management.OperatingSystemMXBean類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。