2

In one of our production Linux servers, CPU utilization is crossing 100 % and sometimes it is 250%.

How can I find which process is using more CPU utilization and where can I find CPU utilization logs?

OS : RHEL 5.5

Khaled
  • 35,688
  • 8
  • 69
  • 98

8 Answers8

11

CPU utilization is measured relative to a single CPU. The maximum is 100% for each CPU, so a four-CPU system would have a maximum CPU utilization of 400%.

3

Try using the top command

man top for more info

ob_dev
  • 93
  • 1
  • 9
3

The sar utility collects some statistics about your system if it is switched on. The simplest way to access them is to type sar on the command line.

A far better option is to install a monitoring system such as Cacti, Munin or Zabbix. (Although Nagios can do graphing, this is not its forte.) There are plenty of questions on ServerFault already about which monitoring system is the best. Once you install one of them, you will have trouble remembering how you lived without it.

Generally, these will not tell you which process was using all the CPU at any given time. For that, top or htop at the time is your best bet. Bear in mind that 25 Apache processes using 10% CPU each shows up differently in top to a single MySQL process using 250% CPU.

The other key metric to watch is the "load average". This is an indication of how many processes are currently waiting to get on a processor. This is a very good indicator of how slow your system will feel to use.

Another note on CPU utilisation, virtual machines can dynamically alter the CPU capacity in response to the needs of the VM. I have seen a single process showing up as using 9999% CPU in top from within a VM. The advice given by VMWare about this is "Don't trust metrics measured from within the VM".

Ladadadada
  • 25,847
  • 7
  • 57
  • 90
2

Another option is to use the ps command and sort on CPU usage:

ps aux --sort=+cpu
Mattias Ahnberg
  • 4,039
  • 18
  • 19
1

There is no logging of process utilization, you might want to install something like atop for this. There used to be a GNU "system accounting" package, too, but IIRC it's less suitable.

tripleee
  • 1,324
  • 3
  • 14
  • 24
0

Not sure what you use to measure the utilization but you can use:

cat /proc/loadavg 
Alok Save
  • 101
  • 3
0

Others have mentioned top.

If you want, you can run top -b -n1 | head in batch mode in cron and save the output somewhere, to keep track of top processes.

Not Now
  • 3,532
  • 17
  • 18
0

I have answered a similar question to this. You may want to enhance that script for your own needs. Basically, the command ps -eo pcpu,pid,user,args | sort -k 1 -r | head -n 5 will give you some meaningful output. You may just want to automate it and log the output for later analysis.

bintut
  • 304
  • 1
  • 5