[ Next Article | Previous Article | Book Contents | Library Home | Legal | Search ]
AIX Versions 3.2 and 4 Performance Tuning Guide

Chapter 12. Performance Diagnostic Tool (PDT)

PDT assesses the current state of a system and tracks changes in workload and performance. It attempts to identify incipient problems and suggest solutions before the problems become critical. PDT became available at AIX Version 4.

For the most part, PDT functions with no required user input. PDT data collection and reporting are easily enabled, and then no further administrator activity is required. Periodically, data is collected and recorded for historical analysis, and a report is produced and mailed to the adm userid. Normally, only the most significant apparent problems are recorded on the report. If there are no significant problems, that fact is reported. PDT can be customized to direct its report to a different user or to report apparent problems of a lower severity level.

The main sections in this topic are:

Structure of PDT

As shown in the figure "PDT Component Structure," the PDT application consists of three components:

PDT considers various aspects of a system's configuration, availability, and delivered performance in making its assessment. In particular, areas of configuration imbalance are sought out (such as I/O-configuration balance, paging-configuration balance) as well as other configuration problems (for example, disks not allocated to volume groups). A wide variety of trending assessments is made, including file sizes, file-system sizes, paging-area usage, network delays and workload-related delays.

Scope of PDT Analysis

PDT collects configuration, availability, workload, and performance data on a daily basis. This data is maintained in a historical record. Approximately a month's worth of data is kept in this way. Also on a daily basis, PDT generates a diagnostic report. The report is mailed to user adm.

In addition to mailing the report, PDT stores a copy in /var/perf/tmp/PDT_REPORT. Before the new report is written, the previous report is renamed /var/perf/tmp/PDT_REPORT.last.

While many common system performance problems are of a specific nature--a system may have too little memory--PDT also attempts to apply some general concepts of well-performing systems to its search for problems. Some of these concepts, together with examples of their application to AIX, are:

Balanced Use of Resources

In general, if there are several resources of the same type, then a balanced use of those resources produces better performance.

Operation within Bounds

Resources have limits to their use. Trends that would attempt to exceed those limits should be detected and reported.

Identify Workload Trends

Trends can indicate a change in the nature of the workload as well as increases in the amount of resource used:

Error-Free Operation

Hardware or software errors often produce performance problems.

Changes Should be Investigated

New workloads or processes that start to consume resources may be the first sign of a problem.

Appropriate Setting of System Parameters

There are many parameters in a system. Are all of them set appropriately?

The PDT report consists of several sections (see the example, below). After the header information, the Alerts section contains identified violations of the concepts noted above. If no alerts are found, the section is not present in the report. The next two sections are for upward trends and downward trends. These two sections focus on problem anticipation, rather than on the identification of existing problems. In general, the same concepts are applied--but with a view toward projecting when violations will occur. If no upward or downward trends are detected, these sections are not present in the report.

Sample PDT Report

______________________________________________________________________________
 Performance Diagnostic Facility 1.0
   
 Report printed: Tue Aug 3 10:00:01 1993
 Host name: test.austin.ibm.com
 Range of analysis is from:  Hour 16 on Monday, July 5th, 1993
 to: Hour 9 on Tuesday, August 3rd, 1993.
   
[To disable/modify/enable collection or reporting, execute the pdt_config script]
   
--------------------- Alerts ---------------------
  I/O BALANCE        
   -  Phys. vol. hdisk0 is significantly busier than others
      volume cd0, mean util. = 0.00
      volume hdisk0, mean util. = 11.75
      volume hdisk1, mean util. = 0.00
  PAGE SPACE AND MEMORY
   -  Mean page space used = 46.85 MB
      System has 32MB memory; may be inadequate.
      Consider further investigations to determine if memory is a bottleneck
   
------------------- Upward Trends ----------------
  FILE SYSTEMS       
   -  File system hd2 (/usr) PERCENTAGE FULL
      now, 45.00 % full, and growing an avg. of 2.0 %/day
      At this rate, hd2 will be full in about 15 days
  PAGE SPACE         
   -  Page space hd6 USE
      now, 44.80 MB and growing an avg. of 1.81 MB/day
      At this rate, hd6 will be full in about 30 days
  WORKLOAD TRACKING
   - Workload nusers indicator is increasing;
     now 23, and growing an avg. of 1.2 per day
    
----------------------- System Health ---------------
  SYSTEM HEALTH
   -  Current process state breakdown:
      2.00 [ 3.0 %] : waiting for the cpu
      64.00 [ 97.0 %] : sleeping
      66.00 = TOTAL
      [based on 1 measurement consisting of 10 2-second samples]
   
------------------ Summary ------------------------
  This is a severity level 2 report
  Further details are available at severity levels > 2
______________________________________________________________________________

In the preceding example, the header section indicates the release number of PDT, the date the report was printed, the host from which the data was collected, and the range of dates of the data that fed the analysis.

The next section, Alerts, indicates suspicious configuration and load conditions. In the example, it appears that, of the three disks on the system, one is getting essentially all of the I/O activity. Clearly, I/O load is not distributed in such a way as to best make use of the available resources. The next message, PAGE SPACE AND MEMORY, suggests that the system may be underconfigured in memory.

The Upward Trends section in the example identifies two possible trends. The first is that the file system on logical volume hd2 (the /usr file system) is growing at an average rate of 2% per day. An estimated date at which the file system will be full is provided, based on an assumption of continued linear growth.

The second trend is the apparent systematic growth in the utilization level of one of the paging areas. Information about its rate of increase and expected fill-date is given. Knowledge of growing file systems and paging spaces approaching their limits is potentially very important (especially if the rate is high or the expected fill-date is imminent), since a full file system or paging space can cause system or application failure.

The third trend is a change in one of the workload indicators. The following indicators are tracked by PDT for trends:

Keyword Indicator
nusers Total number of logged-on users.
loadavg 15-minute load average.
nprocesses Total number of processes.
STAT_A Number of active processes.
STAT_W Number of swapped processes.
STAT_Z Number of zombie processes.
STAT_I Number of idle processes.
STAT_T Number of processes stopped after receiving a signal.
STAT_x Number of processes reported by the ps command as being in state x, where x is a state not listed above.
cp Time to copy a 40KB file.
idle_pct_cpu0 CPU-idle percentage.
idle_pct_avg CPU-idle percentage.

The next section, System Health, uses a number of the workload indicators to assess how processes are spending their time.

The final section of the report (Summary) indicates the selected severity level, and whether or not additional detail can be obtained by changing that level. (The highest severity level is 1, which is the default level reported. The lowest level is 3.)

Any message (excluding header and summary information) occurring in the PDT report should be investigated. The indicated problem should be corrected or an explanation for the condition obtained. Possible responses to specific messages are covered in Responding to PDT-Report Messages.

Installing and Enabling PDT

PDT is installed through installp as the bos.perf.diag_tool option of the AIX Version 4 BOS licensed program.

PDT must be enabled in order to begin data collection and report writing. PDT is enabled by executing the script /usr/sbin/perf/diag_tool/pdt_config. Only the root userid is permitted to run this script. When executed, the following message is displayed:

# /usr/sbin/perf/diag_tool/pdt_config
 ________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 

When you respond with 4, default PDT collection and reporting is enabled. The crontab entry for user adm is updated to add the PDT entries. Actual collection occurs when the cron jobs are run by cron. Respond with 7 to terminate the pdt_config program.

Option 5 should be selected to disable collection.

Customizing PDT

Certain aspects of PDT can be customized. For example, any user can be designated as the regular recipient of PDT reports, and the retention period for data in PDT's historical record can be modified. All customization is performed either by modifying one of the PDT files in /var/perf/cfg/diag_tool/ or by executing the /usr/sbin/perf/diag_tool/pdt_config script.

We recommend that no changes be made until after PDT has produced several reports, and a certain familiarity with PDT has been acquired.

Changing the PDT Report Recipient and Severity Level

By default, PDT reports are generated with severity level 1. This means that only the most serious problems are identified. There are other severity levels (2,3) at which more detailed information is frequently available. Further, whenever a PDT report is produced, it is mailed to userid adm. It might be desirable to have the report mailed elsewhere or not mailed at all.

Both of these parameters are controlled with the pdt_config script. The following dialog changes the user and the severity level :

#/usr/sbin/perf/diag_tool/pdt_config
________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 1
current PDT report recipient and severity level 
adm 1

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 2

enter id@host for recipient of report : rsmith
enter severity level for report (1-3): 2

report recipient and severity level
rsmith 2

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 1

current PDT report recipient and severity level
rsmith 2

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 7
#

In the preceding example, the recipient is changed to user rsmith, and the severity is changed to 2. This means that user rsmith will receive the PDT report, and that both severity 1 and 2 messages will be included. Note the use of option 1 to determine the current PDT report recipient and report severity level.

To terminate reporting (but allow collection to continue), option 3 is selected, for example:

#/usr/sbin/perf/diag_tool 

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 3

disable PDT reporting done

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 1

reporting has been disabled (file .reporting.list not found).

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 7
#

PDT Severity Levels

The following lists indicate the possible problems associated with each severity level. Remember that selecting Severity n results in the reporting of all problems of severity less than or equal to n.

Severity 1 Problems
Severity 2 Problems
Severity 3 Messages:

Obtaining a PDT Report on Demand

As an alternative to using the periodic report, any user can request a current report from the existing data by executing /usr/sbin/perf/diag_tool/pdt_report [SeverityNum]. The report is produced with the given severity (if none is provided, SeverityNum defaults to 1) and written to stdout. Generating a report in this way does not cause any change to the /var/perf/tmp/PDT_REPORT or /var/perf/tmp/PDT_REPORT.last files.

PDT Error Reporting

Errors can occur within each of the different PDT components. In general, an error does not terminate PDT. Instead, a message is output to PDT's standard error file: /var/perf/tmp/.stderr, and that phase of processing terminates.

Users experiencing unexpected behavior, such as the PDT report not being produced as expected, should examine /var/perf/tmp/.stderr.

De-Installing PDT

It is not possible to de-install PDT directly using pdt_config, but if option 6 is requested, a message describes the steps necessary to remove PDT from the system:

#/usr/sbin/perf/diag_tool/pdt_config 

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 6

  PDT is installed as package bos.perf.diag_tool in the bos lpp.
  Use the installp facility to remove the package

________________PDT customization menu__________________
   
1) show current  PDT report recipient and severity level
2) modify/enable PDT reporting
3) disable       PDT reporting
4) modify/enable PDT collection
5) disable       PDT collection
6) de-install    PDT
7) exit pdt_config
Please enter a number: 7
#

Modifying the List of Files Monitored by PDT

PDT analyzes files and directories for systematic growth in size. It examines only those files and directories listed in the file /var/perf/cfg/diag_tool/.files. The format of the .files file is one file/directory name per line. The default content is:

/usr/adm/wtmp
/var/spool/qdaemon/
/var/adm/ras/
/tmp/

You can modify this file with an editor to track files and directories that are important to your system.

Modifying the List of Hosts That PDT Monitors

PDT tracks the average ping delay to hosts whose names are listed in /var/perf/cfg/diag_tool/.nodes. This file is not shipped with PDT (which means that no host analysis is performed by default), but may be created by the administrator. The format of the .nodes file is one host name per line in the file.

Changing the Historical-Record Retention Period

Periodically, a retention shell script is run that discards entries in PDT's historical record that are older than the designated retention period. The retention of all data is governed by the same retention policy. This policy is described in the /var/perf/cfg/diag_tool/.retention.list file. The default .retention.list content is:

* * * 35

which causes all data to be retained no more than 35 days. The number 35 can be replaced by any unsigned integer.

PDT uses the historical record to assess trends and identify system changes. Extending the retention period increases the scope of this analysis at the cost of additional disk storage and PDT processing time.

PDT's historical record is maintained in /var/perf/tmp/.SM. The retention script creates a copy of this file in /var/perf/tmp/.SM.last prior to performing the retention operation. In addition, historical data that is discarded is appended to /var/perf/tmp/.SM.discards.

The existence of /var/perf/tmp/.SM.last provides limited backup, but the administrator should ensure that the /var/perf/tmp/.SM file is regularly backed up. If the file is lost, PDT continues to function, but without the historical information. Over time, the historical record will grow again as new data is collected.

Modifying the Collection, Retention, and Reporting Times

Collection, reporting and retention are driven by three entries in user adm's cron table. Collection occurs on every weekday at 9 a.m. Reporting occurs every weekday at 10 a.m. The retention analysis is performed once a week, on Saturday evening at 9 p.m. The cron entries (created by executing the /usr/sbin/perf/diag_tool/pdt_config script and selecting option 2) are shown below:

0  9 * * 1-5   /usr/sbin/perf/diag_tool/Driver_ daily
0 10 * * 1-5   /usr/sbin/perf/diag_tool/Driver_ daily2
0 21 * * 6     /usr/sbin/perf/diag_tool/Driver_ offweekly

While it is possible to modify these times by editing adm's cron table, this is not recommended.

Responding to PDT-Report Messages

PDT identifies many types of problems. Responses to these indications depends on the individual organization's available resources and set of priorities. The following samples suggest some possibilities:

Problem: JFS file system becomes unavailable
Response: Investigate why file system is unavailable.
Useful cmds: lsfs (to determine file system status)
Problem: JFS file system nearly full
Response: Look for large files in the file system, possibly caused by a runaway process. Has this file system exhibited long term growth trend (look at the rest of the PDT report--or past PDT reports--to check this)?
Useful cmds: du, ls
Problem: Physical volume not allocated to a volume group
Response: Volume should be defined in a volume group; otherwise, it is inaccessible to AIX and is being wasted.
Useful cmds: lspv (to confirm that the volume is not allocated)

smit (to manipulate volume groups)

Problem: All paging spaces defined on one physical volume
Response: The system has more than one physical volume, yet all paging space is defined on a single volume. If the system experiences paging, this configuration will result in reduced performance.
Useful cmds: smit (to modify paging spaces)
Problem: Apparently too little memory for current workload
Response: If the system is paging heavily, more memory may be required on the system for good performance.
Useful cmds: lsps -a, vmstat
Problem: Page space nearly full
Response: The system's paging space may need to be enlarged, unless the problem is due to a process with a memory leak, in which case that process should be identified and the application fixed.
Useful cmds: ps aucg (to examine process activity)

smit (to modify page space characteristics)

Problem: Possible problems in the settings of load control parameters
Response: The memory-load-control parameters are evaluated in relation to current paging activity. For example, if thrashing is occurring and load control is not enabled, it may be appropriate to enable load control.
Useful cmds: schedtune
Problem: VMM-detected bad memory frames
Response: It may be necessary to have the memory analyzed. Compare the amount of installed memory with the memory actually accessible; if the latter is less than the former, then bad memory has been identified.

You can use /usr/sbin/perf/diag_tool/getvmparms and look at the value of numframes to determine the actual number of 4KB memory frames.

Useful cmds: lscfg | grep mem (to obtain installed memory size in MB)
Problem: Any host in .nodes becomes unreachable
Response: Determine if problem is with current host (has a change in the /etc/hosts file been made?), with the remote host (is it down?), or with the network (is the nameserver down?).
Useful cmds: ping
Problem: Imbalance in the I/O configuration (number of disks per adapter)
Response: Consider moving disks around so that an individual SCSI adapter is not overloaded.
Useful cmds: lscfg (to examine the current configuration)

iostat (to determine if the actual load on the adapters is out of balance)

Problem: Imbalance in allocation of paging space on physical volumes with paging space
Response: Consider making paging spaces the same size, except for a few extra megabytes (say, 4) on the primary paging space (hd6). A substantial imbalance in the sizes of paging spaces can cause performance problems.
Useful cmds: smit
Problem: Fragmentation of a paging space in a volume group
Response: Paging performance is better if paging areas are contiguous on a physical volume. However, when paging areas are enlarged, it is possible to create fragments that are scattered across the disk surface.
Useful cmds: lspv -p hdiskn for each physical volume in the volume group. Look for more than one PP Range with the same LVNAME and a TYPE of "paging."
Problem: Significant imbalance in measured I/O load to physical volumes
Response: If one physical volume seems to be getting little I/O activity, consider moving data from busier physical volumes onto less busy volumes. In general, the more evenly the I/O is distributed, the better the performance.
Useful cmds: iostat -d 2 20 (to view the current distribution of I/O across physical volumes)
Problem: New process is a heavy consumer of memory or CPU
Response: Top CPU and memory consumers are regularly identified by PDT. If any of these processes haven't been seen before, they are highlighted in a problem report. These processes should be examined for unusual behavior. Note that PDT simply looks at the process ID. If a known heavy user terminates, then is resumed (with a different process id), it will be identified here as a NEW heavy user.
Useful cmds: ps aucg (To view all processes and their activity)
Problem: Any file in .files exhibits systematic growth (or decline) in size
Response: Look at the current size. Consider the projected growth rate. What user or application is generating the data? For example, the /var/adm/wtmp file is liable to grow unbounded. If it gets too large, login times can increase. In some cases, the solution is to delete the file. In most cases, it is important to identify the user causing the growth and work with that user to correct the problem.
Useful cmds: ls -al (to view file/directory sizes)
Problem: Any file system or paging space exhibits systematic growth (or decline) in space used
Response: Consider the projected growth rate and expected time to fill. It may be necessary to enlarge the file system (or page space). On the other hand, the growth may be an undesirable effect (for example, a process having a memory leak).
Useful cmds: smit (to manipulate file systems/page spaces)

ps aucg, svmon (to view process virtual memory activity)

filemon (to view file system activity)

Problem: Degradation in ping response time or packet loss percentage for any host in .nodes
Response: Is the host in question experiencing performance problems? Is the network having performance problems?
Useful cmds: ping, rlogin, rsh (to time known workloads on remote host)
Problem: A getty process that consumes too much CPU time
Response: Getty processes that use more than just a few percent of the CPU may be in error. It is possible in certain situations for these processes to consume system CPU, even though no users are actually logged on. In general, the solution is to terminate the process.
Useful cmds: ps aucg (to see how much CPU is being used)
Problem: A process that is a top consumer of CPU or memory resources exhibits systematic growth or decline in consumption
Response: Known large consumers of CPU and memory resources are tracked over time to see if their demands grow. As major consumers, a steady growth in their demand is of interest from several perspectives. If the growth is normal, this represents useful capacity planning information. If the growth is unexpected, then the workload should be evaluated for a change (or a chronic problem, such as a memory leak).
Useful cmds: ps aucg
Problem: maxuproc indicated as being possibly too low for a particular userid
Response: it is likely that this user is hitting the maxuproc threshold.

maxuproc is a system-wide parameter that limits the number of processes that nonroot users are allowed to have simultaneously active. If the limit is too low, the user's work can be delayed or terminated. On the other hand, the user might be accidentally creating more processes than needed or appropriate. Further investigation is warranted in either case. The user should be consulted in order to understand more clearly what is happening.

Useful cmds: lsattr -E -l sys0 | grep maxuproc

to determine the current value of maxuproc (although it is also reported directly in the PDT message).

chdev -l sys0 -a maxuproc=100

to change maxuproc to 100 (for example). Root authority is required.

Problem: A WORKLOAD TRACKING indicator shows an upward trend.
Response: The response depends on which workload indicator shows the trend:

loadavg - 15-minute load average

In general, the level of contention in the system is growing. Examine the rest of the PDT report for indicators of system bottlenecks (for example, substantial page space use may indicate a memory shortage; I/O imbalances may indicate that the I/O subsystem requires attention).

nusers - total number of logged users

The number of users on the system is growing. This is important from a capacity planning perspective. Is the growth expected? Can it be explained?

nprocesses - total number of processes

The total number of processes on the system is growing. Are there users bumping up against the maxuproc limitation? Perhaps there are "runaway" applications forking too many processes.

STAT_A - number of active processes

A trend here indicates processes are spending more time waiting for the CPU.

STAT_W - number of swapped processes

A trend here indicates that processes are contending excessively for memory.

STAT_Z - number of zombie processes

Zombies should not stay around for a long time. If the number of zombies on a system is growing, this may be cause for concern.

STAT_I - number of idle processes

This might not be of much concern.

STAT_T - number of processes stopped after receiving a signal

A trend here might indicate a programming error.

STAT_x - (where x is any valid character in the ps command output indicating a process state that has not been listed above)

The interpretation of a trend here depends on the meaning of the character x.

cp - time required to copy a 40KB file

A trend in the time to do a file copy suggests that degradation in the I/O subsystem is evident.

idle_pct_cpu0 - idle percentage for processor 0

An upward trend in the idle percentage might indicate increased contention in non-CPU resources such as paging or I/O. Such an increase is of interest because it suggests the CPU resource is not being well-utilized.

idle_pct_avg - average idle percentage for all processors

An upward trend in the idle percentage might indicate increased contention in non-CPU resources such as paging or I/O. Such an increase is of interest because it suggests the CPU resource is not being well-utilized.


[ Next Article | Previous Article | Book Contents | Library Home | Legal | Search ]