This man page describes version 2.1 of the pmview (1)
configuration file format.
The configuration format supports metrics from multiple hosts or
archives. A configuration file can specify metrics without a source, with
different hosts and different archives. However, a configuration file that
contains archives may only have one archive for any one host. When in
``replay'' mode, any metrics with host specific sources require an archive
to be specified for that host on the command line or as a source to a
previous metric. The archive must be the same archive (based on a string
comparison of the archive names) of any archives specified in the
configuration file for the same host.
The time controls will list all hosts that are specified on the
command line and the configuration file in the timezone listing (see
pmtime(1)).
The configuration file format is based on a two-dimensional grid
which can contain a variety of bars, stacks, links, pipes, labels and other
grids. The grids resize each column and row to match the size of the largest
item in that column or row. A configuration file that contains only one
object does not require a grid. The pmview configuration file starts
with an identification header in the first non-comment line:
pmview Version 2.1 [command_line]
The optional command_line should be the command line with
which the tool was launched, if the configuration file has been generated by
another tool. This is useful for applications that are to be restarted
automatically on the next login, after the user has logged out while
pmview was still running. Care should be taken to ensure that the
command specified is either a full pathname or will be found on the PATH
available at login.
All lines which begin with ``#'' are treated as comments and
ignored. Otherwise, all spaces, tabs and newlines are treated as white space
so multiple commands may be on the same line.
The syntax for specifying values in the configuration file is
consistent for all commands, namely:
- color
- A color must be either one of the 20-or so Qt color names (refer to
the QColor class at https://doc.qt.io/qt-5/qcolor.html#predefined-colors),
or an HTML hexadecimal color value (enclosed in quotes, e.g.
"#ff6347"), or three normalized real values representing
the saturation of red, green and blue. For example, the following colors
are identical:
red
"#ff0000"
1.0 0.0 0.0
- int
- An integer.
- metric
- A metric consists of an optional source (host or archive), the metric
name, an optional instance list immediately after name, followed by the
maximum (or normalization value). A colon (``:'') is used to separate a
host name from the metric, and a forward slash (``/'') to separate an
archive name from the metric. Instances are enclosed in square brackets
and comma separated. Each instance may be enclosed in quotes.
- For example, some legal metrics are:
kernel.all.cpu.idle 4000
myhost:kernel.all.cpu.idle[cpu0,"cpu3"] 1000.0
/path/to/myarchive/kernel.all.cpu.idle[cpu1] 1000
To assist the process of matching instance names, two further
comparisons are made beyond a simple string comparison. If the instance
name contains spaces, only the first word in the instance name is
required to match the instance, assuming that the first word is unique.
If the first word is not unique, only the first matching instance will
be selected. The second comparison occurs if the first word is a number
with leading zeros. Any leading zeros will be skipped before comparing
the first word again. This permits process ids used in the proc
metrics to be easily matched, without specifying the entire instance
name. For example, to visualize the user and system time of init
use the metric specification
proc.psusage.utime[1] 1000
proc.psusage.stime[1] 1000
- name
- A name for an object which may be referred to later in the configuration
file. Names must be a single word consisting of all alphanumeric
characters, as well as underscores, dashes and colons. It is recommended
that names do not begin with an underscore as this may be interpreted as a
keyword.
- pos
- This is the position of the object within the grid. The syntax of a
position is:
-
[ [x z] [ [width depth] [alignment] ] ]
- x
- The horizontal coordinate (left to right) of the object, starting at 0.
The default x is 0.
- z
- The vertical coordinate (top to bottom) of the object, starting at 0. The
default z is 0.
- width
- The number of columns occupied by the object. The default width is
1.
- depth
- The number of rows occupied by the object. The default depth is
1.
-
alignment
- The edge or corner that the object is aligned with. Possible alignments
include: north, south, east, west,
northeast, northwest, southeast, southwest and
center. Abbreviations like se and SE are also
accepted. The default alignment is center.
- The size of an object may not be known as the number of instances for some
metrics will vary between hosts and PMDA configurations. Therefore, the
position of the object can be used to specify the likely size of the
object, so that the position of the surrounding objects is appropriately
adjusted.
- The following are legal positions:
-
0 5
- The object is centered at grid position 0,5 occupying 1 grid square.
-
1 2 north
- The object is aligned with the north edge of position 1,2 occupying 1 grid
square.
-
2 2 2 1 east
- The object is aligned to the eastern edge of position 3,2 and occupies 2
grid squares (2,2 and 3,2).
- string
- A string is a series of characters enclosed in double quotes. A string may
not contain newlines or escaped double quotes.
There are several parameters that may affect the size, shape and
color of objects when they are displayed. These parameters are scoped so
that they only alter objects defined later in the same scope. Therefore,
parameter settings at the top of a configuration file affect the entire
scene, unless they are changed later in the file. Most of these parameters
are also resources.
- _barLength int
- The side length of the _bar and _stack blocks. Default is
28.
- _barHeight int
- The maximum height of a _bar and _stack blocks. Default is
80.
- _baseColor color
- The color of _bar, _grid and _stack base planes.
Default is "#262626" (i.e. gray15).
- _baseHeight int
- The height of _bar, _grid and _stack base planes.
Default is 2.
- _gapWidth int
- The gap between blocks in a _bar object in the X-axis. The default
is 8.
- _gapDepth int
- The gap between blocks in a _bar object in the Z-axis. The default
is 8.
- _gapLabel int
- The gap between the base of a _bar object, and any metric or
instance labels. The default is 6.
- _gridWidth int
- The minimum width of a _grid column. The default is 20.
- _gridDepth int
- The minimum depth of a _grid row. The default is 20.
- _labelMargin int
- The margin around a _label object. The default is 5.
- _labelColor color
- The color of _label and _bar labels. The default is
white.
- _marginWidth int
- The extra width of a _bar, _grid and _stack base
plane beyond the objects on the plane. The default is 8.
- _marginDepth int
- The extra depth of a _bar, _grid and _stack base
plane beyond the objects on the plane. The default is 8.
- _pipeLength int
- Total length of a _pipe. The default is the value of
_barHeight.
- _scale real
- The scale applied to the entire scene. This parameter may not be used
within any objects, only at the top of the configuration file. The default
is 1.0.
To simplify the specification of colors, a _colorList and a
_colorScale may be used to define colors for an object which has
metrics associated with it, i.e. _bar, _stack or _pipe.
A color list may be defined within an object, or named and defined at the
top of a configuration file. A named color list may then be referenced
within multiple objects:
- _colorList name ( color [color...]
)
- Associate the colors with the color list name. The
assignment of colors to blocks depends on the type of an object. For
example, the color list called foo has the same color three times:
_colorList foo ( red "#ff0000" 1.0 0.0 0.0 )
- _colorScale name color ( color
real [color real...] )
- Associate the colors and reals with the color list
name. The initial color is the default color of the object.
The object will change color to the other colors when the normalized value
of the object is equal to or greater than each real. Therefore,
each real must be larger than the previous real, and should
be in the range 0.0 to 1.0. This scale gradually changes from blue to
red:
_colorScale coldToHot blue ( "#7f00ff" 0.3
purple 0.6
"#ff007f" 0.8
red 0.95)
There are several different object types which could be found in a
pmview scene: _bar, _stack, _pipe, _grid,
_link, and _label. There is also _xing which is a
special type of the _link. The _bar, _stack and
_pipe objects are modulated by metric values, a _label is
fixed text, _link and _xing are interconnects and a
_grid is a container of objects, including other _grid
objects, which controls the layout of the scene. A _grid object is
only required if there are two or more objects in the scene.
_bar, _grid and _stack objects may have base
planes which provide a point of reference for the blocks as they change
height. A label can be applied to the base plane _grid object if it
is _shown with:
_baseLabel name|string
_baseLabel should be used within the scope of the relevant
_bar, _grid or _stack object. The first ``\n''
characters in the string will be replaced by a new line. Subsequent ``\n''
characters will be ignored.
For a scene to be valid it must contain at least one modulated
object.
The objects are defined as:
- _bar [options] ( [metric-list]
[color-list] [label-list] )
- A _bar object represents a collection of blocks. The number of
blocks depends on the number of metrics and metric instances assigned to
the object. By default, the blocks are modulated by changing the height of
each block. Alternatively, blocks may be modulated by changing color, or
both height and color. Each color in the color-list is assigned to
each metric. Therefore, multiple instances of the one metric will have the
same color. The options that may be passed to a _bar object
are:
- pos
- The position of the _bar object within the current _grid
object.
- _col|_row
- Position the blocks so that each instance is in a column (_col) or
a row (_row). This implies that each different metric is in a
separate row or column, respectively. The default is _col.
- _show|_hide
- Is the base plane visible? Default is _show.
- _ymod|_colormod|_colorymod
- Modulate the blocks by adjusting their height (_ymod), color
(_colormod) or both height and color (_colorymod).
- _cube|_cylinder
- Set the shape of the blocks. The default is _cube.
- _groupbymetric|_groupbyinst|_groupbyrow||groupbycol
- Set the grouping of blocks when launching other tools. For tools like
pmchart(1) some views may generate many small charts which cannot
be drawn entirely within the screen. Another problem is it may be more
appropriate to generate charts with the same instance in each chart,
rather then the same metric. The group specifiers control the algorithm
used so that a separate chart will be drawn for each _metrics
specification (_groupbymetric), for the first, second etc. instance
of each _metric (_groupbyinst), or by the rows and columns
of the _bar object depending on _row or _col. The
default is _groupbymetric.
The options must be specified in this order, although preceding
options are not required. Therefore, this is legal:
_bar _hide _cylinder ( ... )
The metrics, colors and labels are specified within the brackets
in any order. Only the metric-list is mandatory.
- metric-list
- A _bar metric list contains a list of metric names, normalization
values and an optional label for the metric:
_metrics ( metric real [string] [metric real [string]...] )
- color-list
- A _bar color list may be a named color list that was defined
earlier, or an unnamed color list. A _colorScale list should be
used when using _colormod or _colorymod modulation.
Therefore, the syntax for color lists within a _bar object are any
of:
_colorList name
_colorList ( color [color...] )
_colorScale name
_colorScale color ( color real [color real...] )
- label-list
- In addition to labels for each metric in the metric-list, metric
and instance labels may be defined using _metriclabels and
_instlabels statements. The position of the labels around the
_bar object depends on the _row or _col orientation
of metrics and instances, and whether the label is read _towards
the _bar object, or _away. The default is _towards.
_metriclabels [_away|_towards] ( name|string [name|string...] )
_instlabels [_away|_towards] ( name|string
[name|string...] )
- _grid [pos] [_show|_hide] (
objects )
- A _grid object is a container for objects, including other
_grid objects. The rows and columns of a _grid object are
resized to the largest object in the row or column. If an object spans
multiple rows and/or columns, those rows and columns may be partly resized
to contain the object. However, the resizing of rows and columns for
objects occupying multiple rows and columns occurs after resizing for
objects occupying only one grid square.
A collision between objects occupying the same squares will be
reported as an error message and the later object will be ignored.
The options to a _grid object control the position
(pos) of the _grid object in the parent _grid, and
indicate whether to _show or _hide the _grid base
plane. By default, the base plane is hidden.
The parameters described above may be specified within the
brackets of a _grid object, however they only apply to the
objects within the _grid, not the _grid itself. For a
parameter to be applied to a _grid object, it must be specified
before the _grid object declaration.
- _label [options] string
- A _label object draws the contexts of string at the
location, orientation and size specified in the options:
- pos
- The position of the _label object in the current _grid
object.
- _left|_right|_up|_down
- The orientation of the string. The direction indicates the
direction the label is read. Therefore, _right is the default since
the string is read from left to right.
- _small|_medium|_large
- The font size. The default is _medium.
- _link pos [string]
- A _link object draws a straight or L-shaped horizontal round
``pipe'' with diameter equal to 80% of the _baseHeight of an
enclosing _grid. The properties of the object are defined by the
options:
- pos
- sets both the position of the _link on the grid and its shape.
_link starts in the column and row on the _grid specified by
first two numbers in the pos and spans the number of columns and
rows set by the second two numbers. The alignment value is used to
decide the orientation of the link (links are always aligned at the
center): east and west links are straight and going from
left to right, north and south links are straight and going
from far end of the grid to near end, northeast, northwest,
southeast and southwest links are L-shaped and connect the
corresponding points of the compass, i.e. a northeast link takes on
the general shape of the Latin letter ``L''.
- string
- sets the ``tag'' for the _link which will be displayed in the text
window when the pointer is over the link.
- _pipe pos ( [metric-list] [color-list]
[tag] )
- A _pipe object represent a set of cylinders, placed on top of each
other and oriented parallel to the base plane. The diameter of a
_pipe is equal to 80% of _baseHeight. The number of blocks
is dependent on the number of metric instances in the metric-list.
The colors in the color-list are assigned in turn to each cylinder
in the _pipe. The length of the _pipe is defined by the
_pipeLength.
- pos
- defines the position of the _pipe on the enclosing _grid and
its orientation with alignment field used to define at which end of
the pipe to stack the colored cylinders. The cylinders are stacked at the
corresponding point of the compass and the pipe's direction is from the
point of the compass towards the center of the compass. Only east,
west, north, and south are valid values for the
pipe's alignment.
The metrics, colors and label may be specified within the brackets in any order.
Only the metric-list is mandatory.
- metric-list
- A _pipe metric list contains a list of metric names and
normalization values:
_metrics ( metric real [metric real...] )
- color-list
- A _pipe color list may be named color list that was defined
earlier, or an unnamed color list:
_colorList name
_colorList ( color [color...] )
- tag
- A _pipe may have a ``tag'' for the filler block (unanimated block
on the ``other'' end of the pipe) which will be displayed in the text
window when the pointer is over that end of the pipe.
- _stack [options] ( [metric-list]
[color-list] [label] )
- A _stack object represents a set of blocks placed vertically on top
of each other. The number of blocks is dependent on the number of metric
instances in the metric-list. The colors in the color-list
are assigned to each block in the _stack. By default, the height of
the _stack will be the sum of the height of each block. The
options that may be passed to a _stack object are:
- pos
- The position of the _stack object within the current _grid
object.
- _show|_hide
- Is the base plane visible? Default is _show.
- _utilmod|_fillmod
- Force the height of the stack to always be the maximum height. This is
achieved by normalizing the height of each block (_utilmod), or by
adding a grey block to the top of the stack (_fillmod).
- _cube|_cylinder
- Set the shape of the blocks. The default is _cube.
The options must be specified in this order, although preceding
options are not required. Therefore, this is legal:
_stack 1 1 _north _utilmod ( ... )
The metrics, colors and label may be specified within the brackets
in any order. Only the metric-list is mandatory.
- metric-list
- A _stack metric list contains a list of metric names and
normalization values:
_metrics ( metric real [metric real...] )
- color-list
- A _stack color list may be named color list that was defined
earlier, or an unnamed color list:
_colorList name
_colorList ( color [color...] )
- label
- A _fillmod type _stack may have a label for the filler
block:
- _xing col row columns rows dir1
... dir4
- A _xing is a special kind of link which is used to draw a pair of
links which cross each other. To convey the visual impression that the
links do not join, one of the links is drawn as a ``broken'' cylinder.
col and row define the position on the enclosing grid.
columns and rows define the size of the bounding box. The
end points of the crossing cylinders are placed exactly in the center of
the corner cells of the bounding box and four small cylinders or stubs are
used to join the perimeter of the bounding box with the end points on the
crossing cylinders. Four dir values define the orientation of the
stubs, starting at the upper left corner of the _xing and
proceeding clockwise, such that respective stubs are used to join the
point of the compass with the center on the cell (see example).