23

We are running computing jobs with GridEngine. Every jobs returns 3 different times:

  • Wall clock time
  • User time
  • CPU time

What are the differences between these three? Which of these three is most suitable to compare the performance of two applications/scripts

Peter Smit
  • 1,649
  • 4
  • 21
  • 37

3 Answers3

29

Wall clock time is the actual amount of time taken to perform a job. This is equivalent to timing your job with a stopwatch and the measured time to complete your task can be affected by anything else that the system happens to be doing at the time.

User time measures the amount of time the CPU spent running your code. This does not count anything else that might be running, and also does not count CPU time spent in the kernel (such as for file I/O).

CPU time measures the total amount of time the CPU spent running your code or anything requested by your code. This includes kernel time.

The "User time" measurement is probably the most appropriate for measuring the performance of different jobs, since it will be least affected by other things happening on the system.

Greg Hewgill
  • 6,749
  • 3
  • 29
  • 26
4

From Wikipedia:

The term 'user CPU time' can be a bit misleading at first. To be clear the total time (real CPU time), is the combination of the amount of time the CPU spends performing some action for a program and the amount of time the CPU spends performing system calls for the kernel on the program's behalf. When a program loops through an array, it is accumulating user CPU time. Conversely, when a program executes a system call such as exec or fork, it is accumulating system CPU time

Wall clock time is the actual time taken by a computer to complete a task. It is the sum of three terms: CPU time, I/O time, and the communication channel delay (e.g. if data are scattered on multiple machines). In contrast to CPU time, which measures only the time during which the processor is actively working on a certain task, wall time measures the total time for the process to complete. The difference between the two consists of time that passes due to programmed delays or waiting for resources to become available.

Maxwell
  • 5,026
  • 1
  • 25
  • 31
2

Wall clock time is the time you would get if you measured the runtime with a stopwatch. User time is the amount of time the CPU takes for running exclusively the code in your job (this does not include system calls you job may do). CPU time is the amount of time the CPU takes on actively running your code and including possible system calls.