Probes v9

A probe is a scheduled task that retrieves information about the database objects that are being monitored by the PEM agent. PEM uses the collected information to build the graphs displayed on each homepage. The Management > Manage Probes tab allows you to modify the data collection schedule and the length of time that PEM retains information returned by a specific probe.

System probes

Unless otherwise noted, Postgres Enterprise Manager enables the following probes at the server, database, schema, extension (starting with version 8.4), or agent levels:

NameInformation monitored by probeLevel
Background Writer StatisticsMonitors information about the background writer. The information includes the number of:
Timed checkpoints
Requested checkpoints
Buffers written (by checkpoint)
Buffers written (by background writer)
Background writer cycles
Background buffers written
Buffers allocated
Server
Barman ConfigurationInformation about the Barman tool global configuration.Agent
Barman InformationInformation about the Barman tool.Agent
Barman ServerInformation about the respective database server configuration monitored by Barman.Agent
Barman Server StatusInformation about the respective database server status monitored by Barman.Agent
Barman Server BackupInformation about the backups of the respective database servers.Agent
Barman Server WAL StatusInformation about the Barman server WAL files.Agent
Blocked Session InformationInformation about blocked sessions.Server
CPU UsageCPU usage information.Agent
Data and Log File AnalysisInformation about log files. The information includes:
The name of the log file
The directory in which the log file resides
Server
Database Frozen XIDThe frozen XID of each database.Server
Database SizeInformation about the size of the monitored databases. The information includes:
The time the information was gathered
The database name
The database size (in MB).
Server
Database StatisticsDatabase statistics. The information includes:
The number of backends
The number of transactions committed
The number of transactions rolled back
The number of blocks read
The number of blocks hit
The number of rows returned
The number of rows fetched
The number of rows inserted
The number of rows updated
The number of rows deleted
Server
Disk Busy InfoInformation about disk activity.
Note: This probe isn't supported on Mac OS X, Solaris, or HP-UX.
Agent
Disk SpaceInformation about disk space usage. The information includes:
The amount of disk space used
The amount of disk space available
Agent
EDB Audit ConfigurationThe audit logging configuration of EDB Postgres Advanced Server.Server
Failover Manager Cluster InfoMonitors a Failover Manager cluster, returning information about the cluster. This probe is enabled when a cluster name and path of the Failover Manager binary is provided on the Server Properties dialog box.Server
Failover Manager Node StatusMonitors a Failover Manager cluster, returning details about each node within the cluster. This probe is enabled when a cluster name and path of the Failover Manager binary is provided on the Server Properties dialog box.Server
Function StatisticsMonitors a database, retrieving information about functions. The information includes:
Function names
Argument types
Return values
Database
Index SizeMonitors a database, retrieving information about indexes. The information includes:
The name of the index
The time the data was gathered
The size of the index (in MB)
Database
Index StatisticsIndex statistics. The information includes:
The number of index scans
The number of rows read
The number of rows fetched
The number of blocks read
The number of blocks hit
Database
Installed PackagesThe packages that are currently installed. The information gathered includes:
The name of the installed package
The version of the installed package
The date and time that the probe executed
Agent
IO AnalysisDisk I/O information. The information includes:
The number of blocks read
The number of blocks written
The date and time that the probe executed
Note: This probe isn't supported on Mac OS X.
Agent
Load AverageCPU load averages. The information includes:
The 1-minute load average
The 5-minute load average
The 15-minute load average
Note: This probe isn't supported on Windows.
Agent
Lock InformationLock information. The information includes:
The database name
The lock type
The lock mode
The process holding the lock
Server
Memory UsageInformation about system memory usage. The information includes:
Total RAM in MB
Free RAM in MB
Total swap memory in MB
Free swap memory in MB
Shared system memory in MB (used by tuning wizard to tune the memory parameters for the database server)
- On non-Windows systems, it is the shmmax value and read from /proc/sys/kernel/shmmax.
- On Windows, it is same as total memory.
Agent
Network StatisticsNetwork statistics. The information includes:
The interface IP address
The number of packets sent
The number of packets received
The number of bytes sent
The number of bytes received
The link speed (in MB/second)
Agent
Number of Prepared TransactionsStores the number of prepared transactions.Server
Number of WAL FilesThe number of WAL files.Server
Object Catalog: DatabaseMonitors a list of databases and their properties. The information includes:
The database name
The database encoding type
If the database allows user connections or system connections
Server
Object Catalog: Foreign KeyMonitors a list of foreign keys and their properties. The information includes:
The name of the table that contains the foreign key
The name of the table that the foreign key references
The name of the database in which the table resides
The name of the schema in which the table resides
Schema
Object Catalog: FunctionMonitors a list of functions and their properties. The information includes:
The name of the function
The name of the schema in which the function resides
The name of the database in which the function resides
Schema
Object Catalog: IndexMonitors a list of indexes and their properties. The information includes:
The name of the index
The name of the table that the index is associated with
The name of the database in which the indexed table resides
Schema
Object Catalog: SchemaMonitors a list of schemas and their associated databases and servers.Database
Object Catalog: SequenceMonitors a list of sequences and their properties.Schema
Object Catalog: TableMonitors a list of table information. The information includes:
The table name
The name of the schema in which the table resides
The name of the database in which the schema resides
A Boolean indicator that shows whether the table has a primary key
Schema
Object Catalog: TablespaceMonitors a list of tablespaces.Server
Operating System InformationOperating system details and boot time.Agent
Package CatalogThe packages that are currently available for installation. The information gathered includes:
The package name
The package version
Agent
PG HBA ConfAuthentication configuration information from the pg_hba.conf file.Server
Server InformationServer information.Server
Session InformationSession information. The information includes:
The name of the session user
The date and time that the session connected to the server
The status of the session at the time that the information was gathered (idle, waiting, and so on)
The client address and port number
Server
SettingsMonitors the values currently assigned to GUC variables.Server
SQL ProtectMonitors a server, retrieving information about SQL injection attacks.Server
Slony ReplicationLag data for clusters replicated using Slony.Database
Streaming ReplicationMonitors a cluster that is using streaming replication, retrieving information about:
The sent Xlog location (in bytes)
The write Xlog location (in bytes)
The flush Xlog location (in bytes)
The replay Xlog location (in bytes)
The Xlog lag (in segments)
The Xlog lag (in pages)
Server
Streaming Replication Lag TimeMonitors a cluster that's using streaming replication, retrieving lag information about:
Replication lag time (in seconds)
Current status of replication (running/paused)
Server
Streaming Replication Database ConflictsMonitors a database that's using streaming replication, retrieving information about any conflicts that arise. This includes information about queries that were canceled due to the number of:
Drop tablespace conflicts
Lock timeout conflicts
Old snapshot conflicts
Pinned buffer conflicts
Deadlock conflicts
Server
Table BloatInformation about the current table bloat. The information includes:
The name of the table
The name of the schema in which the table resides
The estimated number of pages
The estimated number of wasted pages
The estimated number of bytes per row
Database
Table Frozen XIDMonitors the frozen XID of each table.Schema
Table SizeInformation about table size. The information includes:
Table size (in MB)
Total index size (in MB)
Total table size, with indexes and TOAST (in MB)
Database
Table StatisticsTable statistics. The information includes:
The number of sequential scans
The number of sequential scan rows
The number of index scans
The number of index scan rows
The number of rows inserted
The number of rows updated
The number of rows deleted
The number of live rows
The number of dead rows
The last VACUUM
The last auto-vacuum
The last ANALYZE
The last auto-analyze
The number of pages estimated by ANALYZE
The number of rows estimated by ANALYZE
Database
Tablespace SizeA list of tablespaces and their sizes.Server
User InformationA list of the current users. The stored information includes:
The user name
The user type (superuser or non-superuser)
The server to which the user is connected
Server
WAL Archive StatusStatus of the WAL archive. The stored information includes:
The number of WAL archives done
The number of WAL archives pending
The last archive time
The number of WAL archives failed
The time of the last failure
Server
xDB ReplicationLag data for clusters replicated using xDB replication.Database
Multixact ID Exhaustion (Wraparound)Information about the multixact ID. The stored information includes:
The name of the database
The oldest current multixact ID in the database
Percentage toward wraparound
Percentage toward emergency autovacuum
Server
Replication SlotsInformation about the replication slots. The stored information includes:
A unique, cluster-wide identifier for the replication slot.
The base name of the shared object containing the output plugin this logical slot is using, or null for physical slot.
The slot type: physical or logical.
The OID of the database this slot is associated with, or null. Only logical slots have an associated database.
The name of the database this slot is associated with, or null. Only logical slots have an associated database.
Active field is True if this slot is currently actively being used.
The oldest transaction that this slot needs the database to retain. VACUUM can't remove tuples deleted by any later transaction
The oldest transaction affecting the system catalogs that this slot needs the database to retain. VACUUM can't remove catalog tuples deleted by any later transaction.
The address (LSN) of oldest WAL, which still might be required by the consumer of this slot and thus won't be automatically removed during checkpoints.
Server

EDB Postgres Distributed (PGD) probes

To monitor the EDB Postgres Distributed group using dashboards, you must enable the following probes. Configure these probes at extension level.

Note

Prior to version 8.4, all these probes are available at the server level.

The user with pgd_superuser can view information from all the following probes. If you are using a version of EDB Postgres Distributed earlier than 4.0, all these probes work with EDB Postgres Distributed Enterprise Edition.

Probe nameInformation monitored by probepgd_monitor role required?Works with PGD SE?
PGD Conflict History SummaryInformation about row conflicts per conflict type. The stored information includes:
The local time of the conflict
The type of the conflict
YesYes
PGD Global LocksInformation about global locks in a EDB Postgres Distributed group. The stored information includes:
The name of the node where the global lock originated
The PID of the process holding the lock
The type of lock (DDL or DML)
The name of the locked relation (for DML Locks) or keys (for advisory locks)
The internal state of the lock acquistion process
The list of backends waiting for the same global lock
The time when the global lock acquire was initiated by origin node
The time when the local node started trying to acquire the local lock
The time acquire_stage last changed
YesYes
PGD Group Camo DetailsInformation about camos in a EDB Postgres Distributed group. The stored information includes:
The name of the node
The node name for whom this node is partner
The node name for whom this node is origin
The connection status
The readiness status
The number of pending or unresolved camo transactions
The LSN of last applied WAL log
The LSN of last received WAL log
NoNo
PGD Group Replication Slot DetailsInformation about replication slots in a EDB Postgres Distributed group. The stored information includes:
The name of the EDB Postgres Distributed group
The name of the origin node
The name of the target node
The slot name on the origin node used by this subscription
The active status
The state of the replication (catchup,streaming, disconnected,..)
The approximate lag time for reported write
The approximate lag time for reported flush
The approximate lag time for reported replay
The bytes difference between sent_lsn and current WAL write position
The bytes difference between write_lsn and current WAL write position
The bytes difference between flush_lsn and current WAL write position
NoYes
PGD Group Subscription SummaryInformation about the summary of subscriptions in the EDB Postgres Distributed group. The stored information includes:
The name of the origin of the subscription
The name of the target of the subscription
The timestamp of the last replayed transaction
The lag between now and time of last replayed transaction
NoYes
PGD Monitor Group RaftThe status and message of a cluster-wide raft check.YesYes
PGD Group Raft DetailsInformation about raft consensus status from all the nodes in a EDB Postgres Distributed group. The stored information includes:
The name of the node
The raft worker state on the node
The node id of the RAFT_LEADER
The raft election internal id
The raft snapshot internal id
YesYes
PGD Monitor Group VersionsThe status and message of cluster-wide version check.YesYes
PGD Group Versions DetailsInformation about version details of the installed Postgres, pglogical, EDB Postgres Distributed for each node in the EDB Postgres Distributed group. The stored information includes:
The name of the node
The installed Postgres version on the node
The installed pglogical version on the node
The version of the EDB Postgres Distributed on the node
The EDB Postgres Distributed edition (Standard/Enterprise) for versions earlier than 4.0.
NoYes
PGD Node Replication RatesInformation about outgoing replication activity from a given node. The stored information includes:
The name of the target peer node
The latest sent position
The latest position reported as replayed
The approximate lag time for reported replay
The bytes difference between replay_lsn and current WAL write position on origin
The human-readable bytes difference between replay_lsn and current WAL write position
Approximate time required for the peer node to catch up to all the changes that are yet to be applied
YesNo
PGD Node SlotsInformation about the mapping of local EDB Postgres Distributed database nodes to replication slots, their status, and replication progress. The stored information includes:
The name of the slot
The name of the target node
The name of the EDB Postgres Distributed group
The database name on the target node
The PID of the process attached to the slot
The catalog XID needed by the slot
The IP address of the client connection
The latest sent position
The latest position reported as replayed
The approximate lag time for reported replay
The bytes difference between replay_lsn and current WAL write position
The human-readable bytes difference between replay_lsn and current WAL write position
YesYes
PGD Node SummaryInformation about all the nodes in the EDB Postgres Distributed group. The stored information includes:
The name of the node
The name of the EDB Postgres Distributed group the node is part of
The consistent state of the node in human-readable form
The state which the node is trying to reach (during join or promotion)
The name of subscribed repsets
YesYes
PGD WorkersInformation about workers in a EDB Postgres Distributed node. The stored information includes:
The PID of the worker process
The worker query start timestamp
The worker state change timestamp
The worker wait event type
The worker wait event
The worker state
The worker role name
The worker commit timestamp
The worker local timestamp
The name of the origin node
The receive LSN
The receive commit LSN
The last exact replay LSN
The last exact flush LSN
The last exact replay timestamp
The worker query
YesYes
PGD Work ErrorsInformation about the work errors in EDB Postgres Distributed database node. The stored information includes:
The process id of the worker causing the error
The name of the EDB Postgres Distributed group the node is part of
The name of the origin node
The name of the source node

The name of the target node
The name of the subscription
The internal identifier of the role of this worker
The name of the role of this worker
The date and time of the error
The age of the error
The description of the error
The context in which the error happened
The remote relation id
The subscription writer id
The subscription writer name
YesYes

Customizing probes

A probe is a scheduled task that returns a set of performance metrics about a specific monitored object. A probe retrieves statistics from a monitored server, database, operating system, or agent. You can use the Manage Probes tab to override the default configuration and customize the behavior of each probe.

To open the Manage Probes tab, select Management > Manage Probes. The Manage Probes tab provides a set of icons that you can use to create and manage probes:

  • Select Manage Custom Probes to open the Custom Probes tab and create or modify a custom probe.
  • Select Copy Probes to open the Copy Probe dialog box and copy the probe configurations from the currently selected object to one or more monitored objects.
Note

Copy Probe isn't supported for the extension-level probes.

A probe monitors a unique set of metrics for each object type (server, database, database object, or agent). Select the name of an object in the tree to review the probes for that object.

To modify the properties associated with a probe, select the name of a probe and customize the settings that are displayed in the Probes table:

  • Move the Default switch in the Execution Frequency columns to N to enable the Minutes and Seconds selectors, and specify a custom value for the length of time between executions of the probe.
  • Move the Default switch in the Enabled? column to No to change the state of the probe and indicate if the probe is active or not.
Note

If data from a disabled probe is used in a chart, the chart displays an information icon in the upper-left corner that allows you to enable the probe by clicking the provided link.

  • Move the Default switch in the Data Retention column to No to enable the Day(s) field and specify the number of days that information gathered by the probe is stored on the PEM server.

The Manage Probes tab might display information about probes that you can't modify from the current node. If you can't modify a probe from the current dialog box, the switches are disabled. Generally, you can modify a disabled probe from a node that's higher in the hierarchy of the PEM client tree control. Select another object in the tree control to modify the probes that are displayed or enabled in the Manage Probes tab.

Creating a custom probe

You can use the PEM Custom Probes tab to create a new probe or modify an existing custom probe. To open the Custom Probes tab, from the Manage Probes tab, select Manage Custom Probes.

Use the Show System Probes? switch to show or hide the system probes on the Custom Probes tab.

You can use the Custom Probes tab to create a probe or modify an existing one. To create a probe:

  1. Select Add in the upper-right corner of the tab.
  2. Provide a name for the new probe in the Probe Name column.
  3. Select Edit (located to the left of the probe name) to review or add the probe definition.

Use the General tab to modify the definition of an existing probe or to specify the properties of a new probe:

  • Use the Probe Name field to provide a name for a new probe.

  • Use the Collection method field to specify the probe type. From the list, select:

    • SQL The probe gathers information by way of a SQL statement.
    • WMI The probe gathers information by way of a Windows Management Instrumentation extension.
    • Batch The probe uses a command-script or shell-script to gather information.

    Before creating a batch probe on a Linux system, you must modify the agent.cfg file, setting the allow_batch_probes parameter to true. Then restart the PEM agent. The agent.cfg file is located in one of the following directories:

    • If you installed PEM using graphical installer: /opt/edb/pem/agent/etc/agent.cfg
    • If you installed PEM using RPM: /usr/edb/pem/agent/etc/agent.cfg

    On Windows systems, agent settings are stored in the registry. Before creating a batch probe, modify the registry entry for the AllowBatchProbes registry entry and restart the PEM agent. PEM registry entries are located in HKEY_LOCAL_MACHINE\Software\EnterpriseDB\PEM\agent.

    Batch probes are platform specific. If you specify a collection method of Batch, you must specify a platform type in the Platform field.

    To invoke a script on a Linux system, you must modify the entry for the batch_script_user parameter of the agent.cfg file and specify the user to use to run the script. You can either specify a non-root user or root for this parameter. If you don't specify a user or the specified user doesn't exist, then the script doesn't run. Restart the agent after modifying the file.

    To invoke a script on a Windows system, set the registry entry for AllowBatchJobSteps to true and restart the PEM agent.

  • Use the Target Type list to select the object type for the probe to monitor. Target Type is disabled if Collection method is WMI. Configure Target Type in probes to ensure that the collected metrics are relevant and accurate for the intended level of the system hierarchy. By setting the target type, you can effectively monitor various components, ranging from individual database objects like tables and indexes to server-wide monitoring.

    Target type configuration matrix

    The following table provides an overview of the target type configurations, their monitoring scope, and the mandatory fields for configuring them.

    In this table:

    • The Target type column determines the object you want to monitor with the probe.
    • The Execution level column determines if the monitoring probes execute once per database, per server, per agent, or per extension level.
    • The Mandatory columns column indicates the coloumns you must configure in the probe query to ensure the required data is collected.
    • The Probe examples column provides some existing probes you can explore to better understand how probes are used in practice.
    Target typeExecution levelMandatory columnsProbe examples
    AgentAgentNonecpu_usage
    ServerServerNone
    DatabaseDatabaseNone
    SchemaDatabaseschema_name
    TableDatabaseschema_name, table_name
    IndexDatabaseschema_name, index_nameindex_size
    SequenceDatabaseschema_name, sequence_name
    ViewDatabaseschema_name, view_name
    FunctionDatabaseschema_name, arg_types, function_type, function_name
    ExtensionExtensionNoneExtension
    Note
    • The custom probes set to a database or larger target type (including schema, table, index, view, sequence, and functions) collect the information at the database level.
    • The system probes set to a schema or larger target type collect the information up to the schema level.

    Proper configuration of the Target Type in probes ensures that the collected metrics are relevant and accurate for the intended level of the system hierarchy. By setting the appropriate target type, users can effectively monitor various components, from the server level down to individual database objects like tables and indexes.

  • Use the Minutes and Seconds selectors to specify how often the probe collects data.

  • Use the Probe Enable? switch to specify if the probe in enabled by default. Specify Yes to enable the probe by default or No to disable the probe by default.

Note

If data from a disabled probe is used in a chart, the chart displays an information icon in the upper-left corner that allows you to enable the probe by clicking the provided link.

  • Use the Data Retention field to specify the number of days that gathered information is retained in the probe's history table.
  • Use the switch next to Discard from history to specify if the server creates a history table for the probe. Select Yes to discard probe history or No to retain the probe history in a table.
  • Use the Platform list to specify the type of platform that the probe monitors. This field is enabled only when the Collection method is Batch.

Use the Columns tab to define the columns in which to store the probe data. To define a new column:

  1. Navigate to the Columns tab and select Add in the upper-right corner.
  2. In the Name field, provide a column name.
  3. Select Edit (to the left of the new column name) to provide information about the column:
  • Provide a descriptive name for the column in the Name field.

  • The Internal Name field isn't enabled for custom probes.

  • Use the Column Type list to specify if the column is a key column (a primary key) or a non-key column. Non-key columns are generally metric items (values that can be graphed).

  • Use the Data Type list to specify the type of data to store in the column.

  • Use the Unit field to specify the unit of measure that applies to the metric stored in the column. This unit is displayed on the y-axis of a custom chart or a Capacity Manager chart. This is an optional field.

  • Use the Graphable switch to specify if the defined metric can be graphed and to make the probe accessible from the Capacity Manager or Manage Charts dialog boxes.

  • Use the Is PIT switch to specify whether to store the metric by point-in-time.

    Point-in-time metrics change (increase or decrease) at any given point of time. For example, database size is a point-in-time metric. At any given point-in-time, the size of the database is fluctuating. Metrics that aren't point-in-time (also referred to as cumulative metrics) are those whose size always increases over time. For example, Blocks Read and Tuples Read are cumulative metrics. The value stays the same or increases.

  • Use the Calculate PIT switch to specify for the server to calculate a point-in-time value for the metric data. Calculate PIT is disabled if Is PIT is Yes.

    PEM allows you to store point-in time-values of cumulative metrics as well. PEM subtracts the last collected value of a cumulative metric from the current value and stores the difference as a point-in-time value.

Use the Code tab to specify the default code for the propbe to execute:

  • If the probe is a SQL probe, you must specify the SQL SELECT statement invoked by the probe on the Code tab. The column names returned by the query must match the Internal Name specified on the Columns tab. The number of columns returned by the query, as well as the column name, data type, and so on, must match the information specified on the Columns tab.

  • If the probe is a batch probe, you must specify the shell or .bat script to invoke when the probe runs. The output of the script is as follows:

    • The first line must contain the names of the columns provided on the Columns tab. Each column name must be separated by a tab (t) character. From the second line onwards, each line must contain the data for each column, separated by a tab character.

    • If a specified column is defined as a key column, make sure that the script doesn't produce duplicate data for that column across lines of output. The number of columns specified in the Columns tab and their names, data type, and so on must match with the output of the script output.

  • If the probe is a WMI probe, you must specify the WMI query as a SELECT WMI query. The column name referenced in the SELECT statement must be same as the name of the corresponding column specified on the Column tab. The column names returned by the query must match the Internal Name specified on the Columns tab. The number of columns returned by the query, as well as the column name, data type, and so on, must match the information specified on the Columns tab.

Use the Alternate Code tab to provide code to invoke if the probe fires on a specific version of the server. To provide version-specific code, move the Applies to any server version? switch to No and select Add. Then, use the Database Version(s) list to select a version, and select Edit (to the left of the version name) to provide the code to execute when the probe fires.

If you select a database version and leave the Probe Code column blank, PEM invokes the code specified on the Code tab when the probe executes on a server that matches that version.

When you've finished defining the probe, select Save (in the corner of the Custom Probes tab) to save the definition and make the probe data available for use on custom charts and graphs.

Exporting or importing a probe

To export the probe, select any probes from the Manage Custom Probes tab, and then select Export in the upper-right corner of the table. To generate the JSON file, select Save File and then select OK.

To import the probe, on the Manage Custom Probes tab, select Import in the upper-right corner of the table. Select Browse to select the JSON file with the probe code to import, and then select Import.

After selecting the file to import, you can select the Skip existing check box. This option skips the probe if it already exists and displays a message letting you know that the import was skipped.

  • If you don't select the check box and the probe already exists, then it doesn't import the probe and an error message is reported.

    !!! Note Import can't overwrite the existing probe as it might be configured to retain historical data as per the configured retention policy.

  • If you don't select the check box and the probe doesn't exist but the corresponding table in the pem schema does, then it imports the probe successfully using the same table.

Note

It's possible for the probe to be deleted and not listed on Manage Custom Probe tab and for the table holding the data of that probe to exist in the pem schema.

Deleting a probe

You can delete only custom probes. To delete a probe, select the probe name in the probes table, and select Delete (located to the upper-right corner of the table). The probe history persists for the length of time specified in the History Retention field in the probe definition. During the deletion, the probe definition is deleted and any corresponding tables are dropped from the pemdata and pemhistory schemas.

System probes are the built-in probes provided by PEM and are part of the PEM schema. You can only modify system probes. If you attempt to delete a system probe, PEM reports an error.

Copying a probe

You can use the Copy Probe Configuration dialog box to copy probe definitions from one monitored object to one or more monitored objects of the same type. To open the Copy Probe Configuration dialog box:

  1. Un the PEM client tree, select the object from which you are copying probes.
  2. Select Management > Manage Probes.
  3. From the Manage Probes tab, select Copy Probe.

The dialog box copies the probe definitions from the object from which you opened the Copy Probe Configuration dialog box to the locations selected on the tree control.

If you specify a parent node in the Copy Probe Configuration tree, PEM copies the probe configurations to each object of the same type that resides under that node in the tree. For example, to copy the probe definitions from one schema to all schemas that reside in a database, select only the parent database of the target schemas. A red warning symbol is displayed to the left of the name of a listed target object if that object is the source of the probe that's being copied.

After you select the target object or objects, select Configure Probes to copy the probe definitions to the location selected in the dialog box.

Managing probes using pemworker

From version 9.6, you can enable and disable a probe using the pemworker utility using --probe-display-name, --probe-internal-name, or --probe-id option.

Examples

On Linux

This example shows how to disable a probe using the probe display name:

export PEM_SERVER_PASSWORD=edb
./pemworker --pem-user enterprisedb --disable-probe --probe-display-name "cpu usage"
Output
Wed Mar 27 01:43:40 2024 INFO: Probe status updated for agent (id: 1)

This example shows how to enable a probe using the probe display name:

export PEM_SERVER_PASSWORD=edb
./pemworker  --pem-user enterprisedb --enable-probe --probe-display-name "database size"
Output
Wed Mar 27 02:02:20 2024 INFO: Probe status updated for server (id: 1)

On Windows

This example shows how to disable a probe using the probe display name:

set PEM_SERVER_PASSWORD=edb
./pemworker.exe DISABLE-PROBE --pem-user postgres --probe-display-name "CPU usage"
Output
INFO: Probe status updated for agent (id: 1)

This example shows how to enable a probe using the probe display name:

set PEM_SERVER_PASSWORD=edb
./pemworker.exe ENABLE-PROBE --pem-user postgres --probe-display-name "CPU usage"
Output
INFO: Probe status updated for agent (id: 1)

PEM probes - reference

A probe is a scheduled task that retrieves information about the database objects that are being monitored by the PEM agent. PEM uses the collected information to build the graphs displayed on each dashboard. The Manage Probes tab (accessed from the Management menu) allows you to modify the data collection schedule and the length of time that PEM retains information returned by a specific probe.

NameInformation monitoredLevel
Background Writer StatisticsInformation about the background writer. The information includes:
The number of timed checkpoints
The number of requested checkpoints
The number of buffers written (by checkpoint)
The number of buffers written (by background writer)
The number of background writer cycles
The number of background buffers written
The number of buffers allocated
Server
Blocked Session InformationInformation about blocked sessions.Server
CPU UsageCPU Usage information.Agent
Data and Log File AnalysisInformation about log files. The information includes:
The name of the log file
The directory in which the log file resides
Server
Database Frozen XIDThe frozen XID of each database.Server
Database SizeInformation about the size of the monitored databases. The information includes:
The time the information was gathered
The database name
The database size (in MB).
Server
Database StatisticsDatabase statistics. The information includes the number of:
Backends
Transactions committed
Transactions rolled back
Blocks read
Blocks hit
Rows returned
Rows fetched
Rows inserted
Rows updated
Rows deleted
Server
Disk Busy InfoInformation about disk activity.
Note: This probe isn't supported on Mac OS X, Solaris, or HP-UX.
Agent
Disk SpaceInformation about disk space usage. The information includes:
The amount of disk space used
The amount of disk space available
Agent
EDB Audit ConfigurationThe audit logging configuration of EDB Postgres Advanced Server.Server
Failover Manager Cluster InfoMonitors a Failover Manager cluster, returning information about the cluster. This probe is enabled when you provide a cluster name and path of the Failover Manager binary in the Server Properties dialog box.Server
Failover Manager Node StatusMonitors a Failover Manager cluster, returning detailed about each node in the cluster. This probe is enabled when you provide a cluster name and path of the Failover Manager binary in the Server Properties dialog box.Server
Function StatisticsMonitors a database, retrieving information about functions. The information includes:
Function names
Argument types
Return values
Database
Index SizeMonitors a database, retrieving information about indexes. The information includes:
The name of the index
The time the data was gathered
The size of the index (in MB)
Database
Index StatisticsIndex statistics. The information includes the number of:
Index scans
Rows read
Rows fetched
Blocks read
Blocks hit
Database
Installed PackagesThe packages that are currently installed. The information gathered includes:
The name of the installed package
The version of the installed package
The date and time that the probe executed
Agent
IO AnalysisMonitors disk I/O information. The information includes:
The number of blocks read
The number of blocks written
The date and time that the probe executed
Note: This probe isn't supported on Mac OS X.
Agent
Load AverageCPU load averages. The information includes:
The 1-minute load average
The 5-minute load average
The 15-minute load average
Note: This probe isn't supported on Windows.
Agent
Lock InformationMonitors lock information. The information includes:
The database name
The lock type
The lock mode
The process holding the lock
Server
Memory UsageInformation about system memory usage. The information includes:
Total RAM in MB
Free RAM in MB
Total swap memory in MB
Free swap memory in MB
Shared system memory in MB (used by tuning wizard to tune the memory parameters for the database server)
- On non-Windows system, it's the shmmax value and read from /proc/sys/kernel/shmmax.
- On Windows, it's same as total memory.
Agent
Network StatisticsNetwork statistics. The information includes:
The interface IP address
The number of packets sent
The number of packets received
The number of bytes sent
The number of bytes received
The link speed (in MB/second)
Agent
Number of Prepared TransactionsStores the number of prepared transactions.Server
Number of WAL FilesThe number of WAL files.Server
Object Catalog: DatabaseMonitors a list of databases and their properties. The information includes:
The database name
The database encoding type
If the database allows user connections or system connections
Server
Object Catalog: Foreign KeyMonitors a list of foreign keys and their properties. The information includes:
The name of the table that contains the foreign key
The name of the table that the foreign key references
The name of the database in which the table resides
The name of the schema in which the table resides
Schema
Object Catalog: FunctionMonitors a list of functions and their properties. The information includes:
The name of the function
The name of the schema in which the function resides
The name of the database in which the function resides
Schema
Object Catalog: IndexMonitors a list of indexes and their properties. The information includes:
The name of the index
The name of the table that the index is associated with
The name of the database in which the indexed table resides
Schema
Object Catalog: SchemaMonitors a list of schemas and their associated databases and servers.Database
Object Catalog: SequenceMonitors a list of sequences and their properties.Schema
Object Catalog: TableMonitors a list of table information. The information includes:
The table name
The name of the schema in which the table resides
The name of the database in which the schema resides
A Boolean indicator that shows whether the table has a primary key
Schema
Object Catalog: TablespaceMonitors a list of tablespaces.Server
Operating System InformationThe operating system details and boot time.Agent
Package CatalogThe packages that are currently available for installation. The information gathered includes:
The package name
The package version
Agent
PG HBA ConfAuthentication configuration information from the pg_hba.conf file.Server
Server InformationServer information.Server
Session InformationSession information. The information includes:
The name of the session user
The date and time that the session connected to the server
The status of the session at the time that the information was gathered (idle, waiting, and so on)
The client address and port number
Server
SettingsThe values currently assigned to GUC variables.Server
SQL ProtectMonitors a server, retrieving information about SQL injection attacks.Server
Slony ReplicationLag data for clusters replicated using Slony.Database
Streaming ReplicationMonitors a cluster that's using streaming replication, retrieving information about:
The sent Xlog location (in bytes)
The write Xlog location (in bytes)
The flush Xlog location (in bytes)
The replay Xlog location (in bytes)
The Xlog lag (in segments)
The Xlog lag (in pages)
Server
Streaming Replication Lag TimeMonitors a cluster that's using streaming replication, retrieving lag information about:
Replication lag time (in seconds)
Current status of replication (running/paused)
Server
Streaming Replication Database ConflictsMonitors a database that's using streaming replication, retrieving information about any conflicts that arise. This includes information about queries that were canceled due to the number of:
Drop tablespace conflicts
Lock timeout conflicts
Old snapshot conflicts
Pinned buffer conflicts
Deadlock conflicts
Server
Table BloatInformation about the current table bloat. The information includes:
The name of the table
The name of the schema in which the table resides
The estimated number of pages
The estimated number of wasted pages
The estimated number of bytes per row
Database
Table Frozen XIDThe frozen XID of each table.Schema
Table SizeInformation about table size. The information includes:
Table size (in MB)
Total index size (in MB)
Total table size, with indexes and TOAST (in MB)
Database
Table StatisticsTable statistics. The information includes:
The number of sequential scans
The number of sequential scan rows
The number of index scans
The number of index scan rows
The number of rows inserted
The number of rows updated
The number of rows deleted
The number of live rows
The number of dead rows
The last VACUUM
The last auto-vacuum
The last ANALYZE
The last auto-analyze
The number of pages estimated by ANALYZE
The number of rows estimated by ANALYZE
Database
Tablespace SizeA list of tablespaces and their sizes.Server
User InformationA list of the current users. The stored information includes:
The user name
The user type (superuser or non-superuser)
The server to which the user is connected
Server
WAL Archive StatusThe status of the WAL archive. The stored information includes:
The number of WAL archives done
The number of WAL archives pending
The last archive time
The number of WAL archives failed
The time of the last failure
Server
xDB ReplicationMonitors lag data for clusters replicated using xDB replication.Database