Global Profiling Engine
Global Profiling Engine reference
This page applies to:
- HAProxy Enterprise - all versions
This section describes all configuration options for the Global Profiling Engine.
Startup arguments Jump to heading
The Global Profiling Engine supports the following startup arguments, which you can set in the file /etc/default/hapee-extras-gpe:
| Argument | Description | 
|---|---|
| -f <stktagg_config_file> | Sets the path to the GPE peers configuration file. | 
| -c <gpe_config_file> | Sets the path to the GPE settings configuration file. | 
| -d | Enables debug mode. | 
| -l [<flag>:]<log_file> | Enables logging to a file and sets the path to the target file. Supported flags are: A: appendW: truncate | 
| -v | Displays the version. | 
GPE peers configuration Jump to heading
The following fields can be set in the /etc/hapee-extras/hapee-gpe-stktagg.cfg file:
global section Jump to heading
The global section supports the following fields:
| Field | Description | 
|---|---|
| bind | Available since GPE 1.0 Adds a listener to which aggregations sections can be attached. This allows GPE to listen for several aggregationssections on the same IP/port. You can set multiplebindlines, and more than one can serve the sameaggregationssection if they use the sameuse_aggrsvalues. See thebindsyntax section below. | 
| cpu-map | This has the same meaning as the cpu-mapdirective for HAProxy. It configures the CPU affinity of the GPE processes. | 
| dynamic-peers | Available since GPE 1.0 Enables the GPE to accept up to 64 concurrent connections from peers that are not defined in the configuration file by aggregationssections. This limit of 64 concurrents peers includes the ones set up by the configuration file. | 
| hash-table | Available since GPE 1.0 Configures global hash-table settings that are common for all stick tables managed by the process. | 
| source | Binds an IP/port for outgoing connections. Set it as source <ipv4 or ipv6>[:<port>]. | 
| stats socket | Creates a listener with which you can interact through a TCP or UNIX domain socket with the aggregator at runtime. | 
| trash-batch | Sets the number of incoming update messages on a table to perform a lookup of expired entries to trash. A maximum of the same number of entries is trashed. Default: 10000. | 
The bind line has the following syntax:
text
text
where:
| Argument | Description | 
|---|---|
| use_aggrs | This option must be followed by the special value  NOTE: As a listener configured on a  | 
The hash-table line has the following syntax:
text
text
where:
| Argument | Description | 
|---|---|
| load-factor <lf> | Sets the optimal load factor that the GPE will try its best to enforce on the hash-table. Load factor is the ratio of the current number of entries in the table divided by the number of buckets. When load factor is reached, the GPE will automatically try to grow (and rehash) the hash-table on the fly. 
 | 
| low <low> | Sets the pow2 (power of 2) exponent that will be used to compute the number of buckets. 
 | 
| high <high> | Sets the pow2 (power of 2) exponent that will be used to compute the buckets upper limit (maximum number of buckets that the hash-table may allocate upon resizes). 
 | 
| steps <steps> | Takes a list of intermediary pow2 exponents (separated by comma) that will be used for hash-table resizing. Values outside of  
 | 
aggregations section Jump to heading
You can have one or more aggregations sections, where the following fields are supported:
| Field | Description | 
|---|---|
| dynamic-peers | Available since GPE 1.0 This field has exactly the same meaning as dynamic-peersin theglobalsection. It enables the dynamic peers feature. But contrary to the option forglobalsection, the one foraggregationssections limits the feature to thataggregationssection. | 
| forward | This field supports the syntax forward <suffix1,suffix2...>. The stick tables with those suffixes are considered to be forwarded from upward to downward servers. Note that updates to one of those tables coming from a down server will be ignored. | 
| from | Gives some information to the GPE about how to name the destination stick tables (the aggregated stick-tables). You can set multiple  
 
 A suffix string must have  
 
 | 
| peer | The  
 They are made of two mandatory settings, their name and IP/port, followed by optional, exclusive keywords  
 
 Note that there can only be at most 64 peers handled by an  
 If there is no listener configured by a  | 
Historical statistics configuration Jump to heading
The following fields can be set in the /etc/hapee-extras/hapee-gpe.json file:
| Field | Description | 
|---|---|
| aggregate_tables | An array of stick table names that should be processed. One set of aggregates will be created for each stick table as a whole. | 
| collector_queue_size | The size of the message queue between workers and the collector. It must be greater than 2 and a power of 2. Default: 64. | 
| datadir | The directory in which to store historical data files. | 
| default_stick_table_handling | Indicates how the server should process stick tables that are not listed in the ignore_tables,detail_tables, oraggregate_tablesarrays.  Values:0= ignore,1= aggregate,2= detailed processing (Experimental). | 
| default_toplist_table_handling | Available since GPE 1.0 Indicates whether to enable the generation of toplist statistics for tables not included in enable_toplist_tables. Enabled when1, disabled when0. Default:0. | 
| detail_tables(Experimental) | An array of stick table names that should be processed. One set of aggregates will be created for every value in the stick table. | 
| disable_toplist_tables | Available since GPE 1.0 A list of stick tables to not generate toplists for. | 
| enable_toplist_tables | Available since GPE 1.0 A list of stick tables to generate toplists for. | 
| httpd_addr | Available since GPE 1.0 The IP address on which to publish historical statistics data. Can be IPv4 or IPv6, with or without brackets. IPv4 wildcard is *. Default:0.0.0.0. | 
| httpd_port | The TCP port on which to publish historical statistics data. Default: 9888. | 
| ignore_tables | An array of stick table names that should be skipped during processing. | 
| inter_worker_queue_size | The size of the message queue that handles communication between workers. It must be greater than 2 and a power of 2. Default: 1024. | 
| prometheus_exporter | Available since GPE 1.0 Generate profiling engine data in Prometheus format at the profiling engine’s  
 Default:  | 
| stat_retentions | An array of data retention policies. Each policy should have: duration: an integer value in seconds indicating the size of the bucket (i.e. time period) to aggregate data for.retention: the number of buckets to keep. | 
| toplist_element_count | Available since GPE 1.0 The number of elements in a toplist. Default: 10. Max:50. | 
| worker_thread_count | The number of worker threads to start. Default: 2. | 
Historical statistics reference Jump to heading
Calling the /aggs endpoint on port 9888 returns a list of available statistics. For example, if you set the following retention policy in the stat_retentions field:
json
json
The /aggs endpoint would return data for each bucket. Each bucket contains one hour of data (3600 seconds), representing one of the hours during the last 24 hours.  For example, the following statistics are recorded for the hour that happened one hour ago:
text
text
Each line is a key and value. The key has this format:
/name-of-stick-table . name-of-counter . bucket-duration . time since bucket occurred . statistic
For example:
text
text
Some lines have a negative number in them:
text
text
This indicates a sliding time window that has a begin and end time that changes at a regular interval (i.e. an hour ago from now, or more realistically, at the next time the smallest bucket is calculated). In contrast, the following metric would be updated only at the top of every hour:
text
text
The table below describes each statistic:
| Field | Description | 
|---|---|
| cnt | The count of data points of the counter (e.g. HTTP rate limit) recorded in the bucket. | 
| sum | The sum of all data point values in the bucket. | 
| avg | An average of all data points in the bucket that preserves the time period of the stick table counter, which makes it easy to work with when comparing it to current request rates in HAProxy Enterprise; the sum of all data points (e.g. 3547) is multiplied by the stick table counter period (e.g. 10 for http_req_rate(10s)), then divided by the duration of the bucket (e.g. 3600). | 
| persec_avg | An average of all data points in the bucket, converted to a 1-second average (discards the period of the stick table counter). | 
| burst_avg | A traditional, mathematical average; the sum of all data points is divided by the count. | 
| min | The minimum data point value in the bucket. | 
| max | The maximum data point value in the bucket. | 
| 50p | The 50th percentile. | 
| 75p | The 75th percentile. | 
| 90p | The 90th percentile. | 
| 95p | The 95th percentile. | 
| 99p | The 99th percentile. | 
| 99.9p | The 99.9th percentile. | 
GPE Runtime API Jump to heading
You can issue commands to the running GPE service using the GPE Runtime API. The following commands are available:
- List all aggregation debugging information
- Dump aggregated stick-table contents in HAProxy Enterprise format
- Dump aggregated stick-table contents in stktaggformat
- Display API help
Add socket Jump to heading
You communicate with the GPE service through a TCP or UNIX domain socket similar to the one used for the HAProxy Enterprise Runtime API. Define the socket using the stats socket directive in the GPE configuration. The directive creates a listener for interacting with the aggregator at runtime.
To add Runtime API support:
- 
On the Global Profiling Engine server, edit the file /etc/hapee-extras/hapee-gpe-stktagg.cfg.
- 
Add the stats socketdirective to the global section:hapee-gpe-stktagg.cfghaproxyglobal# Enables the Global Profiling Engine APIstats socket /var/run/hapee-extras/gpe-api.sockhapee-gpe-stktagg.cfghaproxyglobal# Enables the Global Profiling Engine APIstats socket /var/run/hapee-extras/gpe-api.sock
- 
You can also add support by specifying the IP address and port: hapee-gpe-stktagg.cfghaproxyglobal# connect to 127.0.0.1 on port 11111 to access runtime CLI.stats socket 127.0.0.1:11111hapee-gpe-stktagg.cfghaproxyglobal# connect to 127.0.0.1 on port 11111 to access runtime CLI.stats socket 127.0.0.1:11111
- 
Reload the service. nixsudo systemctl reload hapee-extras-gpenixsudo systemctl reload hapee-extras-gpe
Commands Jump to heading
The following commands are supported.
Show aggregations Jump to heading
List all aggregation debugging information.
Syntax:
text
text
Example: Show details for the first peer in the GPE aggregation:
nix
nix
outputtext
outputtext
Dump table contents in HAProxy format Jump to heading
Dump aggregated stick-table contents (HAProxy Enterprise format).
Syntax:
text
text
Example: Dump table contents for an aggregation named data:
nix
nix
outputtext
outputtext
Example: Dump table contents for table /request_rates in aggregation data:
nix
nix
outputtext
outputtext
Example: Dump table contents for table /request_rates in aggregation data and just for the peer with hostname ip-10-80-10-31:
nix
nix
outputtext
outputtext
GPE 1.0 and later: You can filter the dump output. The filter syntax is:
text
text
When you use the data. form, the filter returns rows from the table that match the compared value. Specify a stored data type in <type>; this data type must be stored in the table or else an error is reported. The command compares the data according to <operator> with the 64-bit integer <value>. Operators are the same ones used with HAProxy Enterprise:
- eqmatches entries whose data is equal to this value.
- nematches entries whose data is not equal to this value.
- lematches entries whose data is less than or equal to this value.
- gematches entries whose data is greater than or equal to this value.
- ltmatches entries whose data is less than this value.
- gtmatches entries whose data is greater than this value.
In this form, you can use up to four data filter entries.
When you use the key form, the filter returns rows from the table that having a matching key, such as a matching IPv4 address. The key must be of the same type as the table, which currently is limited to ipv4, ipv6, integer, and string.
When you use the ptr form, the filter returns rows from the table that having a matching address pointer. <ptr> is written in the form 0xffff and must correspond to the address returned by a previous show table command. Matching an entry using its pointer may be relevant if you can’t match the entry using the key due to an empty key or incompatible characters on the CLI.
Example: Dump the rows of the aggregated stick table if the request count is greater than or equal to 9:
nix
nix
outputtext
outputtext
Dump table contents in stktagg format Jump to heading
Dump aggregated stick-table contents in stktagg format. The output includes tables whose content has expired.
Syntax:
text
text
Example: Dump table contents for an aggregations section named data and table named /request_rates.agg:
nix
nix
outputtext
outputtext
Display help Jump to heading
Display API help.
Syntax:
text
text
Do you have any suggestions on how we can improve the content of this page?