package sun.tools.jstat;
import java.util.*;
import sun.jvmstat.monitor.*;
import sun.jvmstat.monitor.event.*;
public class Jstat {
private static Arguments arguments;
public static void main(String[] args) {
try {
arguments = new Arguments(args);
} catch (IllegalArgumentException e) {
System.err.println(e.getMessage());
Arguments.printUsage(System.err);
System.exit(1);
}
if (arguments.isHelp()) {
Arguments.printUsage(System.out);
System.exit(0);
}
if (arguments.isOptions()) {
OptionLister ol = new OptionLister(arguments.optionsSources());
ol.print(System.out);
System.exit(0);
}
try {
if (arguments.isList()) {
logNames();
} else if (arguments.isSnap()) {
logSnapShot();
} else {
logSamples();
}
} catch (MonitorException e) {
if (e.getMessage() != null) {
System.err.println(e.getMessage());
} else {
Throwable cause = e.getCause();
if ((cause != null) && (cause.getMessage() != null)) {
System.err.println(cause.getMessage());
} else {
e.printStackTrace();
}
}
System.exit(1);
}
System.exit(0);
}
static void logNames() throws MonitorException {
VmIdentifier vmId = arguments.vmId();
int interval = arguments.sampleInterval();
MonitoredHost monitoredHost = MonitoredHost.getMonitoredHost(vmId);
MonitoredVm monitoredVm = monitoredHost.getMonitoredVm(vmId, interval);
JStatLogger logger = new JStatLogger(monitoredVm);
logger.printNames(arguments.counterNames(), arguments.comparator(),
arguments.showUnsupported(), System.out);
monitoredHost.detach(monitoredVm);
}
static void logSnapShot() throws MonitorException {
VmIdentifier vmId = arguments.vmId();
int interval = arguments.sampleInterval();
MonitoredHost monitoredHost = MonitoredHost.getMonitoredHost(vmId);
MonitoredVm monitoredVm = monitoredHost.getMonitoredVm(vmId, interval);
JStatLogger logger = new JStatLogger(monitoredVm);
logger.printSnapShot(arguments.counterNames(), arguments.comparator(),
arguments.isVerbose(), arguments.showUnsupported(),
System.out);
monitoredHost.detach(monitoredVm);
}
static void logSamples() throws MonitorException {
final VmIdentifier vmId = arguments.vmId();
int interval = arguments.sampleInterval();
final MonitoredHost monitoredHost =
MonitoredHost.getMonitoredHost(vmId);
MonitoredVm monitoredVm = monitoredHost.getMonitoredVm(vmId, interval);
final JStatLogger logger = new JStatLogger(monitoredVm);
OutputFormatter formatter = null;
if (arguments.isSpecialOption()) {
OptionFormat format = arguments.optionFormat();
formatter = new OptionOutputFormatter(monitoredVm, format);
} else {
List<Monitor> logged = monitoredVm.findByPattern(arguments.counterNames());
Collections.sort(logged, arguments.comparator());
List<Monitor> constants = new ArrayList<Monitor>();
for (Iterator i = logged.iterator(); i.hasNext(); ) {
Monitor m = (Monitor)i.next();
if (!(m.isSupported() || arguments.showUnsupported())) {
i.remove();
continue;
}
if (m.getVariability() == Variability.CONSTANT) {
i.remove();
if (arguments.printConstants()) constants.add(m);
} else if ((m.getUnits() == Units.STRING)
&& !arguments.printStrings()) {
i.remove();
}
}
if (!constants.isEmpty()) {
logger.printList(constants, arguments.isVerbose(),
arguments.showUnsupported(), System.out);
if (!logged.isEmpty()) {
System.out.println();
}
}
if (logged.isEmpty()) {
monitoredHost.detach(monitoredVm);
return;
}
formatter = new RawOutputFormatter(logged,
arguments.printStrings());
}
Runtime.getRuntime().addShutdownHook(new Thread() {
public void run() {
logger.stopLogging();
}
});
HostListener terminator = new HostListener() {
public void vmStatusChanged(VmStatusChangeEvent ev) {
Integer lvmid = new Integer(vmId.getLocalVmId());
if (ev.getTerminated().contains(lvmid)) {
logger.stopLogging();
} else if (!ev.getActive().contains(lvmid)) {
logger.stopLogging();
}
}
public void disconnected(HostEvent ev) {
if (monitoredHost == ev.getMonitoredHost()) {
logger.stopLogging();
}
}
};
if (vmId.getLocalVmId() != 0) {
monitoredHost.addHostListener(terminator);
}
logger.logSamples(formatter, arguments.headerRate(),
arguments.sampleInterval(), arguments.sampleCount(),
System.out);
if (terminator != null) {
monitoredHost.removeHostListener(terminator);
}
monitoredHost.detach(monitoredVm);
}
}