Получить загрузку ЦП всех заданий с JT400
Мне нужно получить% загрузки ЦП всех заданий, использующих JT400. Но мне не удается получить список заданий сразу, так как loadStatistics() доступна только на уровне заданий, а не в списке (более эффективное время).
Используя приведенный ниже код, я могу получить процент загрузки процессора по заданию один за другим, но это занимает много времени:
AS400 as400 = new AS400("hostname", "username", "password");
//Reading SystemStatus like CPU usage and hdd usage
SystemStatus systemStatus = new SystemStatus(as400);
JobList list = new JobList(as400);
list.addJobSelectionCriteria(JobList.SELECTION_PRIMARY_JOB_STATUS_ACTIVE, Boolean.TRUE);
list.addJobSelectionCriteria(JobList.SELECTION_PRIMARY_JOB_STATUS_JOBQ, Boolean.FALSE);
list.addJobSelectionCriteria(JobList.SELECTION_PRIMARY_JOB_STATUS_OUTQ, Boolean.FALSE);
list.addJobAttributeToRetrieve(Job.CPU_TIME_USED);
list.addJobAttributeToRetrieve(Job.SUBSYSTEM);
list.addJobAttributeToRetrieve(Job.JOB_NAME);
list.addJobAttributeToRetrieve(Job.JOB_NUMBER);
list.addJobAttributeToRetrieve(Job.USER_NAME);
//list.addJobAttributeToRetrieve(Job.ELAPSED_CPU_PERCENT_USED);
Enumeration jobs = list.getJobs();
while (jobs.hasMoreElements()) {
Job j= (Job) jobs.nextElement();
j.loadStatistics();
//TimeUnit.SECONDS.sleep(10);
System.out.println("Name " + j.getName() + " | Job NO : " + j.getNumber() + " | User : " + j.getUser() + " | CPU USED : " + j.getCPUUsed()+ " | CPU% : " + j.getValue(Job.ELAPSED_CPU_PERCENT_USED));
j.resetStatistics();
}
Есть ли способ получить% процессора (Job.ELAPSED_CPU_PERCENT_USED) для всех заданий одновременно?
1 ответ
Взгляните на некоторые из системных служб управления работой DB2 for i.
Вы должны быть в состоянии извлечь информацию, которую вы ищете из этих функций.
Я решил это тогда, используя com.ibm.jtopenlite.components
JobInfo [] jobs = lstJobs.getJobs(connection, false);
List<Point> pointList = new ArrayList<Point>();
for (JobInfo job : jobs) {
log.debug("getCPUPercent: " + job.getCPUPercent());
log.debug("getCurrentUser: " + job.getCurrentUser());
log.debug("getJobName: " + job.getJobName());
log.debug("getJobType: " + job.getJobType());
log.debug("getSubsystem: " + job.getSubsystem());
log.debug("getTotalCPUUsed: " + job.getTotalCPUUsed());
log.debug("getUserName: " + job.getUserName());
log.debug("getCPUPercentInTenths: " + job.getCPUPercentInTenths());
}