All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hyperic.sigar.CpuTimer Maven / Gradle / Ivy

There is a newer version: 1.6.6-rev002
Show newest version
/*
 * Copyright (c) 2006-2007 Hyperic, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.hyperic.sigar;

import org.hyperic.sigar.jmx.CpuTimerMBean;

import java.io.PrintStream;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

public class CpuTimer implements CpuTimerMBean {
    private static final Map timers =
        Collections.synchronizedMap(new HashMap());

    private Sigar sigar;
    private long totalTime;
    private long cpuTotal;
    private long cpuUser;
    private long cpuSys;
    private long cpuSampleFirst;
    private long cpuSampleLast;
    private long cpuSampleTime;

    private ThreadCpu cpu = new ThreadCpu();

    private long startTime, stopTime;

    public CpuTimer() {
        this(null);
    }

    public CpuTimer(Sigar sigar) {
        clear();
        this.sigar = sigar;
    }

    public void clear() {
        this.startTime = -1;
        this.stopTime = -1;
        this.totalTime = 0;
        this.cpuTotal = 0;
        this.cpuUser  = 0;
        this.cpuSys   = 0;
        this.cpuSampleFirst = 0;
        this.cpuSampleLast = 0;
        this.cpuSampleTime = 0;
    }

    private void stamp(CpuTimer timer) {
        if (this.cpuSampleFirst == 0) {
            this.cpuSampleFirst = toMillis(timer.cpu.total);
            this.cpuSampleTime = timer.startTime;
        }
        else {
            this.cpuSampleLast = toMillis(timer.cpu.total);
        }
    }

    public void add(CpuTimer timer) {
        stamp(timer);
        this.cpuTotal  += timer.cpuTotal;
        this.cpuUser   += timer.cpuUser;
        this.cpuSys    += timer.cpuSys;
        this.totalTime += timer.totalTime;
    }

    public void start() {
        start(this.sigar);
    }

    public void start(Sigar sigar) {
        this.startTime = System.currentTimeMillis();

        try {
            this.cpu.gather(sigar, 0);
        } catch (SigarException e) {
            throw new IllegalArgumentException(e.toString());
        }
        stamp(this);
    }

    public void stop() {
        stop(this.sigar);
    }

    public void stop(Sigar sigar) {
        ThreadCpu diff = getDiff(sigar);

        this.cpuTotal += diff.total;
        this.cpuUser  += diff.user;
        this.cpuSys   += diff.sys;

        this.stopTime = System.currentTimeMillis();
        
        double timeDiff = this.stopTime - this.startTime;

        this.totalTime += timeDiff;
    }

    public ThreadCpu getDiff() {
        return getDiff(this.sigar);
    }

    public ThreadCpu getDiff(Sigar sigar) {
        long startTotal = this.cpu.total;
        long startUser  = this.cpu.user;
        long startSys   = this.cpu.sys;
    
        ThreadCpu diff = new ThreadCpu();

        try {
            this.cpu.gather(sigar, 0);
        } catch (SigarException e) {
            throw new IllegalArgumentException(e.toString());
        }

        diff.total = this.cpu.total - startTotal;
        diff.user  = this.cpu.user - startUser;
        diff.sys   = this.cpu.sys - startSys;

        stamp(this);

        return diff;
    }

    public long getTotalTime() {
        return this.totalTime;
    }
    
    private long toMillis(long ns) {
        return ns / 1000000; //convert nanos to millis
    }

    public long getCpuTotal() {
        return toMillis(this.cpuTotal);
    }
    
    public long getCpuUser() {
        return toMillis(this.cpuUser);
    }
    
    public long getCpuSys() {
        return toMillis(this.cpuSys);
    }

    //expecting start/stop/add to be called more often than this,
    //so we give percentage over time in between calls.
    public double getCpuUsage() {
        if ((this.cpuSampleFirst == 0) ||
            (this.cpuSampleLast == 0))
        {
            return 0.0;
        }

        long timeNow = System.currentTimeMillis();
        double diff = timeNow - this.cpuSampleTime;
        if (diff == 0) {
            return 0.0;
        }

        double usage =
            (this.cpuSampleLast - this.cpuSampleFirst) / diff;

        this.cpuSampleFirst = 0;
        this.cpuSampleLast = 0;
        this.cpuSampleTime = 0;

        return usage;
    }

    public long getLastSampleTime() {
        return this.stopTime;
    }

    public static CpuTimer getInstance(String name) {
        CpuTimer timer = (CpuTimer)timers.get(name);
        if (timer == null) {
            timer = new CpuTimer();
            timers.put(name, timer);
        }
        return timer;
    }

    public String format(long elap) {
        String fraction = (elap % 1000) + "";
        int pad = 3 - fraction.length();

        StringBuffer buf = new StringBuffer()
            .append(elap / 1000).append('.');

        //for example, 15 millseconds formatted as ".015" rather than ".15"
        while (pad-- > 0) {
            buf.append("0");
        }
        buf.append(fraction).append(" seconds");
        return buf.toString();
    }

    public void list(PrintStream out) {
        out.println("real....." +
                    format(getTotalTime()));
        out.println("user....." + format(getCpuUser()));
        out.println("sys......" + format(getCpuSys()));
        out.println("usage...." + CpuPerc.format(getCpuUsage()));
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy