|
|
|
This document describes the interface between ksysguard and
|
|
|
|
ksysguardd. ksysguardd is started as a child of ksysguard, either
|
|
|
|
directly or via a shell. Alternatively a ksysguardd can listen on a
|
|
|
|
port and a single instance can then be used by multiple instances of
|
|
|
|
ksysguard.
|
|
|
|
|
|
|
|
This client/server design was chosen, because on some operating
|
|
|
|
systems the back-end needs elevated permissions. Since C++ programs
|
|
|
|
should NEVER have setgid/setuid permissions, a plain C back-end was
|
|
|
|
needed. It also allowed for an easy network support using existing
|
|
|
|
security mechanisms (ssh).
|
|
|
|
|
|
|
|
ksysguard sends commands and ksysguardd answers to them. Each answer
|
|
|
|
ends with the string "\nksysguardd> ". Error messages are enclosed in
|
|
|
|
ESC '\033' characters. Therefor regular messages may never contain
|
|
|
|
ESC. The set of commands that each ksysguardd implementation supports
|
|
|
|
can be very different. There are only a very few mandatory command and
|
|
|
|
a few recommended commands.
|
|
|
|
|
|
|
|
The mandatory commands are 'monitors', 'test' and 'quit'.
|
|
|
|
The recommended commands are:
|
|
|
|
|
|
|
|
cpu/idle
|
|
|
|
cpu/sys
|
|
|
|
cpu/nice
|
|
|
|
cpu/user
|
|
|
|
mem/swap/free
|
|
|
|
mem/swap/used
|
|
|
|
mem/physical/cached
|
|
|
|
mem/physical/buf
|
|
|
|
mem/physical/application
|
|
|
|
mem/physical/used
|
|
|
|
mem/physical/free
|
|
|
|
ps
|
|
|
|
pscount
|
|
|
|
|
|
|
|
Without these commands KSysGuard is not very helpful.
|
|
|
|
|
|
|
|
The 'monitors' command returns the list of available sensors. The
|
|
|
|
output looks like this:
|
|
|
|
|
|
|
|
--------
|
|
|
|
mem/physical/free integer
|
|
|
|
ps table
|
|
|
|
pscount integer
|
|
|
|
ksysguardd>
|
|
|
|
--------
|
|
|
|
|
|
|
|
Sensor names can be hierarchical. Each level is separated by a
|
|
|
|
/. ksysguard uses a tree widget in the SensorBrowser to display the
|
|
|
|
commands in a tree. Every sensor name must be followed by the type of
|
|
|
|
the sensor separated by a tab. Currently 4 different types of sensors
|
|
|
|
are supported, integer, float, listview and table. The table sensor
|
|
|
|
returns the information for the ProcessController widget. listview
|
|
|
|
sensors use a generic table to display information. To find out more
|
|
|
|
about a sensor an additional command must be implemented for each
|
|
|
|
sensor that has a questionmark appended to the sensor name. It can be
|
|
|
|
used to find out more about the sensor.
|
|
|
|
|
|
|
|
--------
|
|
|
|
ksysguardd> mem/physical/free?
|
|
|
|
Free Memory 0 260708 KB
|
|
|
|
ksysguardd>
|
|
|
|
--------
|
|
|
|
|
|
|
|
integer and float sensor return a short description, the minimum and
|
|
|
|
maximum value and the unit. All fields are again separated by
|
|
|
|
tabs. The minimum and maximum values can both be 0 to trigger the
|
|
|
|
auto-range feature of the display.
|
|
|
|
|
|
|
|
--------
|
|
|
|
ksysguardd> ps?
|
|
|
|
Name PID PPID UID GID Status User% System% Nice VmSize VmRss VmLib Login Command
|
|
|
|
s d d d d S f f d d sksysguardd>
|
|
|
|
--------
|
|
|
|
|
|
|
|
This is the output of the ps? inquiry command. The ps command is the
|
|
|
|
only recommended command. The answer to ps? consists of 2 lines. Both
|
|
|
|
lines have the same number of fields each separated by a tab. The
|
|
|
|
first line specifies the name of the columns and the second the type
|
|
|
|
of the values in the column.
|
|
|
|
|
|
|
|
d: integer value
|
|
|
|
D: integer value that should be localized in the frontend
|
|
|
|
f: floating point value
|
|
|
|
s: string value
|
|
|
|
S: string value that needs to be translated
|
|
|
|
Strings must be added to the ProcessList::columnDict dictionary.
|
|
|
|
|
|
|
|
For the ProcessController to function properly the Name and PID
|
|
|
|
columns are mandatory. All other columns are optional and their
|
|
|
|
content may be implementation dependant. It is highly recommended not
|
|
|
|
to deviate from the Linux implementation unless absolutely
|
|
|
|
unavoidable, in order to provide a consistent interface across all
|
|
|
|
platforms.
|
|
|
|
|
|
|
|
The 'test' command can be used by the front-end to find out if a
|
|
|
|
certain other command is supported by this version of ksysguardd. The
|
|
|
|
command returns "1\n" if the command is supported and "0\n" if the
|
|
|
|
command is not supported.
|
|
|
|
|
|
|
|
The 'quit' command terminates ksysguardd.
|
|
|
|
|
|
|
|
ksysguardd may support dynamic monitor sets. If a CPU is added or an
|
|
|
|
interface disabled, monitors may be added or removed. To notify the
|
|
|
|
front-end about this, you need to send the string "RECONFIGURE\n" over
|
|
|
|
stderr. This causes the front-end to request the list of monitors
|
|
|
|
again and adapt it's layout accordingly. If ksysguardd receives a
|
|
|
|
command it doesn't know it has to reply with "UNKNOWN
|
|
|
|
COMMAND\nksysguardd> ".
|
|
|
|
|
|
|
|
ksysguardd does not handle native language support. In order to have a
|
|
|
|
minimum installation (only a single file) on the monitored machine,
|
|
|
|
all translation are handled by the front-end. Please see the files
|
|
|
|
gui/ksgrd/SensorManger.cpp and gui/SensorDisplayLib/ProcessTable.cpp
|
|
|
|
if you add new strings.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Since I'm very much a C++ guy I've written some functions which
|
|
|
|
* provide a similar functionality as template classes for lists and
|
|
|
|
* arrays. The Linux implementation uses them. Feel free to use them for
|
|
|
|
* the ports as well if you like. The interface is described in
|
|
|
|
* CContLib/ccont.h. Unfortunately I still haven't found time to document
|
|
|
|
* it properly, but the use should be fairly obvious.
|
|
|
|
*/
|
|
|
|
|
|
|
|
Chris <cs@kde.org>
|
|
|
|
|
|
|
|
Since the above mentioned CContLib was a little slow I reimplement it and
|
|
|
|
wrote some docu stuff in the header file. If you need an example for use
|
|
|
|
look at ksysguardd/Linux/diskstat.(h|c).
|
|
|
|
|
|
|
|
Tobias <tokoe@kde.org>
|