19962009 Ericsson AB. All Rights Reserved. The contents of this file are subject to the Erlang Public License, Version 1.1, (the "License"); you may not use this file except in compliance with the License. You should have received a copy of the Erlang Public License along with this software. If not, it can be retrieved online at http://www.erlang.org/. Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific language governing rights and limitations under the License. Pman pman_chapter.xml
Introduction

The process manager Pman is a tool for viewing processes executing locally or on remote nodes. Its main purpose is to locate erroneous code by inspecting the state of the processes and by tracing events. Bottlenecks, unread messages, and bad memory handling are some of the problems that can be solved with Pman.

Processes may be inspected individually in a process trace window. There the user may dynamically follow the execution of a process by getting trace output for sent and received messages as well as for called functions and some other process events. Information about source code modules executed by the processes is also accessible. Note that Pman has some effect on the real time behavior of a running system.

Getting Started with Pman

Start Pman by calling pman:start(). It will start the Main Window, showing an overview of all processes running at the current node.

To trace a certain process, select it by clicking on its line and then chose Trace->Selected Process, or simply double-click it. This will open a Trace Window. In the Trace Window, there is some information about the process and traced events are added dynamically.

Which events to trace are selected in the Options Window which is opened by choosing File->Options... in the Main Window or in a Trace Window. Currently supported trace events are message sending, message receiving, function calls and process events.

It is possible to by-pass the Main Window and open a Trace Window directly for the process Pid by calling pman:proc(Pid).

The Main Window

The Main Window shows all processes running at the displayed node. The window is automatically updated every 5 seconds. Select which node to display in the window by choosing the node name from the Nodes menu.

The Main Window.

A process can be selected by clicking on its line. The selected process is highlighted. Use the arrow keys to move up and down in the process overview.

The following information is displayed for each process:

Pid - process identifier. Current Function - the function (Module:Function/Arity) the process is currently executing. Name - registered name of the process, if any. Msgs - number of messages in the process' mailbox. Reds - number of reductions performed. Gives a rough estimate of the process' work load. Size - estimated size of the process, in words, calculated by adding the stack size and the heap size.

At the bottom of the window the following functions and information can be found:

Hide System Processes This check button controls the display of what Pman consider system processes, that is, processes Pman knows are part of Erlang/OTP rather than the user's application. If the button is selected, these system processes will not be shown. Auto-Hide New This check button controls the treatment of newly created processes. If it is selected, new processes will not be shown. # Hidden This label displays the number of processes currently executing that are not shown in the process overview.
The File Menu Options... Open the Options Window which allows the user to set the trace options to use. Save Options Save the options set using the Options Window. The options are stored to the file HOME/.erlang_tools/pman.opts, where HOME is the user's home directory, and are automatically loaded the next time Pman is started. Exit Stop Pman.
The View Menu

This menu mainly contains buttons for controlling what to display in the Main Window. Note that the View Menu overrides the settings of the check buttons (Hide System processes, Auto-Hide new) in the Main Window.

Hide All Processes Hide all processes. Hide Modules... Opens a dialog window with all loaded modules. If the user selects a window and clicks OK, the process overview will not show any processes running code from those modules. Hide Selected Processs Hide the selected process. Module Info... Given a selected process currently executing a function in the module Module, this menu button opens a window showing information about the module as returned from Module:module_info(). Refresh Updates the process overview. Show All Processes Show all processes, except system processes and/or new processes if Hide System Processes and/or Auto-Hide New is selected. Show Processes... Opens a dialog window with all hidden processes. If the user selects a process and clicks OK, the process overview will show that process.
The Trace Menu Kill Terminates the selected process by calling exit(Pid,kill). Trace Selected Process Opens a Trace Window for the selected process. Tracing will start immediately with the default trace flags set from the Main Window. Shell Process Opens a Trace Window for the shell process of node Pman was started at (not the displayed node). If the shell process dies, the opened Trace Window will find the pid of the automatically started new shell process, and continue to trace that process.
The Nodes Menu

The Nodes menu contains one entry for each known node. By selecting a node from the Nodes menu, the process overview window will change its view, and display the processes running on that node.

The Help Menu Help Selecting Help from the Help menu will cause the HTML version of the Pman User's Guide (this document) to be displayed. Currently this function requires Netscape to be up and running.
The Trace Window

A Trace Window outputs trace information for a traced process. A Trace Window automatically uses the trace options set in the Main Window, but it is also possible to change the options for each Trace Window individually.

The Trace Window.

There is no limit to how many Trace Windows can be open at the same time. However, notice that if more processes are traced, the performance degradation of the system will be more noticeable.

The following information is displayed, where applicable:

initial call - the function (Module:Function/Arity) the process started executing in. current function - the function (Module:Function/Arity) the process is currently executing. messages - the messages in the mailbox. dictionary - the contents of the process dictionary. heap size - heap size in words. stack size - stack size in words. reductions - number of reductions performed. Gives a rough estimate of the process' work load. links - list of pids the process is linked to. trap_exit - true if the process trap exit signals, false otherwise.

In the Trace Window, trace output is continuously added. First in each trace message is the pid of the traced process. Note that if the inheritance flags for tracing are set, the trace output for the spawned/linked processes will be shown in the same window as the spawning/linking process.

Each trace message also has a mnemonic tag:

! This tag indicates that a message has been sent. Following the To: tag will be a pid/name of the receiver. Next, following the Msg: tag will be the sent message. rec This tag indicates that a message has been received. Following this will be the received message. call This tag indicates a call to a function. Following this will be the actual call, with all the arguments. link This tag indicates that a link between the traced process and another process has been created. Following this will be the pid of the other process. spawn This tag indicates that the traced process has spawned another process. Following this will be the pid of the spawned process. exit This tag indicates that traced process has exited. Following this will be the exit reason.
The File Menu Options... Opens the Options Window which allows the user to set the trace options to use for this specific Trace Window. Save Buffer... Opens a dialog that prompts the user for a file name to save the current Trace Window contents in. Close Stops tracing of the process, and closes the Trace Window.
The View Menu Clear Buffer Clears the contents of the Trace Window. Module Info Opens a window showing information about the module the process is currently executing code from, as returned from Module:module_info().
The Trace Menu All Linked Processes Opens a Trace Window for each of the processes linked to the process being traced in the current Trace Window. Linked Process -> The Linked Process submenu has one entry for each process linked to the process being traced in the current Trace Window. Select one of the processes to open a new Trace Window for that process. Kill Terminates the process being traced in the current Trace Window by calling exit(Pid,kill).
The Help Menu Help Selecting Help from the Help menu will cause the HTML version of the Pman User's Guide (this document) to be displayed. Currently this function requires Netscape to be up and running.
The Options Window

The Options Window allows the user to specify the amount of output, and the destination of output for traced processes.

The Options Window.

In the upper left corner of the Options Window, there are check buttons for determining what to output in the Trace Window:

Trace send Select this check button to display information about sent messages. Trace receive Select this check button to display information about received messages. Trace functions Select this check button to display information about function calls. Trace events Select this check button to display information about process events, such as spawn, link and exit.

In the upper right corner of the dialog, there are options for controlling the behaviour of spawned or linked processes:

Inherit on spawn

The user may select if spawned processes shall also be traced. And if so, if all spawned processes should be traced, or just the first spawned process.

If a spawned process is traced, it will get the same trace options that are set for the spawning process. And the output will be shown in the same Trace Window as that of the spawning process.

.

Inherit on link

The user may select if a process that is being linked to shall be traced. And if so, if all linked processes shall be traced, or just the first one linked to.

If a linked process is traced, it will get the same trace options that are set for the linking process. And the output will be shown in the same Trace Window as that of the linked process.

In the lower part of the Options Dialog, the user may select whether the trace information shall be output to a file, or appear in the trace window.

Sending trace information to a file is more efficient than displaying it in the Trace Window. Furthermore, if the amount of trace data is large, it will not be lost if tracing to a file. The trace information in the Trace Window has an upper limit (approx. 10,000 lines), after which the output buffer will be cleared.