Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 1 | ------------------------ |
| 2 | HAProxy Management Guide |
| 3 | ------------------------ |
Willy Tarreau | eaded98 | 2022-12-01 15:25:34 +0100 | [diff] [blame] | 4 | version 2.8 |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 5 | |
| 6 | |
| 7 | This document describes how to start, stop, manage, and troubleshoot HAProxy, |
| 8 | as well as some known limitations and traps to avoid. It does not describe how |
| 9 | to configure it (for this please read configuration.txt). |
| 10 | |
| 11 | Note to documentation contributors : |
| 12 | This document is formatted with 80 columns per line, with even number of |
| 13 | spaces for indentation and without tabs. Please follow these rules strictly |
| 14 | so that it remains easily printable everywhere. If you add sections, please |
| 15 | update the summary below for easier searching. |
| 16 | |
| 17 | |
| 18 | Summary |
| 19 | ------- |
| 20 | |
| 21 | 1. Prerequisites |
| 22 | 2. Quick reminder about HAProxy's architecture |
| 23 | 3. Starting HAProxy |
| 24 | 4. Stopping and restarting HAProxy |
| 25 | 5. File-descriptor limitations |
| 26 | 6. Memory management |
| 27 | 7. CPU usage |
| 28 | 8. Logging |
| 29 | 9. Statistics and monitoring |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 30 | 9.1. CSV format |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 31 | 9.2. Typed output format |
| 32 | 9.3. Unix Socket commands |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 33 | 9.4. Master CLI |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 34 | 9.4.1. Master CLI commands |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 35 | 10. Tricks for easier configuration management |
| 36 | 11. Well-known traps to avoid |
| 37 | 12. Debugging and performance issues |
| 38 | 13. Security considerations |
| 39 | |
| 40 | |
| 41 | 1. Prerequisites |
| 42 | ---------------- |
| 43 | |
| 44 | In this document it is assumed that the reader has sufficient administration |
| 45 | skills on a UNIX-like operating system, uses the shell on a daily basis and is |
| 46 | familiar with troubleshooting utilities such as strace and tcpdump. |
| 47 | |
| 48 | |
| 49 | 2. Quick reminder about HAProxy's architecture |
| 50 | ---------------------------------------------- |
| 51 | |
Willy Tarreau | 3f36448 | 2019-02-27 15:01:46 +0100 | [diff] [blame] | 52 | HAProxy is a multi-threaded, event-driven, non-blocking daemon. This means is |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 53 | uses event multiplexing to schedule all of its activities instead of relying on |
| 54 | the system to schedule between multiple activities. Most of the time it runs as |
| 55 | a single process, so the output of "ps aux" on a system will report only one |
| 56 | "haproxy" process, unless a soft reload is in progress and an older process is |
| 57 | finishing its job in parallel to the new one. It is thus always easy to trace |
Willy Tarreau | 3f36448 | 2019-02-27 15:01:46 +0100 | [diff] [blame] | 58 | its activity using the strace utility. In order to scale with the number of |
| 59 | available processors, by default haproxy will start one worker thread per |
| 60 | processor it is allowed to run on. Unless explicitly configured differently, |
| 61 | the incoming traffic is spread over all these threads, all running the same |
| 62 | event loop. A great care is taken to limit inter-thread dependencies to the |
| 63 | strict minimum, so as to try to achieve near-linear scalability. This has some |
| 64 | impacts such as the fact that a given connection is served by a single thread. |
| 65 | Thus in order to use all available processing capacity, it is needed to have at |
| 66 | least as many connections as there are threads, which is almost always granted. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 67 | |
| 68 | HAProxy is designed to isolate itself into a chroot jail during startup, where |
| 69 | it cannot perform any file-system access at all. This is also true for the |
| 70 | libraries it depends on (eg: libc, libssl, etc). The immediate effect is that |
| 71 | a running process will not be able to reload a configuration file to apply |
| 72 | changes, instead a new process will be started using the updated configuration |
| 73 | file. Some other less obvious effects are that some timezone files or resolver |
| 74 | files the libc might attempt to access at run time will not be found, though |
| 75 | this should generally not happen as they're not needed after startup. A nice |
| 76 | consequence of this principle is that the HAProxy process is totally stateless, |
| 77 | and no cleanup is needed after it's killed, so any killing method that works |
| 78 | will do the right thing. |
| 79 | |
| 80 | HAProxy doesn't write log files, but it relies on the standard syslog protocol |
| 81 | to send logs to a remote server (which is often located on the same system). |
| 82 | |
| 83 | HAProxy uses its internal clock to enforce timeouts, that is derived from the |
| 84 | system's time but where unexpected drift is corrected. This is done by limiting |
| 85 | the time spent waiting in poll() for an event, and measuring the time it really |
| 86 | took. In practice it never waits more than one second. This explains why, when |
| 87 | running strace over a completely idle process, periodic calls to poll() (or any |
| 88 | of its variants) surrounded by two gettimeofday() calls are noticed. They are |
| 89 | normal, completely harmless and so cheap that the load they imply is totally |
| 90 | undetectable at the system scale, so there's nothing abnormal there. Example : |
| 91 | |
| 92 | 16:35:40.002320 gettimeofday({1442759740, 2605}, NULL) = 0 |
| 93 | 16:35:40.002942 epoll_wait(0, {}, 200, 1000) = 0 |
| 94 | 16:35:41.007542 gettimeofday({1442759741, 7641}, NULL) = 0 |
| 95 | 16:35:41.007998 gettimeofday({1442759741, 8114}, NULL) = 0 |
| 96 | 16:35:41.008391 epoll_wait(0, {}, 200, 1000) = 0 |
| 97 | 16:35:42.011313 gettimeofday({1442759742, 11411}, NULL) = 0 |
| 98 | |
| 99 | HAProxy is a TCP proxy, not a router. It deals with established connections that |
| 100 | have been validated by the kernel, and not with packets of any form nor with |
| 101 | sockets in other states (eg: no SYN_RECV nor TIME_WAIT), though their existence |
| 102 | may prevent it from binding a port. It relies on the system to accept incoming |
| 103 | connections and to initiate outgoing connections. An immediate effect of this is |
| 104 | that there is no relation between packets observed on the two sides of a |
| 105 | forwarded connection, which can be of different size, numbers and even family. |
| 106 | Since a connection may only be accepted from a socket in LISTEN state, all the |
| 107 | sockets it is listening to are necessarily visible using the "netstat" utility |
| 108 | to show listening sockets. Example : |
| 109 | |
| 110 | # netstat -ltnp |
| 111 | Active Internet connections (only servers) |
| 112 | Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name |
| 113 | tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1629/sshd |
| 114 | tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 2847/haproxy |
| 115 | tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN 2847/haproxy |
| 116 | |
| 117 | |
| 118 | 3. Starting HAProxy |
| 119 | ------------------- |
| 120 | |
| 121 | HAProxy is started by invoking the "haproxy" program with a number of arguments |
| 122 | passed on the command line. The actual syntax is : |
| 123 | |
| 124 | $ haproxy [<options>]* |
| 125 | |
| 126 | where [<options>]* is any number of options. An option always starts with '-' |
| 127 | followed by one of more letters, and possibly followed by one or multiple extra |
| 128 | arguments. Without any option, HAProxy displays the help page with a reminder |
| 129 | about supported options. Available options may vary slightly based on the |
| 130 | operating system. A fair number of these options overlap with an equivalent one |
| 131 | if the "global" section. In this case, the command line always has precedence |
| 132 | over the configuration file, so that the command line can be used to quickly |
| 133 | enforce some settings without touching the configuration files. The current |
| 134 | list of options is : |
| 135 | |
| 136 | -- <cfgfile>* : all the arguments following "--" are paths to configuration |
Maxime de Roucy | 379d9c7 | 2016-05-13 23:52:56 +0200 | [diff] [blame] | 137 | file/directory to be loaded and processed in the declaration order. It is |
| 138 | mostly useful when relying on the shell to load many files that are |
| 139 | numerically ordered. See also "-f". The difference between "--" and "-f" is |
| 140 | that one "-f" must be placed before each file name, while a single "--" is |
| 141 | needed before all file names. Both options can be used together, the |
| 142 | command line ordering still applies. When more than one file is specified, |
| 143 | each file must start on a section boundary, so the first keyword of each |
| 144 | file must be one of "global", "defaults", "peers", "listen", "frontend", |
| 145 | "backend", and so on. A file cannot contain just a server list for example. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 146 | |
Maxime de Roucy | 379d9c7 | 2016-05-13 23:52:56 +0200 | [diff] [blame] | 147 | -f <cfgfile|cfgdir> : adds <cfgfile> to the list of configuration files to be |
| 148 | loaded. If <cfgdir> is a directory, all the files (and only files) it |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 149 | contains are added in lexical order (using LC_COLLATE=C) to the list of |
Maxime de Roucy | 379d9c7 | 2016-05-13 23:52:56 +0200 | [diff] [blame] | 150 | configuration files to be loaded ; only files with ".cfg" extension are |
| 151 | added, only non hidden files (not prefixed with ".") are added. |
| 152 | Configuration files are loaded and processed in their declaration order. |
| 153 | This option may be specified multiple times to load multiple files. See |
| 154 | also "--". The difference between "--" and "-f" is that one "-f" must be |
| 155 | placed before each file name, while a single "--" is needed before all file |
| 156 | names. Both options can be used together, the command line ordering still |
| 157 | applies. When more than one file is specified, each file must start on a |
| 158 | section boundary, so the first keyword of each file must be one of |
| 159 | "global", "defaults", "peers", "listen", "frontend", "backend", and so on. |
| 160 | A file cannot contain just a server list for example. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 161 | |
| 162 | -C <dir> : changes to directory <dir> before loading configuration |
| 163 | files. This is useful when using relative paths. Warning when using |
| 164 | wildcards after "--" which are in fact replaced by the shell before |
| 165 | starting haproxy. |
| 166 | |
| 167 | -D : start as a daemon. The process detaches from the current terminal after |
| 168 | forking, and errors are not reported anymore in the terminal. It is |
| 169 | equivalent to the "daemon" keyword in the "global" section of the |
| 170 | configuration. It is recommended to always force it in any init script so |
| 171 | that a faulty configuration doesn't prevent the system from booting. |
| 172 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 173 | -L <name> : change the local peer name to <name>, which defaults to the local |
William Lallemand | daf4cd2 | 2018-04-17 16:46:13 +0200 | [diff] [blame] | 174 | hostname. This is used only with peers replication. You can use the |
| 175 | variable $HAPROXY_LOCALPEER in the configuration file to reference the |
| 176 | peer name. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 177 | |
| 178 | -N <limit> : sets the default per-proxy maxconn to <limit> instead of the |
| 179 | builtin default value (usually 2000). Only useful for debugging. |
| 180 | |
| 181 | -V : enable verbose mode (disables quiet mode). Reverts the effect of "-q" or |
| 182 | "quiet". |
| 183 | |
William Lallemand | e202b1e | 2017-06-01 17:38:56 +0200 | [diff] [blame] | 184 | -W : master-worker mode. It is equivalent to the "master-worker" keyword in |
| 185 | the "global" section of the configuration. This mode will launch a "master" |
| 186 | which will monitor the "workers". Using this mode, you can reload HAProxy |
| 187 | directly by sending a SIGUSR2 signal to the master. The master-worker mode |
| 188 | is compatible either with the foreground or daemon mode. It is |
| 189 | recommended to use this mode with multiprocess and systemd. |
| 190 | |
Pavlos Parissis | f65f257 | 2018-02-07 21:42:16 +0100 | [diff] [blame] | 191 | -Ws : master-worker mode with support of `notify` type of systemd service. |
| 192 | This option is only available when HAProxy was built with `USE_SYSTEMD` |
| 193 | build option enabled. |
| 194 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 195 | -c : only performs a check of the configuration files and exits before trying |
| 196 | to bind. The exit status is zero if everything is OK, or non-zero if an |
Willy Tarreau | bebd212 | 2020-04-15 16:06:11 +0200 | [diff] [blame] | 197 | error is encountered. Presence of warnings will be reported if any. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 198 | |
Maximilian Mader | fc0cceb | 2021-06-06 00:50:22 +0200 | [diff] [blame] | 199 | -cc : evaluates a condition as used within a conditional block of the |
| 200 | configuration. The exit status is zero if the condition is true, 1 if the |
| 201 | condition is false or 2 if an error is encountered. |
| 202 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 203 | -d : enable debug mode. This disables daemon mode, forces the process to stay |
Willy Tarreau | ccf4299 | 2020-10-09 19:15:03 +0200 | [diff] [blame] | 204 | in foreground and to show incoming and outgoing events. It must never be |
| 205 | used in an init script. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 206 | |
Erwan Le Goas | b0c0501 | 2022-09-14 17:51:55 +0200 | [diff] [blame] | 207 | -dC[key] : dump the configuration file. It is performed after the lines are |
| 208 | tokenized, so comments are stripped and indenting is forced. If a non-zero |
| 209 | key is specified, lines are truncated before sensitive/confidential fields, |
| 210 | and identifiers and addresses are emitted hashed with this key using the |
Michael Prokop | 9a62e35 | 2022-12-09 12:28:46 +0100 | [diff] [blame] | 211 | same algorithm as the one used by the anonymized mode on the CLI. This |
Erwan Le Goas | b0c0501 | 2022-09-14 17:51:55 +0200 | [diff] [blame] | 212 | means that the output may safely be shared with a developer who needs it |
| 213 | to figure what's happening in a dump that was anonymized using the same |
| 214 | key. Please also see the CLI's "set anon" command. |
| 215 | |
Amaury Denoyelle | 7b01a8d | 2021-03-29 10:29:07 +0200 | [diff] [blame] | 216 | -dD : enable diagnostic mode. This mode will output extra warnings about |
| 217 | suspicious configuration statements. This will never prevent startup even in |
| 218 | "zero-warning" mode nor change the exit status code. |
| 219 | |
Christopher Faulet | 678a4ce | 2023-02-14 16:12:54 +0100 | [diff] [blame] | 220 | -dF : disable data fast-forward. It is a mechanism to optimize the data |
| 221 | forwarding by passing data directly from a side to the other one without |
| 222 | waking the stream up. Thanks to this directive, it is possible to disable |
| 223 | this optimization. Note it also disable any kernel tcp splicing. This |
| 224 | command is not meant for regular use, it will generally only be suggested by |
| 225 | developers along complex debugging sessions. |
| 226 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 227 | -dG : disable use of getaddrinfo() to resolve host names into addresses. It |
| 228 | can be used when suspecting that getaddrinfo() doesn't work as expected. |
| 229 | This option was made available because many bogus implementations of |
| 230 | getaddrinfo() exist on various systems and cause anomalies that are |
| 231 | difficult to troubleshoot. |
| 232 | |
Willy Tarreau | 76871a4 | 2022-03-08 16:01:40 +0100 | [diff] [blame] | 233 | -dK<class[,class]*> : dumps the list of registered keywords in each class. |
| 234 | The list of classes is available with "-dKhelp". All classes may be dumped |
| 235 | using "-dKall", otherwise a selection of those shown in the help can be |
| 236 | specified as a comma-delimited list. The output format will vary depending |
| 237 | on what class of keywords is being dumped (e.g. "cfg" will show the known |
Willy Tarreau | 55b9689 | 2022-05-31 08:07:43 +0200 | [diff] [blame] | 238 | configuration keywords in a format resembling the config file format while |
Willy Tarreau | 76871a4 | 2022-03-08 16:01:40 +0100 | [diff] [blame] | 239 | "smp" will show sample fetch functions prefixed with a compatibility matrix |
| 240 | with each rule set). These may rarely be used as-is by humans but can be of |
| 241 | great help for external tools that try to detect the appearance of new |
| 242 | keywords at certain places to automatically update some documentation, |
| 243 | syntax highlighting files, configuration parsers, API etc. The output |
| 244 | format may evolve a bit over time so it is really recommended to use this |
| 245 | output mostly to detect differences with previous archives. Note that not |
| 246 | all keywords are listed because many keywords have existed long before the |
| 247 | different keyword registration subsystems were created, and they do not |
| 248 | appear there. However since new keywords are only added via the modern |
| 249 | mechanisms, it's reasonably safe to assume that this output may be used to |
| 250 | detect language additions with a good accuracy. The keywords are only |
| 251 | dumped after the configuration is fully parsed, so that even dynamically |
| 252 | created keywords can be dumped. A good way to dump and exit is to run a |
| 253 | silent config check on an existing configuration: |
| 254 | |
| 255 | ./haproxy -dKall -q -c -f foo.cfg |
| 256 | |
| 257 | If no configuration file is available, using "-f /dev/null" will work as |
| 258 | well to dump all default keywords, but then the return status will not be |
| 259 | zero since there will be no listener, and will have to be ignored. |
| 260 | |
Willy Tarreau | 654726d | 2021-12-28 15:43:11 +0100 | [diff] [blame] | 261 | -dL : dumps the list of dynamic shared libraries that are loaded at the end |
| 262 | of the config processing. This will generally also include deep dependencies |
| 263 | such as anything loaded from Lua code for example, as well as the executable |
| 264 | itself. The list is printed in a format that ought to be easy enough to |
| 265 | sanitize to directly produce a tarball of all dependencies. Since it doesn't |
| 266 | stop the program's startup, it is recommended to only use it in combination |
| 267 | with "-c" and "-q" where only the list of loaded objects will be displayed |
| 268 | (or nothing in case of error). In addition, keep in mind that when providing |
| 269 | such a package to help with a core file analysis, most libraries are in fact |
| 270 | symbolic links that need to be dereferenced when creating the archive: |
| 271 | |
| 272 | ./haproxy -W -q -c -dL -f foo.cfg | tar -T - -hzcf archive.tgz |
| 273 | |
Willy Tarreau | 9ef2742 | 2023-03-22 11:37:54 +0100 | [diff] [blame] | 274 | When started in verbose mode (-V) the shared libraries' address ranges are |
| 275 | also enumerated, unless the quiet mode is in use (-q). |
| 276 | |
Willy Tarreau | f4b79c4 | 2022-02-23 15:20:53 +0100 | [diff] [blame] | 277 | -dM[<byte>[,]][help|options,...] : forces memory poisoning, and/or changes |
| 278 | memory other debugging options. Memory poisonning means that each and every |
Willy Tarreau | bafbe01 | 2017-11-24 17:34:44 +0100 | [diff] [blame] | 279 | memory region allocated with malloc() or pool_alloc() will be filled with |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 280 | <byte> before being passed to the caller. When <byte> is not specified, it |
| 281 | defaults to 0x50 ('P'). While this slightly slows down operations, it is |
| 282 | useful to reliably trigger issues resulting from missing initializations in |
| 283 | the code that cause random crashes. Note that -dM0 has the effect of |
| 284 | turning any malloc() into a calloc(). In any case if a bug appears or |
| 285 | disappears when using this option it means there is a bug in haproxy, so |
Willy Tarreau | f4b79c4 | 2022-02-23 15:20:53 +0100 | [diff] [blame] | 286 | please report it. A number of other options are available either alone or |
| 287 | after a comma following the byte. The special option "help" will list the |
| 288 | currently supported options and their current value. Each debugging option |
| 289 | may be forced on or off. The most optimal options are usually chosen at |
| 290 | build time based on the operating system and do not need to be adjusted, |
| 291 | unless suggested by a developer. Supported debugging options include |
| 292 | (set/clear): |
| 293 | - fail / no-fail: |
| 294 | This enables randomly failing memory allocations, in conjunction with |
| 295 | the global "tune.fail-alloc" setting. This is used to detect missing |
Willy Tarreau | 0c4348c | 2023-03-21 09:24:53 +0100 | [diff] [blame] | 296 | error checks in the code. Setting the option presets the ratio to 1% |
| 297 | failure rate. |
Willy Tarreau | f4b79c4 | 2022-02-23 15:20:53 +0100 | [diff] [blame] | 298 | |
| 299 | - no-merge / merge: |
| 300 | By default, pools of very similar sizes are merged, resulting in more |
| 301 | efficiency, but this complicates the analysis of certain memory dumps. |
| 302 | This option allows to disable this mechanism, and may slightly increase |
| 303 | the memory usage. |
| 304 | |
| 305 | - cold-first / hot-first: |
| 306 | In order to optimize the CPU cache hit ratio, by default the most |
| 307 | recently released objects ("hot") are recycled for new allocations. |
| 308 | But doing so also complicates analysis of memory dumps and may hide |
| 309 | use-after-free bugs. This option allows to instead pick the coldest |
| 310 | objects first, which may result in a slight increase of CPU usage. |
| 311 | |
| 312 | - integrity / no-integrity: |
| 313 | When this option is enabled, memory integrity checks are enabled on |
| 314 | the allocated area to verify that it hasn't been modified since it was |
| 315 | last released. This works best with "no-merge", "cold-first" and "tag". |
| 316 | Enabling this option will slightly increase the CPU usage. |
| 317 | |
| 318 | - no-global / global: |
| 319 | Depending on the operating system, a process-wide global memory cache |
| 320 | may be enabled if it is estimated that the standard allocator is too |
| 321 | slow or inefficient with threads. This option allows to forcefully |
| 322 | disable it or enable it. Disabling it may result in a CPU usage |
| 323 | increase with inefficient allocators. Enabling it may result in a |
| 324 | higher memory usage with efficient allocators. |
| 325 | |
| 326 | - no-cache / cache: |
| 327 | Each thread uses a very fast local object cache for allocations, which |
| 328 | is always enabled by default. This option allows to disable it. Since |
| 329 | the global cache also passes via the local caches, this will |
| 330 | effectively result in disabling all caches and allocating directly from |
| 331 | the default allocator. This may result in a significant increase of CPU |
| 332 | usage, but may also result in small memory savings on tiny systems. |
| 333 | |
| 334 | - caller / no-caller: |
| 335 | Enabling this option reserves some extra space in each allocated object |
| 336 | to store the address of the last caller that allocated or released it. |
| 337 | This helps developers go back in time when analysing memory dumps and |
| 338 | to guess how something unexpected happened. |
| 339 | |
| 340 | - tag / no-tag: |
| 341 | Enabling this option reserves some extra space in each allocated object |
| 342 | to store a tag that allows to detect bugs such as double-free, freeing |
| 343 | an invalid object, and buffer overflows. It offers much stronger |
| 344 | reliability guarantees at the expense of 4 or 8 extra bytes per |
| 345 | allocation. It usually is the first step to detect memory corruption. |
| 346 | |
| 347 | - poison / no-poison: |
| 348 | Enabling this option will fill allocated objects with a fixed pattern |
| 349 | that will make sure that some accidental values such as 0 will not be |
| 350 | present if a newly added field was mistakenly forgotten in an |
| 351 | initialization routine. Such bugs tend to rarely reproduce, especially |
| 352 | when pools are not merged. This is normally enabled by directly passing |
| 353 | the byte's value to -dM but using this option allows to disable/enable |
| 354 | use of a previously set value. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 355 | |
| 356 | -dS : disable use of the splice() system call. It is equivalent to the |
| 357 | "global" section's "nosplice" keyword. This may be used when splice() is |
| 358 | suspected to behave improperly or to cause performance issues, or when |
| 359 | using strace to see the forwarded data (which do not appear when using |
| 360 | splice()). |
| 361 | |
| 362 | -dV : disable SSL verify on the server side. It is equivalent to having |
| 363 | "ssl-server-verify none" in the "global" section. This is useful when |
| 364 | trying to reproduce production issues out of the production |
| 365 | environment. Never use this in an init script as it degrades SSL security |
| 366 | to the servers. |
| 367 | |
Willy Tarreau | 3eb10b8 | 2020-04-15 16:42:39 +0200 | [diff] [blame] | 368 | -dW : if set, haproxy will refuse to start if any warning was emitted while |
| 369 | processing the configuration. This helps detect subtle mistakes and keep the |
| 370 | configuration clean and portable across versions. It is recommended to set |
| 371 | this option in service scripts when configurations are managed by humans, |
| 372 | but it is recommended not to use it with generated configurations, which |
| 373 | tend to emit more warnings. It may be combined with "-c" to cause warnings |
| 374 | in checked configurations to fail. This is equivalent to global option |
| 375 | "zero-warning". |
| 376 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 377 | -db : disable background mode and multi-process mode. The process remains in |
| 378 | foreground. It is mainly used during development or during small tests, as |
| 379 | Ctrl-C is enough to stop the process. Never use it in an init script. |
| 380 | |
| 381 | -de : disable the use of the "epoll" poller. It is equivalent to the "global" |
| 382 | section's keyword "noepoll". It is mostly useful when suspecting a bug |
| 383 | related to this poller. On systems supporting epoll, the fallback will |
| 384 | generally be the "poll" poller. |
| 385 | |
| 386 | -dk : disable the use of the "kqueue" poller. It is equivalent to the |
| 387 | "global" section's keyword "nokqueue". It is mostly useful when suspecting |
| 388 | a bug related to this poller. On systems supporting kqueue, the fallback |
| 389 | will generally be the "poll" poller. |
| 390 | |
| 391 | -dp : disable the use of the "poll" poller. It is equivalent to the "global" |
| 392 | section's keyword "nopoll". It is mostly useful when suspecting a bug |
| 393 | related to this poller. On systems supporting poll, the fallback will |
| 394 | generally be the "select" poller, which cannot be disabled and is limited |
| 395 | to 1024 file descriptors. |
| 396 | |
Willy Tarreau | 3eed10e | 2016-11-07 21:03:16 +0100 | [diff] [blame] | 397 | -dr : ignore server address resolution failures. It is very common when |
| 398 | validating a configuration out of production not to have access to the same |
| 399 | resolvers and to fail on server address resolution, making it difficult to |
| 400 | test a configuration. This option simply appends the "none" method to the |
| 401 | list of address resolution methods for all servers, ensuring that even if |
| 402 | the libc fails to resolve an address, the startup sequence is not |
| 403 | interrupted. |
| 404 | |
Willy Tarreau | 7006045 | 2015-12-14 12:46:07 +0100 | [diff] [blame] | 405 | -m <limit> : limit the total allocatable memory to <limit> megabytes across |
| 406 | all processes. This may cause some connection refusals or some slowdowns |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 407 | depending on the amount of memory needed for normal operations. This is |
Willy Tarreau | 7006045 | 2015-12-14 12:46:07 +0100 | [diff] [blame] | 408 | mostly used to force the processes to work in a constrained resource usage |
| 409 | scenario. It is important to note that the memory is not shared between |
| 410 | processes, so in a multi-process scenario, this value is first divided by |
| 411 | global.nbproc before forking. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 412 | |
| 413 | -n <limit> : limits the per-process connection limit to <limit>. This is |
| 414 | equivalent to the global section's keyword "maxconn". It has precedence |
| 415 | over this keyword. This may be used to quickly force lower limits to avoid |
| 416 | a service outage on systems where resource limits are too low. |
| 417 | |
| 418 | -p <file> : write all processes' pids into <file> during startup. This is |
| 419 | equivalent to the "global" section's keyword "pidfile". The file is opened |
| 420 | before entering the chroot jail, and after doing the chdir() implied by |
| 421 | "-C". Each pid appears on its own line. |
| 422 | |
| 423 | -q : set "quiet" mode. This disables some messages during the configuration |
| 424 | parsing and during startup. It can be used in combination with "-c" to |
| 425 | just check if a configuration file is valid or not. |
| 426 | |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 427 | -S <bind>[,bind_options...]: in master-worker mode, bind a master CLI, which |
| 428 | allows the access to every processes, running or leaving ones. |
| 429 | For security reasons, it is recommended to bind the master CLI to a local |
| 430 | UNIX socket. The bind options are the same as the keyword "bind" in |
| 431 | the configuration file with words separated by commas instead of spaces. |
| 432 | |
| 433 | Note that this socket can't be used to retrieve the listening sockets from |
| 434 | an old process during a seamless reload. |
| 435 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 436 | -sf <pid>* : send the "finish" signal (SIGUSR1) to older processes after boot |
| 437 | completion to ask them to finish what they are doing and to leave. <pid> |
| 438 | is a list of pids to signal (one per argument). The list ends on any |
| 439 | option starting with a "-". It is not a problem if the list of pids is |
| 440 | empty, so that it can be built on the fly based on the result of a command |
Amaury Denoyelle | fb37557 | 2023-02-01 09:28:32 +0100 | [diff] [blame] | 441 | like "pidof" or "pgrep". |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 442 | |
| 443 | -st <pid>* : send the "terminate" signal (SIGTERM) to older processes after |
| 444 | boot completion to terminate them immediately without finishing what they |
| 445 | were doing. <pid> is a list of pids to signal (one per argument). The list |
| 446 | is ends on any option starting with a "-". It is not a problem if the list |
| 447 | of pids is empty, so that it can be built on the fly based on the result of |
| 448 | a command like "pidof" or "pgrep". |
| 449 | |
| 450 | -v : report the version and build date. |
| 451 | |
| 452 | -vv : display the version, build options, libraries versions and usable |
| 453 | pollers. This output is systematically requested when filing a bug report. |
| 454 | |
Olivier Houchard | d33fc3a | 2017-04-05 22:50:59 +0200 | [diff] [blame] | 455 | -x <unix_socket> : connect to the specified socket and try to retrieve any |
| 456 | listening sockets from the old process, and use them instead of trying to |
| 457 | bind new ones. This is useful to avoid missing any new connection when |
William Lallemand | f6975e9 | 2017-05-26 17:42:10 +0200 | [diff] [blame] | 458 | reloading the configuration on Linux. The capability must be enable on the |
| 459 | stats socket using "expose-fd listeners" in your configuration. |
William Lallemand | 2be557f | 2021-11-24 18:45:37 +0100 | [diff] [blame] | 460 | In master-worker mode, the master will use this option upon a reload with |
| 461 | the "sockpair@" syntax, which allows the master to connect directly to a |
| 462 | worker without using stats socket declared in the configuration. |
Olivier Houchard | d33fc3a | 2017-04-05 22:50:59 +0200 | [diff] [blame] | 463 | |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 464 | A safe way to start HAProxy from an init file consists in forcing the daemon |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 465 | mode, storing existing pids to a pid file and using this pid file to notify |
| 466 | older processes to finish before leaving : |
| 467 | |
| 468 | haproxy -f /etc/haproxy.cfg \ |
| 469 | -D -p /var/run/haproxy.pid -sf $(cat /var/run/haproxy.pid) |
| 470 | |
| 471 | When the configuration is split into a few specific files (eg: tcp vs http), |
| 472 | it is recommended to use the "-f" option : |
| 473 | |
| 474 | haproxy -f /etc/haproxy/global.cfg -f /etc/haproxy/stats.cfg \ |
| 475 | -f /etc/haproxy/default-tcp.cfg -f /etc/haproxy/tcp.cfg \ |
| 476 | -f /etc/haproxy/default-http.cfg -f /etc/haproxy/http.cfg \ |
| 477 | -D -p /var/run/haproxy.pid -sf $(cat /var/run/haproxy.pid) |
| 478 | |
| 479 | When an unknown number of files is expected, such as customer-specific files, |
| 480 | it is recommended to assign them a name starting with a fixed-size sequence |
| 481 | number and to use "--" to load them, possibly after loading some defaults : |
| 482 | |
| 483 | haproxy -f /etc/haproxy/global.cfg -f /etc/haproxy/stats.cfg \ |
| 484 | -f /etc/haproxy/default-tcp.cfg -f /etc/haproxy/tcp.cfg \ |
| 485 | -f /etc/haproxy/default-http.cfg -f /etc/haproxy/http.cfg \ |
| 486 | -D -p /var/run/haproxy.pid -sf $(cat /var/run/haproxy.pid) \ |
| 487 | -f /etc/haproxy/default-customers.cfg -- /etc/haproxy/customers/* |
| 488 | |
| 489 | Sometimes a failure to start may happen for whatever reason. Then it is |
| 490 | important to verify if the version of HAProxy you are invoking is the expected |
| 491 | version and if it supports the features you are expecting (eg: SSL, PCRE, |
| 492 | compression, Lua, etc). This can be verified using "haproxy -vv". Some |
| 493 | important information such as certain build options, the target system and |
| 494 | the versions of the libraries being used are reported there. It is also what |
| 495 | you will systematically be asked for when posting a bug report : |
| 496 | |
| 497 | $ haproxy -vv |
Willy Tarreau | 58000fe | 2021-05-09 06:25:16 +0200 | [diff] [blame] | 498 | HAProxy version 1.6-dev7-a088d3-4 2015/10/08 |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 499 | Copyright 2000-2015 Willy Tarreau <willy@haproxy.org> |
| 500 | |
| 501 | Build options : |
| 502 | TARGET = linux2628 |
| 503 | CPU = generic |
| 504 | CC = gcc |
| 505 | CFLAGS = -pg -O0 -g -fno-strict-aliasing -Wdeclaration-after-statement \ |
| 506 | -DBUFSIZE=8030 -DMAXREWRITE=1030 -DSO_MARK=36 -DTCP_REPAIR=19 |
| 507 | OPTIONS = USE_ZLIB=1 USE_DLMALLOC=1 USE_OPENSSL=1 USE_LUA=1 USE_PCRE=1 |
| 508 | |
| 509 | Default settings : |
| 510 | maxconn = 2000, bufsize = 8030, maxrewrite = 1030, maxpollevents = 200 |
| 511 | |
| 512 | Encrypted password support via crypt(3): yes |
| 513 | Built with zlib version : 1.2.6 |
| 514 | Compression algorithms supported : identity("identity"), deflate("deflate"), \ |
| 515 | raw-deflate("deflate"), gzip("gzip") |
| 516 | Built with OpenSSL version : OpenSSL 1.0.1o 12 Jun 2015 |
| 517 | Running on OpenSSL version : OpenSSL 1.0.1o 12 Jun 2015 |
| 518 | OpenSSL library supports TLS extensions : yes |
| 519 | OpenSSL library supports SNI : yes |
| 520 | OpenSSL library supports prefer-server-ciphers : yes |
| 521 | Built with PCRE version : 8.12 2011-01-15 |
| 522 | PCRE library supports JIT : no (USE_PCRE_JIT not set) |
| 523 | Built with Lua version : Lua 5.3.1 |
| 524 | Built with transparent proxy support using: IP_TRANSPARENT IP_FREEBIND |
| 525 | |
| 526 | Available polling systems : |
| 527 | epoll : pref=300, test result OK |
| 528 | poll : pref=200, test result OK |
| 529 | select : pref=150, test result OK |
| 530 | Total: 3 (3 usable), will use epoll. |
| 531 | |
| 532 | The relevant information that many non-developer users can verify here are : |
| 533 | - the version : 1.6-dev7-a088d3-4 above means the code is currently at commit |
| 534 | ID "a088d3" which is the 4th one after after official version "1.6-dev7". |
| 535 | Version 1.6-dev7 would show as "1.6-dev7-8c1ad7". What matters here is in |
| 536 | fact "1.6-dev7". This is the 7th development version of what will become |
| 537 | version 1.6 in the future. A development version not suitable for use in |
| 538 | production (unless you know exactly what you are doing). A stable version |
| 539 | will show as a 3-numbers version, such as "1.5.14-16f863", indicating the |
| 540 | 14th level of fix on top of version 1.5. This is a production-ready version. |
| 541 | |
| 542 | - the release date : 2015/10/08. It is represented in the universal |
| 543 | year/month/day format. Here this means August 8th, 2015. Given that stable |
| 544 | releases are issued every few months (1-2 months at the beginning, sometimes |
| 545 | 6 months once the product becomes very stable), if you're seeing an old date |
| 546 | here, it means you're probably affected by a number of bugs or security |
| 547 | issues that have since been fixed and that it might be worth checking on the |
| 548 | official site. |
| 549 | |
| 550 | - build options : they are relevant to people who build their packages |
| 551 | themselves, they can explain why things are not behaving as expected. For |
| 552 | example the development version above was built for Linux 2.6.28 or later, |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 553 | targeting a generic CPU (no CPU-specific optimizations), and lacks any |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 554 | code optimization (-O0) so it will perform poorly in terms of performance. |
| 555 | |
| 556 | - libraries versions : zlib version is reported as found in the library |
| 557 | itself. In general zlib is considered a very stable product and upgrades |
| 558 | are almost never needed. OpenSSL reports two versions, the version used at |
| 559 | build time and the one being used, as found on the system. These ones may |
| 560 | differ by the last letter but never by the numbers. The build date is also |
| 561 | reported because most OpenSSL bugs are security issues and need to be taken |
| 562 | seriously, so this library absolutely needs to be kept up to date. Seeing a |
| 563 | 4-months old version here is highly suspicious and indeed an update was |
| 564 | missed. PCRE provides very fast regular expressions and is highly |
| 565 | recommended. Certain of its extensions such as JIT are not present in all |
| 566 | versions and still young so some people prefer not to build with them, |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 567 | which is why the build status is reported as well. Regarding the Lua |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 568 | scripting language, HAProxy expects version 5.3 which is very young since |
| 569 | it was released a little time before HAProxy 1.6. It is important to check |
| 570 | on the Lua web site if some fixes are proposed for this branch. |
| 571 | |
| 572 | - Available polling systems will affect the process's scalability when |
| 573 | dealing with more than about one thousand of concurrent connections. These |
| 574 | ones are only available when the correct system was indicated in the TARGET |
| 575 | variable during the build. The "epoll" mechanism is highly recommended on |
| 576 | Linux, and the kqueue mechanism is highly recommended on BSD. Lacking them |
| 577 | will result in poll() or even select() being used, causing a high CPU usage |
| 578 | when dealing with a lot of connections. |
| 579 | |
| 580 | |
| 581 | 4. Stopping and restarting HAProxy |
| 582 | ---------------------------------- |
| 583 | |
| 584 | HAProxy supports a graceful and a hard stop. The hard stop is simple, when the |
| 585 | SIGTERM signal is sent to the haproxy process, it immediately quits and all |
| 586 | established connections are closed. The graceful stop is triggered when the |
| 587 | SIGUSR1 signal is sent to the haproxy process. It consists in only unbinding |
| 588 | from listening ports, but continue to process existing connections until they |
| 589 | close. Once the last connection is closed, the process leaves. |
| 590 | |
| 591 | The hard stop method is used for the "stop" or "restart" actions of the service |
| 592 | management script. The graceful stop is used for the "reload" action which |
| 593 | tries to seamlessly reload a new configuration in a new process. |
| 594 | |
| 595 | Both of these signals may be sent by the new haproxy process itself during a |
| 596 | reload or restart, so that they are sent at the latest possible moment and only |
| 597 | if absolutely required. This is what is performed by the "-st" (hard) and "-sf" |
| 598 | (graceful) options respectively. |
| 599 | |
William Lallemand | e202b1e | 2017-06-01 17:38:56 +0200 | [diff] [blame] | 600 | In master-worker mode, it is not needed to start a new haproxy process in |
| 601 | order to reload the configuration. The master process reacts to the SIGUSR2 |
| 602 | signal by reexecuting itself with the -sf parameter followed by the PIDs of |
| 603 | the workers. The master will then parse the configuration file and fork new |
| 604 | workers. |
| 605 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 606 | To understand better how these signals are used, it is important to understand |
| 607 | the whole restart mechanism. |
| 608 | |
| 609 | First, an existing haproxy process is running. The administrator uses a system |
Jackie Tapia | 749f74c | 2020-07-22 18:59:40 -0500 | [diff] [blame] | 610 | specific command such as "/etc/init.d/haproxy reload" to indicate they want to |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 611 | take the new configuration file into effect. What happens then is the following. |
| 612 | First, the service script (/etc/init.d/haproxy or equivalent) will verify that |
| 613 | the configuration file parses correctly using "haproxy -c". After that it will |
| 614 | try to start haproxy with this configuration file, using "-st" or "-sf". |
| 615 | |
| 616 | Then HAProxy tries to bind to all listening ports. If some fatal errors happen |
| 617 | (eg: address not present on the system, permission denied), the process quits |
| 618 | with an error. If a socket binding fails because a port is already in use, then |
| 619 | the process will first send a SIGTTOU signal to all the pids specified in the |
| 620 | "-st" or "-sf" pid list. This is what is called the "pause" signal. It instructs |
| 621 | all existing haproxy processes to temporarily stop listening to their ports so |
| 622 | that the new process can try to bind again. During this time, the old process |
| 623 | continues to process existing connections. If the binding still fails (because |
| 624 | for example a port is shared with another daemon), then the new process sends a |
| 625 | SIGTTIN signal to the old processes to instruct them to resume operations just |
| 626 | as if nothing happened. The old processes will then restart listening to the |
Jonathon Lacher | c5b5e7b | 2021-08-04 00:29:05 -0500 | [diff] [blame] | 627 | ports and continue to accept connections. Note that this mechanism is system |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 628 | dependent and some operating systems may not support it in multi-process mode. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 629 | |
| 630 | If the new process manages to bind correctly to all ports, then it sends either |
| 631 | the SIGTERM (hard stop in case of "-st") or the SIGUSR1 (graceful stop in case |
| 632 | of "-sf") to all processes to notify them that it is now in charge of operations |
| 633 | and that the old processes will have to leave, either immediately or once they |
| 634 | have finished their job. |
| 635 | |
| 636 | It is important to note that during this timeframe, there are two small windows |
| 637 | of a few milliseconds each where it is possible that a few connection failures |
| 638 | will be noticed during high loads. Typically observed failure rates are around |
| 639 | 1 failure during a reload operation every 10000 new connections per second, |
| 640 | which means that a heavily loaded site running at 30000 new connections per |
| 641 | second may see about 3 failed connection upon every reload. The two situations |
| 642 | where this happens are : |
| 643 | |
| 644 | - if the new process fails to bind due to the presence of the old process, |
| 645 | it will first have to go through the SIGTTOU+SIGTTIN sequence, which |
| 646 | typically lasts about one millisecond for a few tens of frontends, and |
| 647 | during which some ports will not be bound to the old process and not yet |
| 648 | bound to the new one. HAProxy works around this on systems that support the |
| 649 | SO_REUSEPORT socket options, as it allows the new process to bind without |
| 650 | first asking the old one to unbind. Most BSD systems have been supporting |
| 651 | this almost forever. Linux has been supporting this in version 2.0 and |
| 652 | dropped it around 2.2, but some patches were floating around by then. It |
| 653 | was reintroduced in kernel 3.9, so if you are observing a connection |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 654 | failure rate above the one mentioned above, please ensure that your kernel |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 655 | is 3.9 or newer, or that relevant patches were backported to your kernel |
| 656 | (less likely). |
| 657 | |
| 658 | - when the old processes close the listening ports, the kernel may not always |
| 659 | redistribute any pending connection that was remaining in the socket's |
| 660 | backlog. Under high loads, a SYN packet may happen just before the socket |
| 661 | is closed, and will lead to an RST packet being sent to the client. In some |
| 662 | critical environments where even one drop is not acceptable, these ones are |
| 663 | sometimes dealt with using firewall rules to block SYN packets during the |
| 664 | reload, forcing the client to retransmit. This is totally system-dependent, |
| 665 | as some systems might be able to visit other listening queues and avoid |
| 666 | this RST. A second case concerns the ACK from the client on a local socket |
| 667 | that was in SYN_RECV state just before the close. This ACK will lead to an |
| 668 | RST packet while the haproxy process is still not aware of it. This one is |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 669 | harder to get rid of, though the firewall filtering rules mentioned above |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 670 | will work well if applied one second or so before restarting the process. |
| 671 | |
| 672 | For the vast majority of users, such drops will never ever happen since they |
| 673 | don't have enough load to trigger the race conditions. And for most high traffic |
| 674 | users, the failure rate is still fairly within the noise margin provided that at |
| 675 | least SO_REUSEPORT is properly supported on their systems. |
| 676 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 677 | 5. File-descriptor limitations |
| 678 | ------------------------------ |
| 679 | |
| 680 | In order to ensure that all incoming connections will successfully be served, |
| 681 | HAProxy computes at load time the total number of file descriptors that will be |
| 682 | needed during the process's life. A regular Unix process is generally granted |
| 683 | 1024 file descriptors by default, and a privileged process can raise this limit |
| 684 | itself. This is one reason for starting HAProxy as root and letting it adjust |
| 685 | the limit. The default limit of 1024 file descriptors roughly allow about 500 |
| 686 | concurrent connections to be processed. The computation is based on the global |
| 687 | maxconn parameter which limits the total number of connections per process, the |
| 688 | number of listeners, the number of servers which have a health check enabled, |
| 689 | the agent checks, the peers, the loggers and possibly a few other technical |
| 690 | requirements. A simple rough estimate of this number consists in simply |
| 691 | doubling the maxconn value and adding a few tens to get the approximate number |
| 692 | of file descriptors needed. |
| 693 | |
| 694 | Originally HAProxy did not know how to compute this value, and it was necessary |
| 695 | to pass the value using the "ulimit-n" setting in the global section. This |
| 696 | explains why even today a lot of configurations are seen with this setting |
| 697 | present. Unfortunately it was often miscalculated resulting in connection |
| 698 | failures when approaching maxconn instead of throttling incoming connection |
| 699 | while waiting for the needed resources. For this reason it is important to |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 700 | remove any vestigial "ulimit-n" setting that can remain from very old versions. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 701 | |
| 702 | Raising the number of file descriptors to accept even moderate loads is |
| 703 | mandatory but comes with some OS-specific adjustments. First, the select() |
| 704 | polling system is limited to 1024 file descriptors. In fact on Linux it used |
| 705 | to be capable of handling more but since certain OS ship with excessively |
| 706 | restrictive SELinux policies forbidding the use of select() with more than |
| 707 | 1024 file descriptors, HAProxy now refuses to start in this case in order to |
| 708 | avoid any issue at run time. On all supported operating systems, poll() is |
| 709 | available and will not suffer from this limitation. It is automatically picked |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 710 | so there is nothing to do to get a working configuration. But poll's becomes |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 711 | very slow when the number of file descriptors increases. While HAProxy does its |
| 712 | best to limit this performance impact (eg: via the use of the internal file |
| 713 | descriptor cache and batched processing), a good rule of thumb is that using |
| 714 | poll() with more than a thousand concurrent connections will use a lot of CPU. |
| 715 | |
| 716 | For Linux systems base on kernels 2.6 and above, the epoll() system call will |
| 717 | be used. It's a much more scalable mechanism relying on callbacks in the kernel |
| 718 | that guarantee a constant wake up time regardless of the number of registered |
| 719 | monitored file descriptors. It is automatically used where detected, provided |
| 720 | that HAProxy had been built for one of the Linux flavors. Its presence and |
| 721 | support can be verified using "haproxy -vv". |
| 722 | |
| 723 | For BSD systems which support it, kqueue() is available as an alternative. It |
| 724 | is much faster than poll() and even slightly faster than epoll() thanks to its |
| 725 | batched handling of changes. At least FreeBSD and OpenBSD support it. Just like |
| 726 | with Linux's epoll(), its support and availability are reported in the output |
| 727 | of "haproxy -vv". |
| 728 | |
| 729 | Having a good poller is one thing, but it is mandatory that the process can |
| 730 | reach the limits. When HAProxy starts, it immediately sets the new process's |
| 731 | file descriptor limits and verifies if it succeeds. In case of failure, it |
| 732 | reports it before forking so that the administrator can see the problem. As |
| 733 | long as the process is started by as root, there should be no reason for this |
| 734 | setting to fail. However, it can fail if the process is started by an |
| 735 | unprivileged user. If there is a compelling reason for *not* starting haproxy |
| 736 | as root (eg: started by end users, or by a per-application account), then the |
| 737 | file descriptor limit can be raised by the system administrator for this |
| 738 | specific user. The effectiveness of the setting can be verified by issuing |
| 739 | "ulimit -n" from the user's command line. It should reflect the new limit. |
| 740 | |
| 741 | Warning: when an unprivileged user's limits are changed in this user's account, |
| 742 | it is fairly common that these values are only considered when the user logs in |
| 743 | and not at all in some scripts run at system boot time nor in crontabs. This is |
| 744 | totally dependent on the operating system, keep in mind to check "ulimit -n" |
| 745 | before starting haproxy when running this way. The general advice is never to |
| 746 | start haproxy as an unprivileged user for production purposes. Another good |
| 747 | reason is that it prevents haproxy from enabling some security protections. |
| 748 | |
| 749 | Once it is certain that the system will allow the haproxy process to use the |
| 750 | requested number of file descriptors, two new system-specific limits may be |
| 751 | encountered. The first one is the system-wide file descriptor limit, which is |
| 752 | the total number of file descriptors opened on the system, covering all |
| 753 | processes. When this limit is reached, accept() or socket() will typically |
| 754 | return ENFILE. The second one is the per-process hard limit on the number of |
| 755 | file descriptors, it prevents setrlimit() from being set higher. Both are very |
| 756 | dependent on the operating system. On Linux, the system limit is set at boot |
| 757 | based on the amount of memory. It can be changed with the "fs.file-max" sysctl. |
| 758 | And the per-process hard limit is set to 1048576 by default, but it can be |
| 759 | changed using the "fs.nr_open" sysctl. |
| 760 | |
| 761 | File descriptor limitations may be observed on a running process when they are |
| 762 | set too low. The strace utility will report that accept() and socket() return |
| 763 | "-1 EMFILE" when the process's limits have been reached. In this case, simply |
| 764 | raising the "ulimit-n" value (or removing it) will solve the problem. If these |
| 765 | system calls return "-1 ENFILE" then it means that the kernel's limits have |
| 766 | been reached and that something must be done on a system-wide parameter. These |
| 767 | trouble must absolutely be addressed, as they result in high CPU usage (when |
| 768 | accept() fails) and failed connections that are generally visible to the user. |
| 769 | One solution also consists in lowering the global maxconn value to enforce |
| 770 | serialization, and possibly to disable HTTP keep-alive to force connections |
| 771 | to be released and reused faster. |
| 772 | |
| 773 | |
| 774 | 6. Memory management |
| 775 | -------------------- |
| 776 | |
| 777 | HAProxy uses a simple and fast pool-based memory management. Since it relies on |
| 778 | a small number of different object types, it's much more efficient to pick new |
| 779 | objects from a pool which already contains objects of the appropriate size than |
| 780 | to call malloc() for each different size. The pools are organized as a stack or |
| 781 | LIFO, so that newly allocated objects are taken from recently released objects |
| 782 | still hot in the CPU caches. Pools of similar sizes are merged together, in |
| 783 | order to limit memory fragmentation. |
| 784 | |
| 785 | By default, since the focus is set on performance, each released object is put |
| 786 | back into the pool it came from, and allocated objects are never freed since |
| 787 | they are expected to be reused very soon. |
| 788 | |
| 789 | On the CLI, it is possible to check how memory is being used in pools thanks to |
| 790 | the "show pools" command : |
| 791 | |
| 792 | > show pools |
| 793 | Dumping pools usage. Use SIGQUIT to flush them. |
Willy Tarreau | 0a93b64 | 2018-10-16 07:58:39 +0200 | [diff] [blame] | 794 | - Pool cache_st (16 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 1 users, @0x9ccc40=03 [SHARED] |
| 795 | - Pool pipe (32 bytes) : 5 allocated (160 bytes), 5 used, 0 failures, 2 users, @0x9ccac0=00 [SHARED] |
| 796 | - Pool comp_state (48 bytes) : 3 allocated (144 bytes), 3 used, 0 failures, 5 users, @0x9cccc0=04 [SHARED] |
| 797 | - Pool filter (64 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 3 users, @0x9ccbc0=02 [SHARED] |
| 798 | - Pool vars (80 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 2 users, @0x9ccb40=01 [SHARED] |
| 799 | - Pool uniqueid (128 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 2 users, @0x9cd240=15 [SHARED] |
| 800 | - Pool task (144 bytes) : 55 allocated (7920 bytes), 55 used, 0 failures, 1 users, @0x9cd040=11 [SHARED] |
| 801 | - Pool session (160 bytes) : 1 allocated (160 bytes), 1 used, 0 failures, 1 users, @0x9cd140=13 [SHARED] |
| 802 | - Pool h2s (208 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 2 users, @0x9ccec0=08 [SHARED] |
| 803 | - Pool h2c (288 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 1 users, @0x9cce40=07 [SHARED] |
| 804 | - Pool spoe_ctx (304 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 2 users, @0x9ccf40=09 [SHARED] |
| 805 | - Pool connection (400 bytes) : 2 allocated (800 bytes), 2 used, 0 failures, 1 users, @0x9cd1c0=14 [SHARED] |
| 806 | - Pool hdr_idx (416 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 1 users, @0x9cd340=17 [SHARED] |
| 807 | - Pool dns_resolut (480 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 1 users, @0x9ccdc0=06 [SHARED] |
| 808 | - Pool dns_answer_ (576 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 1 users, @0x9ccd40=05 [SHARED] |
| 809 | - Pool stream (960 bytes) : 1 allocated (960 bytes), 1 used, 0 failures, 1 users, @0x9cd0c0=12 [SHARED] |
| 810 | - Pool requri (1024 bytes) : 0 allocated (0 bytes), 0 used, 0 failures, 1 users, @0x9cd2c0=16 [SHARED] |
| 811 | - Pool buffer (8030 bytes) : 3 allocated (24090 bytes), 2 used, 0 failures, 1 users, @0x9cd3c0=18 [SHARED] |
| 812 | - Pool trash (8062 bytes) : 1 allocated (8062 bytes), 1 used, 0 failures, 1 users, @0x9cd440=19 |
| 813 | Total: 19 pools, 42296 bytes allocated, 34266 used. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 814 | |
| 815 | The pool name is only indicative, it's the name of the first object type using |
| 816 | this pool. The size in parenthesis is the object size for objects in this pool. |
| 817 | Object sizes are always rounded up to the closest multiple of 16 bytes. The |
| 818 | number of objects currently allocated and the equivalent number of bytes is |
| 819 | reported so that it is easy to know which pool is responsible for the highest |
| 820 | memory usage. The number of objects currently in use is reported as well in the |
| 821 | "used" field. The difference between "allocated" and "used" corresponds to the |
Willy Tarreau | 0a93b64 | 2018-10-16 07:58:39 +0200 | [diff] [blame] | 822 | objects that have been freed and are available for immediate use. The address |
| 823 | at the end of the line is the pool's address, and the following number is the |
| 824 | pool index when it exists, or is reported as -1 if no index was assigned. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 825 | |
| 826 | It is possible to limit the amount of memory allocated per process using the |
| 827 | "-m" command line option, followed by a number of megabytes. It covers all of |
| 828 | the process's addressable space, so that includes memory used by some libraries |
| 829 | as well as the stack, but it is a reliable limit when building a resource |
| 830 | constrained system. It works the same way as "ulimit -v" on systems which have |
| 831 | it, or "ulimit -d" for the other ones. |
| 832 | |
| 833 | If a memory allocation fails due to the memory limit being reached or because |
| 834 | the system doesn't have any enough memory, then haproxy will first start to |
| 835 | free all available objects from all pools before attempting to allocate memory |
| 836 | again. This mechanism of releasing unused memory can be triggered by sending |
| 837 | the signal SIGQUIT to the haproxy process. When doing so, the pools state prior |
| 838 | to the flush will also be reported to stderr when the process runs in |
| 839 | foreground. |
| 840 | |
| 841 | During a reload operation, the process switched to the graceful stop state also |
| 842 | automatically performs some flushes after releasing any connection so that all |
| 843 | possible memory is released to save it for the new process. |
| 844 | |
| 845 | |
| 846 | 7. CPU usage |
| 847 | ------------ |
| 848 | |
| 849 | HAProxy normally spends most of its time in the system and a smaller part in |
| 850 | userland. A finely tuned 3.5 GHz CPU can sustain a rate about 80000 end-to-end |
| 851 | connection setups and closes per second at 100% CPU on a single core. When one |
| 852 | core is saturated, typical figures are : |
| 853 | - 95% system, 5% user for long TCP connections or large HTTP objects |
| 854 | - 85% system and 15% user for short TCP connections or small HTTP objects in |
| 855 | close mode |
| 856 | - 70% system and 30% user for small HTTP objects in keep-alive mode |
| 857 | |
| 858 | The amount of rules processing and regular expressions will increase the user |
| 859 | land part. The presence of firewall rules, connection tracking, complex routing |
| 860 | tables in the system will instead increase the system part. |
| 861 | |
| 862 | On most systems, the CPU time observed during network transfers can be cut in 4 |
| 863 | parts : |
| 864 | - the interrupt part, which concerns all the processing performed upon I/O |
| 865 | receipt, before the target process is even known. Typically Rx packets are |
| 866 | accounted for in interrupt. On some systems such as Linux where interrupt |
| 867 | processing may be deferred to a dedicated thread, it can appear as softirq, |
| 868 | and the thread is called ksoftirqd/0 (for CPU 0). The CPU taking care of |
| 869 | this load is generally defined by the hardware settings, though in the case |
| 870 | of softirq it is often possible to remap the processing to another CPU. |
| 871 | This interrupt part will often be perceived as parasitic since it's not |
| 872 | associated with any process, but it actually is some processing being done |
| 873 | to prepare the work for the process. |
| 874 | |
| 875 | - the system part, which concerns all the processing done using kernel code |
| 876 | called from userland. System calls are accounted as system for example. All |
| 877 | synchronously delivered Tx packets will be accounted for as system time. If |
| 878 | some packets have to be deferred due to queues filling up, they may then be |
| 879 | processed in interrupt context later (eg: upon receipt of an ACK opening a |
| 880 | TCP window). |
| 881 | |
| 882 | - the user part, which exclusively runs application code in userland. HAProxy |
| 883 | runs exclusively in this part, though it makes heavy use of system calls. |
| 884 | Rules processing, regular expressions, compression, encryption all add to |
| 885 | the user portion of CPU consumption. |
| 886 | |
| 887 | - the idle part, which is what the CPU does when there is nothing to do. For |
| 888 | example HAProxy waits for an incoming connection, or waits for some data to |
| 889 | leave, meaning the system is waiting for an ACK from the client to push |
| 890 | these data. |
| 891 | |
| 892 | In practice regarding HAProxy's activity, it is in general reasonably accurate |
| 893 | (but totally inexact) to consider that interrupt/softirq are caused by Rx |
| 894 | processing in kernel drivers, that user-land is caused by layer 7 processing |
| 895 | in HAProxy, and that system time is caused by network processing on the Tx |
| 896 | path. |
| 897 | |
| 898 | Since HAProxy runs around an event loop, it waits for new events using poll() |
| 899 | (or any alternative) and processes all these events as fast as possible before |
| 900 | going back to poll() waiting for new events. It measures the time spent waiting |
| 901 | in poll() compared to the time spent doing processing events. The ratio of |
| 902 | polling time vs total time is called the "idle" time, it's the amount of time |
| 903 | spent waiting for something to happen. This ratio is reported in the stats page |
| 904 | on the "idle" line, or "Idle_pct" on the CLI. When it's close to 100%, it means |
| 905 | the load is extremely low. When it's close to 0%, it means that there is |
| 906 | constantly some activity. While it cannot be very accurate on an overloaded |
| 907 | system due to other processes possibly preempting the CPU from the haproxy |
| 908 | process, it still provides a good estimate about how HAProxy considers it is |
| 909 | working : if the load is low and the idle ratio is low as well, it may indicate |
| 910 | that HAProxy has a lot of work to do, possibly due to very expensive rules that |
| 911 | have to be processed. Conversely, if HAProxy indicates the idle is close to |
| 912 | 100% while things are slow, it means that it cannot do anything to speed things |
| 913 | up because it is already waiting for incoming data to process. In the example |
| 914 | below, haproxy is completely idle : |
| 915 | |
| 916 | $ echo "show info" | socat - /var/run/haproxy.sock | grep ^Idle |
| 917 | Idle_pct: 100 |
| 918 | |
| 919 | When the idle ratio starts to become very low, it is important to tune the |
| 920 | system and place processes and interrupts correctly to save the most possible |
| 921 | CPU resources for all tasks. If a firewall is present, it may be worth trying |
| 922 | to disable it or to tune it to ensure it is not responsible for a large part |
| 923 | of the performance limitation. It's worth noting that unloading a stateful |
| 924 | firewall generally reduces both the amount of interrupt/softirq and of system |
| 925 | usage since such firewalls act both on the Rx and the Tx paths. On Linux, |
| 926 | unloading the nf_conntrack and ip_conntrack modules will show whether there is |
| 927 | anything to gain. If so, then the module runs with default settings and you'll |
| 928 | have to figure how to tune it for better performance. In general this consists |
| 929 | in considerably increasing the hash table size. On FreeBSD, "pfctl -d" will |
| 930 | disable the "pf" firewall and its stateful engine at the same time. |
| 931 | |
| 932 | If it is observed that a lot of time is spent in interrupt/softirq, it is |
| 933 | important to ensure that they don't run on the same CPU. Most systems tend to |
| 934 | pin the tasks on the CPU where they receive the network traffic because for |
| 935 | certain workloads it improves things. But with heavily network-bound workloads |
| 936 | it is the opposite as the haproxy process will have to fight against its kernel |
| 937 | counterpart. Pinning haproxy to one CPU core and the interrupts to another one, |
| 938 | all sharing the same L3 cache tends to sensibly increase network performance |
| 939 | because in practice the amount of work for haproxy and the network stack are |
| 940 | quite close, so they can almost fill an entire CPU each. On Linux this is done |
| 941 | using taskset (for haproxy) or using cpu-map (from the haproxy config), and the |
| 942 | interrupts are assigned under /proc/irq. Many network interfaces support |
| 943 | multiple queues and multiple interrupts. In general it helps to spread them |
| 944 | across a small number of CPU cores provided they all share the same L3 cache. |
| 945 | Please always stop irq_balance which always does the worst possible thing on |
| 946 | such workloads. |
| 947 | |
| 948 | For CPU-bound workloads consisting in a lot of SSL traffic or a lot of |
| 949 | compression, it may be worth using multiple processes dedicated to certain |
| 950 | tasks, though there is no universal rule here and experimentation will have to |
| 951 | be performed. |
| 952 | |
| 953 | In order to increase the CPU capacity, it is possible to make HAProxy run as |
| 954 | several processes, using the "nbproc" directive in the global section. There |
| 955 | are some limitations though : |
| 956 | - health checks are run per process, so the target servers will get as many |
| 957 | checks as there are running processes ; |
| 958 | - maxconn values and queues are per-process so the correct value must be set |
| 959 | to avoid overloading the servers ; |
| 960 | - outgoing connections should avoid using port ranges to avoid conflicts |
| 961 | - stick-tables are per process and are not shared between processes ; |
| 962 | - each peers section may only run on a single process at a time ; |
| 963 | - the CLI operations will only act on a single process at a time. |
| 964 | |
| 965 | With this in mind, it appears that the easiest setup often consists in having |
| 966 | one first layer running on multiple processes and in charge for the heavy |
| 967 | processing, passing the traffic to a second layer running in a single process. |
| 968 | This mechanism is suited to SSL and compression which are the two CPU-heavy |
| 969 | features. Instances can easily be chained over UNIX sockets (which are cheaper |
fengpeiyuan | cc123c6 | 2016-01-15 16:40:53 +0800 | [diff] [blame] | 970 | than TCP sockets and which do not waste ports), and the proxy protocol which is |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 971 | useful to pass client information to the next stage. When doing so, it is |
| 972 | generally a good idea to bind all the single-process tasks to process number 1 |
| 973 | and extra tasks to next processes, as this will make it easier to generate |
| 974 | similar configurations for different machines. |
| 975 | |
| 976 | On Linux versions 3.9 and above, running HAProxy in multi-process mode is much |
| 977 | more efficient when each process uses a distinct listening socket on the same |
| 978 | IP:port ; this will make the kernel evenly distribute the load across all |
| 979 | processes instead of waking them all up. Please check the "process" option of |
| 980 | the "bind" keyword lines in the configuration manual for more information. |
| 981 | |
| 982 | |
| 983 | 8. Logging |
| 984 | ---------- |
| 985 | |
| 986 | For logging, HAProxy always relies on a syslog server since it does not perform |
| 987 | any file-system access. The standard way of using it is to send logs over UDP |
| 988 | to the log server (by default on port 514). Very commonly this is configured to |
| 989 | 127.0.0.1 where the local syslog daemon is running, but it's also used over the |
| 990 | network to log to a central server. The central server provides additional |
| 991 | benefits especially in active-active scenarios where it is desirable to keep |
| 992 | the logs merged in arrival order. HAProxy may also make use of a UNIX socket to |
| 993 | send its logs to the local syslog daemon, but it is not recommended at all, |
| 994 | because if the syslog server is restarted while haproxy runs, the socket will |
| 995 | be replaced and new logs will be lost. Since HAProxy will be isolated inside a |
| 996 | chroot jail, it will not have the ability to reconnect to the new socket. It |
| 997 | has also been observed in field that the log buffers in use on UNIX sockets are |
| 998 | very small and lead to lost messages even at very light loads. But this can be |
| 999 | fine for testing however. |
| 1000 | |
| 1001 | It is recommended to add the following directive to the "global" section to |
| 1002 | make HAProxy log to the local daemon using facility "local0" : |
| 1003 | |
| 1004 | log 127.0.0.1:514 local0 |
| 1005 | |
| 1006 | and then to add the following one to each "defaults" section or to each frontend |
| 1007 | and backend section : |
| 1008 | |
| 1009 | log global |
| 1010 | |
| 1011 | This way, all logs will be centralized through the global definition of where |
| 1012 | the log server is. |
| 1013 | |
| 1014 | Some syslog daemons do not listen to UDP traffic by default, so depending on |
| 1015 | the daemon being used, the syntax to enable this will vary : |
| 1016 | |
| 1017 | - on sysklogd, you need to pass argument "-r" on the daemon's command line |
| 1018 | so that it listens to a UDP socket for "remote" logs ; note that there is |
| 1019 | no way to limit it to address 127.0.0.1 so it will also receive logs from |
| 1020 | remote systems ; |
| 1021 | |
| 1022 | - on rsyslogd, the following lines must be added to the configuration file : |
| 1023 | |
| 1024 | $ModLoad imudp |
| 1025 | $UDPServerAddress * |
| 1026 | $UDPServerRun 514 |
| 1027 | |
| 1028 | - on syslog-ng, a new source can be created the following way, it then needs |
| 1029 | to be added as a valid source in one of the "log" directives : |
| 1030 | |
| 1031 | source s_udp { |
| 1032 | udp(ip(127.0.0.1) port(514)); |
| 1033 | }; |
| 1034 | |
| 1035 | Please consult your syslog daemon's manual for more information. If no logs are |
| 1036 | seen in the system's log files, please consider the following tests : |
| 1037 | |
| 1038 | - restart haproxy. Each frontend and backend logs one line indicating it's |
| 1039 | starting. If these logs are received, it means logs are working. |
| 1040 | |
| 1041 | - run "strace -tt -s100 -etrace=sendmsg -p <haproxy's pid>" and perform some |
| 1042 | activity that you expect to be logged. You should see the log messages |
| 1043 | being sent using sendmsg() there. If they don't appear, restart using |
| 1044 | strace on top of haproxy. If you still see no logs, it definitely means |
| 1045 | that something is wrong in your configuration. |
| 1046 | |
| 1047 | - run tcpdump to watch for port 514, for example on the loopback interface if |
| 1048 | the traffic is being sent locally : "tcpdump -As0 -ni lo port 514". If the |
| 1049 | packets are seen there, it's the proof they're sent then the syslogd daemon |
| 1050 | needs to be troubleshooted. |
| 1051 | |
| 1052 | While traffic logs are sent from the frontends (where the incoming connections |
| 1053 | are accepted), backends also need to be able to send logs in order to report a |
| 1054 | server state change consecutive to a health check. Please consult HAProxy's |
| 1055 | configuration manual for more information regarding all possible log settings. |
| 1056 | |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 1057 | It is convenient to chose a facility that is not used by other daemons. HAProxy |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 1058 | examples often suggest "local0" for traffic logs and "local1" for admin logs |
| 1059 | because they're never seen in field. A single facility would be enough as well. |
| 1060 | Having separate logs is convenient for log analysis, but it's also important to |
| 1061 | remember that logs may sometimes convey confidential information, and as such |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 1062 | they must not be mixed with other logs that may accidentally be handed out to |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 1063 | unauthorized people. |
| 1064 | |
| 1065 | For in-field troubleshooting without impacting the server's capacity too much, |
| 1066 | it is recommended to make use of the "halog" utility provided with HAProxy. |
| 1067 | This is sort of a grep-like utility designed to process HAProxy log files at |
| 1068 | a very fast data rate. Typical figures range between 1 and 2 GB of logs per |
| 1069 | second. It is capable of extracting only certain logs (eg: search for some |
| 1070 | classes of HTTP status codes, connection termination status, search by response |
| 1071 | time ranges, look for errors only), count lines, limit the output to a number |
| 1072 | of lines, and perform some more advanced statistics such as sorting servers |
| 1073 | by response time or error counts, sorting URLs by time or count, sorting client |
| 1074 | addresses by access count, and so on. It is pretty convenient to quickly spot |
| 1075 | anomalies such as a bot looping on the site, and block them. |
| 1076 | |
| 1077 | |
| 1078 | 9. Statistics and monitoring |
| 1079 | ---------------------------- |
| 1080 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1081 | It is possible to query HAProxy about its status. The most commonly used |
| 1082 | mechanism is the HTTP statistics page. This page also exposes an alternative |
| 1083 | CSV output format for monitoring tools. The same format is provided on the |
| 1084 | Unix socket. |
| 1085 | |
Amaury Denoyelle | 072f97e | 2020-10-05 11:49:37 +0200 | [diff] [blame] | 1086 | Statistics are regroup in categories labelled as domains, corresponding to the |
Ilya Shipitsin | 2272d8a | 2020-12-21 01:22:40 +0500 | [diff] [blame] | 1087 | multiple components of HAProxy. There are two domains available: proxy and dns. |
Amaury Denoyelle | fbd0bc9 | 2020-10-05 11:49:46 +0200 | [diff] [blame] | 1088 | If not specified, the proxy domain is selected. Note that only the proxy |
| 1089 | statistics are printed on the HTTP page. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1090 | |
| 1091 | 9.1. CSV format |
| 1092 | --------------- |
| 1093 | |
| 1094 | The statistics may be consulted either from the unix socket or from the HTTP |
| 1095 | page. Both means provide a CSV format whose fields follow. The first line |
| 1096 | begins with a sharp ('#') and has one word per comma-delimited field which |
| 1097 | represents the title of the column. All other lines starting at the second one |
| 1098 | use a classical CSV format using a comma as the delimiter, and the double quote |
| 1099 | ('"') as an optional text delimiter, but only if the enclosed text is ambiguous |
| 1100 | (if it contains a quote or a comma). The double-quote character ('"') in the |
| 1101 | text is doubled ('""'), which is the format that most tools recognize. Please |
| 1102 | do not insert any column before these ones in order not to break tools which |
| 1103 | use hard-coded column positions. |
| 1104 | |
Amaury Denoyelle | 50660a8 | 2020-10-05 11:49:39 +0200 | [diff] [blame] | 1105 | For proxy statistics, after each field name, the types which may have a value |
| 1106 | for that field are specified in brackets. The types are L (Listeners), F |
| 1107 | (Frontends), B (Backends), and S (Servers). There is a fixed set of static |
| 1108 | fields that are always available in the same order. A column containing the |
| 1109 | character '-' delimits the end of the static fields, after which presence or |
| 1110 | order of the fields are not guaranteed. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1111 | |
Amaury Denoyelle | 50660a8 | 2020-10-05 11:49:39 +0200 | [diff] [blame] | 1112 | Here is the list of static fields using the proxy statistics domain: |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1113 | 0. pxname [LFBS]: proxy name |
| 1114 | 1. svname [LFBS]: service name (FRONTEND for frontend, BACKEND for backend, |
| 1115 | any name for server/listener) |
| 1116 | 2. qcur [..BS]: current queued requests. For the backend this reports the |
| 1117 | number queued without a server assigned. |
| 1118 | 3. qmax [..BS]: max value of qcur |
| 1119 | 4. scur [LFBS]: current sessions |
| 1120 | 5. smax [LFBS]: max sessions |
| 1121 | 6. slim [LFBS]: configured session limit |
Willy Tarreau | c73810f | 2016-01-11 13:52:04 +0100 | [diff] [blame] | 1122 | 7. stot [LFBS]: cumulative number of sessions |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1123 | 8. bin [LFBS]: bytes in |
| 1124 | 9. bout [LFBS]: bytes out |
| 1125 | 10. dreq [LFB.]: requests denied because of security concerns. |
| 1126 | - For tcp this is because of a matched tcp-request content rule. |
| 1127 | - For http this is because of a matched http-request or tarpit rule. |
| 1128 | 11. dresp [LFBS]: responses denied because of security concerns. |
| 1129 | - For http this is because of a matched http-request rule, or |
| 1130 | "option checkcache". |
| 1131 | 12. ereq [LF..]: request errors. Some of the possible causes are: |
| 1132 | - early termination from the client, before the request has been sent. |
| 1133 | - read error from the client |
| 1134 | - client timeout |
| 1135 | - client closed connection |
| 1136 | - various bad requests from the client. |
| 1137 | - request was tarpitted. |
| 1138 | 13. econ [..BS]: number of requests that encountered an error trying to |
| 1139 | connect to a backend server. The backend stat is the sum of the stat |
| 1140 | for all servers of that backend, plus any connection errors not |
| 1141 | associated with a particular server (such as the backend having no |
| 1142 | active servers). |
| 1143 | 14. eresp [..BS]: response errors. srv_abrt will be counted here also. |
| 1144 | Some other errors are: |
| 1145 | - write error on the client socket (won't be counted for the server stat) |
| 1146 | - failure applying filters to the response. |
| 1147 | 15. wretr [..BS]: number of times a connection to a server was retried. |
| 1148 | 16. wredis [..BS]: number of times a request was redispatched to another |
| 1149 | server. The server value counts the number of times that server was |
| 1150 | switched away from. |
Willy Tarreau | b96dd28 | 2016-11-09 14:45:51 +0100 | [diff] [blame] | 1151 | 17. status [LFBS]: status (UP/DOWN/NOLB/MAINT/MAINT(via)/MAINT(resolution)...) |
Willy Tarreau | bd71510 | 2020-10-23 22:44:30 +0200 | [diff] [blame] | 1152 | 18. weight [..BS]: total effective weight (backend), effective weight (server) |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1153 | 19. act [..BS]: number of active servers (backend), server is active (server) |
| 1154 | 20. bck [..BS]: number of backup servers (backend), server is backup (server) |
| 1155 | 21. chkfail [...S]: number of failed checks. (Only counts checks failed when |
| 1156 | the server is up.) |
| 1157 | 22. chkdown [..BS]: number of UP->DOWN transitions. The backend counter counts |
| 1158 | transitions to the whole backend being down, rather than the sum of the |
| 1159 | counters for each server. |
| 1160 | 23. lastchg [..BS]: number of seconds since the last UP<->DOWN transition |
| 1161 | 24. downtime [..BS]: total downtime (in seconds). The value for the backend |
| 1162 | is the downtime for the whole backend, not the sum of the server downtime. |
| 1163 | 25. qlimit [...S]: configured maxqueue for the server, or nothing in the |
| 1164 | value is 0 (default, meaning no limit) |
| 1165 | 26. pid [LFBS]: process id (0 for first instance, 1 for second, ...) |
| 1166 | 27. iid [LFBS]: unique proxy id |
| 1167 | 28. sid [L..S]: server id (unique inside a proxy) |
| 1168 | 29. throttle [...S]: current throttle percentage for the server, when |
| 1169 | slowstart is active, or no value if not in slowstart. |
| 1170 | 30. lbtot [..BS]: total number of times a server was selected, either for new |
| 1171 | sessions, or when re-dispatching. The server counter is the number |
| 1172 | of times that server was selected. |
| 1173 | 31. tracked [...S]: id of proxy/server if tracking is enabled. |
| 1174 | 32. type [LFBS]: (0=frontend, 1=backend, 2=server, 3=socket/listener) |
| 1175 | 33. rate [.FBS]: number of sessions per second over last elapsed second |
| 1176 | 34. rate_lim [.F..]: configured limit on new sessions per second |
| 1177 | 35. rate_max [.FBS]: max number of new sessions per second |
| 1178 | 36. check_status [...S]: status of last health check, one of: |
| 1179 | UNK -> unknown |
| 1180 | INI -> initializing |
| 1181 | SOCKERR -> socket error |
| 1182 | L4OK -> check passed on layer 4, no upper layers testing enabled |
| 1183 | L4TOUT -> layer 1-4 timeout |
| 1184 | L4CON -> layer 1-4 connection problem, for example |
| 1185 | "Connection refused" (tcp rst) or "No route to host" (icmp) |
| 1186 | L6OK -> check passed on layer 6 |
| 1187 | L6TOUT -> layer 6 (SSL) timeout |
| 1188 | L6RSP -> layer 6 invalid response - protocol error |
| 1189 | L7OK -> check passed on layer 7 |
| 1190 | L7OKC -> check conditionally passed on layer 7, for example 404 with |
| 1191 | disable-on-404 |
| 1192 | L7TOUT -> layer 7 (HTTP/SMTP) timeout |
| 1193 | L7RSP -> layer 7 invalid response - protocol error |
| 1194 | L7STS -> layer 7 response error, for example HTTP 5xx |
Daniel Schneller | b6c8b0d | 2017-09-01 19:13:55 +0200 | [diff] [blame] | 1195 | Notice: If a check is currently running, the last known status will be |
| 1196 | reported, prefixed with "* ". e. g. "* L7OK". |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1197 | 37. check_code [...S]: layer5-7 code, if available |
| 1198 | 38. check_duration [...S]: time in ms took to finish last health check |
| 1199 | 39. hrsp_1xx [.FBS]: http responses with 1xx code |
| 1200 | 40. hrsp_2xx [.FBS]: http responses with 2xx code |
| 1201 | 41. hrsp_3xx [.FBS]: http responses with 3xx code |
| 1202 | 42. hrsp_4xx [.FBS]: http responses with 4xx code |
| 1203 | 43. hrsp_5xx [.FBS]: http responses with 5xx code |
| 1204 | 44. hrsp_other [.FBS]: http responses with other codes (protocol error) |
| 1205 | 45. hanafail [...S]: failed health checks details |
| 1206 | 46. req_rate [.F..]: HTTP requests per second over last elapsed second |
| 1207 | 47. req_rate_max [.F..]: max number of HTTP requests per second observed |
Willy Tarreau | fb981bd | 2016-12-12 14:31:46 +0100 | [diff] [blame] | 1208 | 48. req_tot [.FB.]: total number of HTTP requests received |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1209 | 49. cli_abrt [..BS]: number of data transfers aborted by the client |
| 1210 | 50. srv_abrt [..BS]: number of data transfers aborted by the server |
| 1211 | (inc. in eresp) |
| 1212 | 51. comp_in [.FB.]: number of HTTP response bytes fed to the compressor |
| 1213 | 52. comp_out [.FB.]: number of HTTP response bytes emitted by the compressor |
| 1214 | 53. comp_byp [.FB.]: number of bytes that bypassed the HTTP compressor |
| 1215 | (CPU/BW limit) |
| 1216 | 54. comp_rsp [.FB.]: number of HTTP responses that were compressed |
| 1217 | 55. lastsess [..BS]: number of seconds since last session assigned to |
| 1218 | server/backend |
| 1219 | 56. last_chk [...S]: last health check contents or textual error |
| 1220 | 57. last_agt [...S]: last agent check contents or textual error |
| 1221 | 58. qtime [..BS]: the average queue time in ms over the 1024 last requests |
| 1222 | 59. ctime [..BS]: the average connect time in ms over the 1024 last requests |
| 1223 | 60. rtime [..BS]: the average response time in ms over the 1024 last requests |
| 1224 | (0 for TCP) |
| 1225 | 61. ttime [..BS]: the average total session time in ms over the 1024 last |
| 1226 | requests |
Willy Tarreau | 7f61884 | 2016-01-08 11:40:03 +0100 | [diff] [blame] | 1227 | 62. agent_status [...S]: status of last agent check, one of: |
| 1228 | UNK -> unknown |
| 1229 | INI -> initializing |
| 1230 | SOCKERR -> socket error |
| 1231 | L4OK -> check passed on layer 4, no upper layers testing enabled |
| 1232 | L4TOUT -> layer 1-4 timeout |
| 1233 | L4CON -> layer 1-4 connection problem, for example |
| 1234 | "Connection refused" (tcp rst) or "No route to host" (icmp) |
| 1235 | L7OK -> agent reported "up" |
| 1236 | L7STS -> agent reported "fail", "stop", or "down" |
| 1237 | 63. agent_code [...S]: numeric code reported by agent if any (unused for now) |
| 1238 | 64. agent_duration [...S]: time in ms taken to finish last check |
Willy Tarreau | dd7354b | 2016-01-08 13:47:26 +0100 | [diff] [blame] | 1239 | 65. check_desc [...S]: short human-readable description of check_status |
| 1240 | 66. agent_desc [...S]: short human-readable description of agent_status |
Willy Tarreau | 3141f59 | 2016-01-08 14:25:28 +0100 | [diff] [blame] | 1241 | 67. check_rise [...S]: server's "rise" parameter used by checks |
| 1242 | 68. check_fall [...S]: server's "fall" parameter used by checks |
| 1243 | 69. check_health [...S]: server's health check value between 0 and rise+fall-1 |
| 1244 | 70. agent_rise [...S]: agent's "rise" parameter, normally 1 |
| 1245 | 71. agent_fall [...S]: agent's "fall" parameter, normally 1 |
| 1246 | 72. agent_health [...S]: agent's health parameter, between 0 and rise+fall-1 |
Willy Tarreau | a6f5a73 | 2016-01-08 16:59:56 +0100 | [diff] [blame] | 1247 | 73. addr [L..S]: address:port or "unix". IPv6 has brackets around the address. |
Willy Tarreau | e4847c6 | 2016-01-08 15:43:54 +0100 | [diff] [blame] | 1248 | 74: cookie [..BS]: server's cookie value or backend's cookie name |
Willy Tarreau | f8211df | 2016-01-11 14:09:38 +0100 | [diff] [blame] | 1249 | 75: mode [LFBS]: proxy mode (tcp, http, health, unknown) |
Willy Tarreau | f1516d9 | 2016-01-11 14:48:36 +0100 | [diff] [blame] | 1250 | 76: algo [..B.]: load balancing algorithm |
Willy Tarreau | c73810f | 2016-01-11 13:52:04 +0100 | [diff] [blame] | 1251 | 77: conn_rate [.F..]: number of connections over the last elapsed second |
| 1252 | 78: conn_rate_max [.F..]: highest known conn_rate |
| 1253 | 79: conn_tot [.F..]: cumulative number of connections |
Willy Tarreau | 5b9bdff | 2016-01-11 14:40:47 +0100 | [diff] [blame] | 1254 | 80: intercepted [.FB.]: cum. number of intercepted requests (monitor, stats) |
Willy Tarreau | 8a90b8e | 2016-10-21 18:15:32 +0200 | [diff] [blame] | 1255 | 81: dcon [LF..]: requests denied by "tcp-request connection" rules |
Willy Tarreau | a5bc36b | 2016-10-21 18:16:27 +0200 | [diff] [blame] | 1256 | 82: dses [LF..]: requests denied by "tcp-request session" rules |
Willy Tarreau | ea96a82 | 2018-05-28 15:15:43 +0200 | [diff] [blame] | 1257 | 83: wrew [LFBS]: cumulative number of failed header rewriting warnings |
Jérôme Magnin | 708eb88 | 2019-07-17 09:24:46 +0200 | [diff] [blame] | 1258 | 84: connect [..BS]: cumulative number of connection establishment attempts |
| 1259 | 85: reuse [..BS]: cumulative number of connection reuses |
Willy Tarreau | 7297429 | 2019-11-08 07:29:34 +0100 | [diff] [blame] | 1260 | 86: cache_lookups [.FB.]: cumulative number of cache lookups |
Jérôme Magnin | 34ebb5c | 2019-07-17 14:04:40 +0200 | [diff] [blame] | 1261 | 87: cache_hits [.FB.]: cumulative number of cache hits |
Christopher Faulet | 2ac2574 | 2019-11-08 15:27:27 +0100 | [diff] [blame] | 1262 | 88: srv_icur [...S]: current number of idle connections available for reuse |
| 1263 | 89: src_ilim [...S]: limit on the number of available idle connections |
| 1264 | 90. qtime_max [..BS]: the maximum observed queue time in ms |
| 1265 | 91. ctime_max [..BS]: the maximum observed connect time in ms |
| 1266 | 92. rtime_max [..BS]: the maximum observed response time in ms (0 for TCP) |
| 1267 | 93. ttime_max [..BS]: the maximum observed total session time in ms |
Christopher Faulet | 0159ee4 | 2019-12-16 14:40:39 +0100 | [diff] [blame] | 1268 | 94. eint [LFBS]: cumulative number of internal errors |
Pierre Cheynier | 08eb718 | 2020-10-08 16:37:14 +0200 | [diff] [blame] | 1269 | 95. idle_conn_cur [...S]: current number of unsafe idle connections |
| 1270 | 96. safe_conn_cur [...S]: current number of safe idle connections |
| 1271 | 97. used_conn_cur [...S]: current number of connections in use |
| 1272 | 98. need_conn_est [...S]: estimated needed number of connections |
Willy Tarreau | bd71510 | 2020-10-23 22:44:30 +0200 | [diff] [blame] | 1273 | 99. uweight [..BS]: total user weight (backend), server user weight (server) |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1274 | |
Amaury Denoyelle | 50660a8 | 2020-10-05 11:49:39 +0200 | [diff] [blame] | 1275 | For all other statistics domains, the presence or the order of the fields are |
| 1276 | not guaranteed. In this case, the header line should always be used to parse |
| 1277 | the CSV data. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1278 | |
Phil Scherer | b931f96 | 2020-12-02 19:36:08 +0000 | [diff] [blame] | 1279 | 9.2. Typed output format |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 1280 | ------------------------ |
| 1281 | |
| 1282 | Both "show info" and "show stat" support a mode where each output value comes |
| 1283 | with its type and sufficient information to know how the value is supposed to |
| 1284 | be aggregated between processes and how it evolves. |
| 1285 | |
| 1286 | In all cases, the output consists in having a single value per line with all |
| 1287 | the information split into fields delimited by colons (':'). |
| 1288 | |
| 1289 | The first column designates the object or metric being dumped. Its format is |
| 1290 | specific to the command producing this output and will not be described in this |
| 1291 | section. Usually it will consist in a series of identifiers and field names. |
| 1292 | |
| 1293 | The second column contains 3 characters respectively indicating the origin, the |
| 1294 | nature and the scope of the value being reported. The first character (the |
| 1295 | origin) indicates where the value was extracted from. Possible characters are : |
| 1296 | |
| 1297 | M The value is a metric. It is valid at one instant any may change depending |
| 1298 | on its nature . |
| 1299 | |
| 1300 | S The value is a status. It represents a discrete value which by definition |
| 1301 | cannot be aggregated. It may be the status of a server ("UP" or "DOWN"), |
| 1302 | the PID of the process, etc. |
| 1303 | |
| 1304 | K The value is a sorting key. It represents an identifier which may be used |
| 1305 | to group some values together because it is unique among its class. All |
| 1306 | internal identifiers are keys. Some names can be listed as keys if they |
| 1307 | are unique (eg: a frontend name is unique). In general keys come from the |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 1308 | configuration, even though some of them may automatically be assigned. For |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 1309 | most purposes keys may be considered as equivalent to configuration. |
| 1310 | |
| 1311 | C The value comes from the configuration. Certain configuration values make |
| 1312 | sense on the output, for example a concurrent connection limit or a cookie |
| 1313 | name. By definition these values are the same in all processes started |
| 1314 | from the same configuration file. |
| 1315 | |
| 1316 | P The value comes from the product itself. There are very few such values, |
| 1317 | most common use is to report the product name, version and release date. |
| 1318 | These elements are also the same between all processes. |
| 1319 | |
| 1320 | The second character (the nature) indicates the nature of the information |
| 1321 | carried by the field in order to let an aggregator decide on what operation to |
| 1322 | use to aggregate multiple values. Possible characters are : |
| 1323 | |
| 1324 | A The value represents an age since a last event. This is a bit different |
| 1325 | from the duration in that an age is automatically computed based on the |
| 1326 | current date. A typical example is how long ago did the last session |
| 1327 | happen on a server. Ages are generally aggregated by taking the minimum |
| 1328 | value and do not need to be stored. |
| 1329 | |
| 1330 | a The value represents an already averaged value. The average response times |
| 1331 | and server weights are of this nature. Averages can typically be averaged |
| 1332 | between processes. |
| 1333 | |
| 1334 | C The value represents a cumulative counter. Such measures perpetually |
| 1335 | increase until they wrap around. Some monitoring protocols need to tell |
| 1336 | the difference between a counter and a gauge to report a different type. |
| 1337 | In general counters may simply be summed since they represent events or |
| 1338 | volumes. Examples of metrics of this nature are connection counts or byte |
| 1339 | counts. |
| 1340 | |
| 1341 | D The value represents a duration for a status. There are a few usages of |
| 1342 | this, most of them include the time taken by the last health check and |
| 1343 | the time a server has spent down. Durations are generally not summed, |
| 1344 | most of the time the maximum will be retained to compute an SLA. |
| 1345 | |
| 1346 | G The value represents a gauge. It's a measure at one instant. The memory |
| 1347 | usage or the current number of active connections are of this nature. |
| 1348 | Metrics of this type are typically summed during aggregation. |
| 1349 | |
| 1350 | L The value represents a limit (generally a configured one). By nature, |
| 1351 | limits are harder to aggregate since they are specific to the point where |
| 1352 | they were retrieved. In certain situations they may be summed or be kept |
| 1353 | separate. |
| 1354 | |
| 1355 | M The value represents a maximum. In general it will apply to a gauge and |
| 1356 | keep the highest known value. An example of such a metric could be the |
| 1357 | maximum amount of concurrent connections that was encountered in the |
| 1358 | product's life time. To correctly aggregate maxima, you are supposed to |
| 1359 | output a range going from the maximum of all maxima and the sum of all |
| 1360 | of them. There is indeed no way to know if they were encountered |
| 1361 | simultaneously or not. |
| 1362 | |
| 1363 | m The value represents a minimum. In general it will apply to a gauge and |
| 1364 | keep the lowest known value. An example of such a metric could be the |
| 1365 | minimum amount of free memory pools that was encountered in the product's |
| 1366 | life time. To correctly aggregate minima, you are supposed to output a |
| 1367 | range going from the minimum of all minima and the sum of all of them. |
| 1368 | There is indeed no way to know if they were encountered simultaneously |
| 1369 | or not. |
| 1370 | |
| 1371 | N The value represents a name, so it is a string. It is used to report |
| 1372 | proxy names, server names and cookie names. Names have configuration or |
| 1373 | keys as their origin and are supposed to be the same among all processes. |
| 1374 | |
| 1375 | O The value represents a free text output. Outputs from various commands, |
| 1376 | returns from health checks, node descriptions are of such nature. |
| 1377 | |
| 1378 | R The value represents an event rate. It's a measure at one instant. It is |
| 1379 | quite similar to a gauge except that the recipient knows that this measure |
| 1380 | moves slowly and may decide not to keep all values. An example of such a |
| 1381 | metric is the measured amount of connections per second. Metrics of this |
| 1382 | type are typically summed during aggregation. |
| 1383 | |
| 1384 | T The value represents a date or time. A field emitting the current date |
| 1385 | would be of this type. The method to aggregate such information is left |
| 1386 | as an implementation choice. For now no field uses this type. |
| 1387 | |
| 1388 | The third character (the scope) indicates what extent the value reflects. Some |
| 1389 | elements may be per process while others may be per configuration or per system. |
| 1390 | The distinction is important to know whether or not a single value should be |
| 1391 | kept during aggregation or if values have to be aggregated. The following |
| 1392 | characters are currently supported : |
| 1393 | |
| 1394 | C The value is valid for a whole cluster of nodes, which is the set of nodes |
| 1395 | communicating over the peers protocol. An example could be the amount of |
| 1396 | entries present in a stick table that is replicated with other peers. At |
| 1397 | the moment no metric use this scope. |
| 1398 | |
| 1399 | P The value is valid only for the process reporting it. Most metrics use |
| 1400 | this scope. |
| 1401 | |
| 1402 | S The value is valid for the whole service, which is the set of processes |
| 1403 | started together from the same configuration file. All metrics originating |
| 1404 | from the configuration use this scope. Some other metrics may use it as |
| 1405 | well for some shared resources (eg: shared SSL cache statistics). |
| 1406 | |
| 1407 | s The value is valid for the whole system, such as the system's hostname, |
| 1408 | current date or resource usage. At the moment this scope is not used by |
| 1409 | any metric. |
| 1410 | |
| 1411 | Consumers of these information will generally have enough of these 3 characters |
| 1412 | to determine how to accurately report aggregated information across multiple |
| 1413 | processes. |
| 1414 | |
| 1415 | After this column, the third column indicates the type of the field, among "s32" |
| 1416 | (signed 32-bit integer), "s64" (signed 64-bit integer), "u32" (unsigned 32-bit |
| 1417 | integer), "u64" (unsigned 64-bit integer), "str" (string). It is important to |
| 1418 | know the type before parsing the value in order to properly read it. For example |
| 1419 | a string containing only digits is still a string an not an integer (eg: an |
| 1420 | error code extracted by a check). |
| 1421 | |
| 1422 | Then the fourth column is the value itself, encoded according to its type. |
| 1423 | Strings are dumped as-is immediately after the colon without any leading space. |
| 1424 | If a string contains a colon, it will appear normally. This means that the |
| 1425 | output should not be exclusively split around colons or some check outputs |
| 1426 | or server addresses might be truncated. |
| 1427 | |
| 1428 | |
| 1429 | 9.3. Unix Socket commands |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1430 | ------------------------- |
| 1431 | |
| 1432 | The stats socket is not enabled by default. In order to enable it, it is |
| 1433 | necessary to add one line in the global section of the haproxy configuration. |
| 1434 | A second line is recommended to set a larger timeout, always appreciated when |
| 1435 | issuing commands by hand : |
| 1436 | |
| 1437 | global |
| 1438 | stats socket /var/run/haproxy.sock mode 600 level admin |
| 1439 | stats timeout 2m |
| 1440 | |
| 1441 | It is also possible to add multiple instances of the stats socket by repeating |
| 1442 | the line, and make them listen to a TCP port instead of a UNIX socket. This is |
| 1443 | never done by default because this is dangerous, but can be handy in some |
| 1444 | situations : |
| 1445 | |
| 1446 | global |
| 1447 | stats socket /var/run/haproxy.sock mode 600 level admin |
| 1448 | stats socket ipv4@192.168.0.1:9999 level admin |
| 1449 | stats timeout 2m |
| 1450 | |
| 1451 | To access the socket, an external utility such as "socat" is required. Socat is |
| 1452 | a swiss-army knife to connect anything to anything. We use it to connect |
| 1453 | terminals to the socket, or a couple of stdin/stdout pipes to it for scripts. |
| 1454 | The two main syntaxes we'll use are the following : |
| 1455 | |
| 1456 | # socat /var/run/haproxy.sock stdio |
| 1457 | # socat /var/run/haproxy.sock readline |
| 1458 | |
| 1459 | The first one is used with scripts. It is possible to send the output of a |
| 1460 | script to haproxy, and pass haproxy's output to another script. That's useful |
| 1461 | for retrieving counters or attack traces for example. |
| 1462 | |
| 1463 | The second one is only useful for issuing commands by hand. It has the benefit |
| 1464 | that the terminal is handled by the readline library which supports line |
| 1465 | editing and history, which is very convenient when issuing repeated commands |
| 1466 | (eg: watch a counter). |
| 1467 | |
| 1468 | The socket supports two operation modes : |
| 1469 | - interactive |
| 1470 | - non-interactive |
| 1471 | |
| 1472 | The non-interactive mode is the default when socat connects to the socket. In |
| 1473 | this mode, a single line may be sent. It is processed as a whole, responses are |
| 1474 | sent back, and the connection closes after the end of the response. This is the |
| 1475 | mode that scripts and monitoring tools use. It is possible to send multiple |
| 1476 | commands in this mode, they need to be delimited by a semi-colon (';'). For |
| 1477 | example : |
| 1478 | |
| 1479 | # echo "show info;show stat;show table" | socat /var/run/haproxy stdio |
| 1480 | |
Dragan Dosen | a1c35ab | 2016-11-24 11:33:12 +0100 | [diff] [blame] | 1481 | If a command needs to use a semi-colon or a backslash (eg: in a value), it |
Joseph Herlant | 71b4b15 | 2018-11-13 16:55:16 -0800 | [diff] [blame] | 1482 | must be preceded by a backslash ('\'). |
Chad Lavoie | e3f5031 | 2016-05-26 16:42:25 -0400 | [diff] [blame] | 1483 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1484 | The interactive mode displays a prompt ('>') and waits for commands to be |
| 1485 | entered on the line, then processes them, and displays the prompt again to wait |
| 1486 | for a new command. This mode is entered via the "prompt" command which must be |
| 1487 | sent on the first line in non-interactive mode. The mode is a flip switch, if |
| 1488 | "prompt" is sent in interactive mode, it is disabled and the connection closes |
| 1489 | after processing the last command of the same line. |
| 1490 | |
| 1491 | For this reason, when debugging by hand, it's quite common to start with the |
| 1492 | "prompt" command : |
| 1493 | |
| 1494 | # socat /var/run/haproxy readline |
| 1495 | prompt |
| 1496 | > show info |
| 1497 | ... |
| 1498 | > |
| 1499 | |
| 1500 | Since multiple commands may be issued at once, haproxy uses the empty line as a |
| 1501 | delimiter to mark an end of output for each command, and takes care of ensuring |
| 1502 | that no command can emit an empty line on output. A script can thus easily |
| 1503 | parse the output even when multiple commands were pipelined on a single line. |
| 1504 | |
Aurélien Nephtali | abbf607 | 2018-04-18 13:26:46 +0200 | [diff] [blame] | 1505 | Some commands may take an optional payload. To add one to a command, the first |
| 1506 | line needs to end with the "<<\n" pattern. The next lines will be treated as |
| 1507 | the payload and can contain as many lines as needed. To validate a command with |
| 1508 | a payload, it needs to end with an empty line. |
| 1509 | |
| 1510 | Limitations do exist: the length of the whole buffer passed to the CLI must |
| 1511 | not be greater than tune.bfsize and the pattern "<<" must not be glued to the |
| 1512 | last word of the line. |
| 1513 | |
| 1514 | When entering a paylod while in interactive mode, the prompt will change from |
| 1515 | "> " to "+ ". |
| 1516 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1517 | It is important to understand that when multiple haproxy processes are started |
| 1518 | on the same sockets, any process may pick up the request and will output its |
| 1519 | own stats. |
| 1520 | |
| 1521 | The list of commands currently supported on the stats socket is provided below. |
| 1522 | If an unknown command is sent, haproxy displays the usage message which reminds |
| 1523 | all supported commands. Some commands support a more complex syntax, generally |
| 1524 | it will explain what part of the command is invalid when this happens. |
| 1525 | |
Olivier Doucet | d8703e8 | 2017-08-31 11:05:10 +0200 | [diff] [blame] | 1526 | Some commands require a higher level of privilege to work. If you do not have |
| 1527 | enough privilege, you will get an error "Permission denied". Please check |
| 1528 | the "level" option of the "bind" keyword lines in the configuration manual |
| 1529 | for more information. |
| 1530 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 1531 | abort ssl ca-file <cafile> |
| 1532 | Abort and destroy a temporary CA file update transaction. |
| 1533 | |
| 1534 | See also "set ssl ca-file" and "commit ssl ca-file". |
| 1535 | |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 1536 | abort ssl cert <filename> |
| 1537 | Abort and destroy a temporary SSL certificate update transaction. |
| 1538 | |
| 1539 | See also "set ssl cert" and "commit ssl cert". |
| 1540 | |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 1541 | abort ssl crl-file <crlfile> |
| 1542 | Abort and destroy a temporary CRL file update transaction. |
| 1543 | |
| 1544 | See also "set ssl crl-file" and "commit ssl crl-file". |
| 1545 | |
Willy Tarreau | bb51c44 | 2021-04-30 15:23:36 +0200 | [diff] [blame] | 1546 | add acl [@<ver>] <acl> <pattern> |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1547 | Add an entry into the acl <acl>. <acl> is the #<id> or the <file> returned by |
Willy Tarreau | bb51c44 | 2021-04-30 15:23:36 +0200 | [diff] [blame] | 1548 | "show acl". This command does not verify if the entry already exists. Entries |
| 1549 | are added to the current version of the ACL, unless a specific version is |
| 1550 | specified with "@<ver>". This version number must have preliminary been |
| 1551 | allocated by "prepare acl", and it will be comprised between the versions |
| 1552 | reported in "curr_ver" and "next_ver" on the output of "show acl". Entries |
| 1553 | added with a specific version number will not match until a "commit acl" |
| 1554 | operation is performed on them. They may however be consulted using the |
| 1555 | "show acl @<ver>" command, and cleared using a "clear acl @<ver>" command. |
| 1556 | This command cannot be used if the reference <acl> is a file also used with |
| 1557 | a map. In this case, the "add map" command must be used instead. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1558 | |
Willy Tarreau | bb51c44 | 2021-04-30 15:23:36 +0200 | [diff] [blame] | 1559 | add map [@<ver>] <map> <key> <value> |
| 1560 | add map [@<ver>] <map> <payload> |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1561 | Add an entry into the map <map> to associate the value <value> to the key |
| 1562 | <key>. This command does not verify if the entry already exists. It is |
Willy Tarreau | bb51c44 | 2021-04-30 15:23:36 +0200 | [diff] [blame] | 1563 | mainly used to fill a map after a "clear" or "prepare" operation. Entries |
| 1564 | are added to the current version of the ACL, unless a specific version is |
| 1565 | specified with "@<ver>". This version number must have preliminary been |
| 1566 | allocated by "prepare acl", and it will be comprised between the versions |
| 1567 | reported in "curr_ver" and "next_ver" on the output of "show acl". Entries |
| 1568 | added with a specific version number will not match until a "commit map" |
| 1569 | operation is performed on them. They may however be consulted using the |
| 1570 | "show map @<ver>" command, and cleared using a "clear acl @<ver>" command. |
| 1571 | If the designated map is also used as an ACL, the ACL will only match the |
| 1572 | <key> part and will ignore the <value> part. Using the payload syntax it is |
| 1573 | possible to add multiple key/value pairs by entering them on separate lines. |
| 1574 | On each new line, the first word is the key and the rest of the line is |
| 1575 | considered to be the value which can even contains spaces. |
Aurélien Nephtali | 25650ce | 2018-04-18 14:04:47 +0200 | [diff] [blame] | 1576 | |
| 1577 | Example: |
| 1578 | |
| 1579 | # socat /tmp/sock1 - |
| 1580 | prompt |
| 1581 | |
| 1582 | > add map #-1 << |
| 1583 | + key1 value1 |
| 1584 | + key2 value2 with spaces |
| 1585 | + key3 value3 also with spaces |
| 1586 | + key4 value4 |
| 1587 | |
| 1588 | > |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1589 | |
Amaury Denoyelle | f99f77a | 2021-03-08 17:13:32 +0100 | [diff] [blame] | 1590 | add server <backend>/<server> [args]* |
Amaury Denoyelle | 76e8b70 | 2022-03-09 15:07:31 +0100 | [diff] [blame] | 1591 | Instantiate a new server attached to the backend <backend>. |
Amaury Denoyelle | f99f77a | 2021-03-08 17:13:32 +0100 | [diff] [blame] | 1592 | |
| 1593 | The <server> name must not be already used in the backend. A special |
Amaury Denoyelle | eafd701 | 2021-04-29 14:59:42 +0200 | [diff] [blame] | 1594 | restriction is put on the backend which must used a dynamic load-balancing |
| 1595 | algorithm. A subset of keywords from the server config file statement can be |
| 1596 | used to configure the server behavior. Also note that no settings will be |
| 1597 | reused from an hypothetical 'default-server' statement in the same backend. |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1598 | |
Amaury Denoyelle | efbf35c | 2021-06-10 17:34:10 +0200 | [diff] [blame] | 1599 | Currently a dynamic server is statically initialized with the "none" |
| 1600 | init-addr method. This means that no resolution will be undertaken if a FQDN |
| 1601 | is specified as an address, even if the server creation will be validated. |
| 1602 | |
Amaury Denoyelle | 14c3c5c | 2021-08-23 14:10:51 +0200 | [diff] [blame] | 1603 | To support the reload operations, it is expected that the server created via |
| 1604 | the CLI is also manually inserted in the relevant haproxy configuration file. |
| 1605 | A dynamic server not present in the configuration won't be restored after a |
| 1606 | reload operation. |
| 1607 | |
Amaury Denoyelle | 56eb8ed | 2021-07-13 10:36:03 +0200 | [diff] [blame] | 1608 | A dynamic server may use the "track" keyword to follow the check status of |
| 1609 | another server from the configuration. However, it is not possible to track |
| 1610 | another dynamic server. This is to ensure that the tracking chain is kept |
| 1611 | consistent even in the case of dynamic servers deletion. |
| 1612 | |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1613 | Use the "check" keyword to enable health-check support. Note that the |
| 1614 | health-check is disabled by default and must be enabled independently from |
Amaury Denoyelle | b65f4ca | 2021-08-04 11:33:14 +0200 | [diff] [blame] | 1615 | the server using the "enable health" command. For agent checks, use the |
| 1616 | "agent-check" keyword and the "enable agent" command. Note that in this case |
| 1617 | the server may be activated via the agent depending on the status reported, |
| 1618 | without an explicit "enable server" command. This also means that extra care |
| 1619 | is required when removing a dynamic server with agent check. The agent should |
| 1620 | be first deactivated via "disable agent" to be able to put the server in the |
| 1621 | required maintenance mode before removal. |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1622 | |
Amaury Denoyelle | 414a612 | 2021-08-06 10:25:32 +0200 | [diff] [blame] | 1623 | It may be possible to reach the fd limit when using a large number of dynamic |
| 1624 | servers. Please refer to the "u-limit" global keyword documentation in this |
| 1625 | case. |
| 1626 | |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1627 | Here is the list of the currently supported keywords : |
| 1628 | |
Amaury Denoyelle | b65f4ca | 2021-08-04 11:33:14 +0200 | [diff] [blame] | 1629 | - agent-addr |
| 1630 | - agent-check |
| 1631 | - agent-inter |
| 1632 | - agent-port |
| 1633 | - agent-send |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1634 | - allow-0rtt |
| 1635 | - alpn |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1636 | - addr |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1637 | - backup |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1638 | - ca-file |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1639 | - check |
Amaury Denoyelle | 79b90e8 | 2021-09-20 15:15:19 +0200 | [diff] [blame] | 1640 | - check-alpn |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1641 | - check-proto |
| 1642 | - check-send-proxy |
Amaury Denoyelle | 79b90e8 | 2021-09-20 15:15:19 +0200 | [diff] [blame] | 1643 | - check-sni |
| 1644 | - check-ssl |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1645 | - check-via-socks4 |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1646 | - ciphers |
| 1647 | - ciphersuites |
| 1648 | - crl-file |
| 1649 | - crt |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1650 | - disabled |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1651 | - downinter |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1652 | - enabled |
Amaury Denoyelle | 725f8d2 | 2021-09-20 15:16:12 +0200 | [diff] [blame] | 1653 | - error-limit |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1654 | - fall |
| 1655 | - fastinter |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1656 | - force-sslv3/tlsv10/tlsv11/tlsv12/tlsv13 |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1657 | - id |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1658 | - inter |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1659 | - maxconn |
| 1660 | - maxqueue |
| 1661 | - minconn |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1662 | - no-ssl-reuse |
| 1663 | - no-sslv3/tlsv10/tlsv11/tlsv12/tlsv13 |
| 1664 | - no-tls-tickets |
| 1665 | - npn |
Amaury Denoyelle | 725f8d2 | 2021-09-20 15:16:12 +0200 | [diff] [blame] | 1666 | - observe |
| 1667 | - on-error |
| 1668 | - on-marked-down |
| 1669 | - on-marked-up |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1670 | - pool-low-conn |
| 1671 | - pool-max-conn |
| 1672 | - pool-purge-delay |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1673 | - port |
Amaury Denoyelle | 3046723 | 2021-03-12 18:03:27 +0100 | [diff] [blame] | 1674 | - proto |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1675 | - proxy-v2-options |
Amaury Denoyelle | 2fc4d39 | 2021-07-22 16:04:59 +0200 | [diff] [blame] | 1676 | - rise |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1677 | - send-proxy |
| 1678 | - send-proxy-v2 |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1679 | - send-proxy-v2-ssl |
| 1680 | - send-proxy-v2-ssl-cn |
Amaury Denoyelle | cd8a6f2 | 2021-09-21 11:51:54 +0200 | [diff] [blame] | 1681 | - slowstart |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1682 | - sni |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1683 | - source |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1684 | - ssl |
| 1685 | - ssl-max-ver |
| 1686 | - ssl-min-ver |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1687 | - tfo |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1688 | - tls-tickets |
Amaury Denoyelle | 56eb8ed | 2021-07-13 10:36:03 +0200 | [diff] [blame] | 1689 | - track |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1690 | - usesrc |
Amaury Denoyelle | 34897d2 | 2021-05-19 09:49:41 +0200 | [diff] [blame] | 1691 | - verify |
| 1692 | - verifyhost |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1693 | - weight |
Amaury Denoyelle | f9d5957 | 2021-10-18 14:40:29 +0200 | [diff] [blame] | 1694 | - ws |
Amaury Denoyelle | fc465a5 | 2021-03-09 17:36:23 +0100 | [diff] [blame] | 1695 | |
| 1696 | Their syntax is similar to the server line from the configuration file, |
| 1697 | please refer to their individual documentation for details. |
Amaury Denoyelle | f99f77a | 2021-03-08 17:13:32 +0100 | [diff] [blame] | 1698 | |
William Lallemand | 62c0b99 | 2022-07-29 17:50:58 +0200 | [diff] [blame] | 1699 | add ssl ca-file <cafile> <payload> |
| 1700 | Add a new certificate to a ca-file. This command is useful when you reached |
Michael Prokop | 9a62e35 | 2022-12-09 12:28:46 +0100 | [diff] [blame] | 1701 | the buffer size limit on the CLI and want to add multiple certificates. |
William Lallemand | 62c0b99 | 2022-07-29 17:50:58 +0200 | [diff] [blame] | 1702 | Instead of doing a "set" with all the certificates you are able to add each |
| 1703 | certificate individually. A "set ssl ca-file" will reset the ca-file. |
| 1704 | |
| 1705 | Example: |
| 1706 | echo -e "set ssl ca-file cafile.pem <<\n$(cat rootCA.crt)\n" | \ |
| 1707 | socat /var/run/haproxy.stat - |
| 1708 | echo -e "add ssl ca-file cafile.pem <<\n$(cat intermediate1.crt)\n" | \ |
| 1709 | socat /var/run/haproxy.stat - |
| 1710 | echo -e "add ssl ca-file cafile.pem <<\n$(cat intermediate2.crt)\n" | \ |
| 1711 | socat /var/run/haproxy.stat - |
| 1712 | echo "commit ssl ca-file cafile.pem" | socat /var/run/haproxy.stat - |
| 1713 | |
William Lallemand | accac23 | 2020-04-02 17:42:51 +0200 | [diff] [blame] | 1714 | add ssl crt-list <crtlist> <certificate> |
| 1715 | add ssl crt-list <crtlist> <payload> |
| 1716 | Add an certificate in a crt-list. It can also be used for directories since |
| 1717 | directories are now loaded the same way as the crt-lists. This command allow |
| 1718 | you to use a certificate name in parameter, to use SSL options or filters a |
| 1719 | crt-list line must sent as a payload instead. Only one crt-list line is |
| 1720 | supported in the payload. This command will load the certificate for every |
| 1721 | bind lines using the crt-list. To push a new certificate to HAProxy the |
| 1722 | commands "new ssl cert" and "set ssl cert" must be used. |
| 1723 | |
| 1724 | Example: |
| 1725 | $ echo "new ssl cert foobar.pem" | socat /tmp/sock1 - |
| 1726 | $ echo -e "set ssl cert foobar.pem <<\n$(cat foobar.pem)\n" | socat |
| 1727 | /tmp/sock1 - |
| 1728 | $ echo "commit ssl cert foobar.pem" | socat /tmp/sock1 - |
| 1729 | $ echo "add ssl crt-list certlist1 foobar.pem" | socat /tmp/sock1 - |
| 1730 | |
| 1731 | $ echo -e 'add ssl crt-list certlist1 <<\nfoobar.pem [allow-0rtt] foo.bar.com |
| 1732 | !test1.com\n' | socat /tmp/sock1 - |
| 1733 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1734 | clear counters |
| 1735 | Clear the max values of the statistics counters in each proxy (frontend & |
Willy Tarreau | d80cb4e | 2018-01-20 19:30:13 +0100 | [diff] [blame] | 1736 | backend) and in each server. The accumulated counters are not affected. The |
| 1737 | internal activity counters reported by "show activity" are also reset. This |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1738 | can be used to get clean counters after an incident, without having to |
| 1739 | restart nor to clear traffic counters. This command is restricted and can |
| 1740 | only be issued on sockets configured for levels "operator" or "admin". |
| 1741 | |
| 1742 | clear counters all |
| 1743 | Clear all statistics counters in each proxy (frontend & backend) and in each |
| 1744 | server. This has the same effect as restarting. This command is restricted |
| 1745 | and can only be issued on sockets configured for level "admin". |
| 1746 | |
Willy Tarreau | ff3feeb | 2021-04-30 13:31:43 +0200 | [diff] [blame] | 1747 | clear acl [@<ver>] <acl> |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1748 | Remove all entries from the acl <acl>. <acl> is the #<id> or the <file> |
| 1749 | returned by "show acl". Note that if the reference <acl> is a file and is |
Willy Tarreau | ff3feeb | 2021-04-30 13:31:43 +0200 | [diff] [blame] | 1750 | shared with a map, this map will be also cleared. By default only the current |
| 1751 | version of the ACL is cleared (the one being matched against). However it is |
| 1752 | possible to specify another version using '@' followed by this version. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1753 | |
Willy Tarreau | ff3feeb | 2021-04-30 13:31:43 +0200 | [diff] [blame] | 1754 | clear map [@<ver>] <map> |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1755 | Remove all entries from the map <map>. <map> is the #<id> or the <file> |
| 1756 | returned by "show map". Note that if the reference <map> is a file and is |
Willy Tarreau | ff3feeb | 2021-04-30 13:31:43 +0200 | [diff] [blame] | 1757 | shared with a acl, this acl will be also cleared. By default only the current |
| 1758 | version of the map is cleared (the one being matched against). However it is |
| 1759 | possible to specify another version using '@' followed by this version. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1760 | |
| 1761 | clear table <table> [ data.<type> <operator> <value> ] | [ key <key> ] |
| 1762 | Remove entries from the stick-table <table>. |
| 1763 | |
| 1764 | This is typically used to unblock some users complaining they have been |
| 1765 | abusively denied access to a service, but this can also be used to clear some |
| 1766 | stickiness entries matching a server that is going to be replaced (see "show |
| 1767 | table" below for details). Note that sometimes, removal of an entry will be |
| 1768 | refused because it is currently tracked by a session. Retrying a few seconds |
| 1769 | later after the session ends is usual enough. |
| 1770 | |
| 1771 | In the case where no options arguments are given all entries will be removed. |
| 1772 | |
| 1773 | When the "data." form is used entries matching a filter applied using the |
| 1774 | stored data (see "stick-table" in section 4.2) are removed. A stored data |
| 1775 | type must be specified in <type>, and this data type must be stored in the |
| 1776 | table otherwise an error is reported. The data is compared according to |
| 1777 | <operator> with the 64-bit integer <value>. Operators are the same as with |
| 1778 | the ACLs : |
| 1779 | |
| 1780 | - eq : match entries whose data is equal to this value |
| 1781 | - ne : match entries whose data is not equal to this value |
| 1782 | - le : match entries whose data is less than or equal to this value |
| 1783 | - ge : match entries whose data is greater than or equal to this value |
| 1784 | - lt : match entries whose data is less than this value |
| 1785 | - gt : match entries whose data is greater than this value |
| 1786 | |
| 1787 | When the key form is used the entry <key> is removed. The key must be of the |
| 1788 | same type as the table, which currently is limited to IPv4, IPv6, integer and |
| 1789 | string. |
| 1790 | |
| 1791 | Example : |
| 1792 | $ echo "show table http_proxy" | socat stdio /tmp/sock1 |
| 1793 | >>> # table: http_proxy, type: ip, size:204800, used:2 |
| 1794 | >>> 0x80e6a4c: key=127.0.0.1 use=0 exp=3594729 gpc0=0 conn_rate(30000)=1 \ |
| 1795 | bytes_out_rate(60000)=187 |
| 1796 | >>> 0x80e6a80: key=127.0.0.2 use=0 exp=3594740 gpc0=1 conn_rate(30000)=10 \ |
| 1797 | bytes_out_rate(60000)=191 |
| 1798 | |
| 1799 | $ echo "clear table http_proxy key 127.0.0.1" | socat stdio /tmp/sock1 |
| 1800 | |
| 1801 | $ echo "show table http_proxy" | socat stdio /tmp/sock1 |
| 1802 | >>> # table: http_proxy, type: ip, size:204800, used:1 |
| 1803 | >>> 0x80e6a80: key=127.0.0.2 use=0 exp=3594740 gpc0=1 conn_rate(30000)=10 \ |
| 1804 | bytes_out_rate(60000)=191 |
| 1805 | $ echo "clear table http_proxy data.gpc0 eq 1" | socat stdio /tmp/sock1 |
| 1806 | $ echo "show table http_proxy" | socat stdio /tmp/sock1 |
| 1807 | >>> # table: http_proxy, type: ip, size:204800, used:1 |
| 1808 | |
Willy Tarreau | 7a562ca | 2021-04-30 15:10:01 +0200 | [diff] [blame] | 1809 | commit acl @<ver> <acl> |
| 1810 | Commit all changes made to version <ver> of ACL <acl>, and deletes all past |
| 1811 | versions. <acl> is the #<id> or the <file> returned by "show acl". The |
| 1812 | version number must be between "curr_ver"+1 and "next_ver" as reported in |
| 1813 | "show acl". The contents to be committed to the ACL can be consulted with |
| 1814 | "show acl @<ver> <acl>" if desired. The specified version number has normally |
| 1815 | been created with the "prepare acl" command. The replacement is atomic. It |
| 1816 | consists in atomically updating the current version to the specified version, |
| 1817 | which will instantly cause all entries in other versions to become invisible, |
| 1818 | and all entries in the new version to become visible. It is also possible to |
| 1819 | use this command to perform an atomic removal of all visible entries of an |
| 1820 | ACL by calling "prepare acl" first then committing without adding any |
| 1821 | entries. This command cannot be used if the reference <acl> is a file also |
| 1822 | used as a map. In this case, the "commit map" command must be used instead. |
| 1823 | |
| 1824 | commit map @<ver> <map> |
| 1825 | Commit all changes made to version <ver> of map <map>, and deletes all past |
| 1826 | versions. <map> is the #<id> or the <file> returned by "show map". The |
| 1827 | version number must be between "curr_ver"+1 and "next_ver" as reported in |
| 1828 | "show map". The contents to be committed to the map can be consulted with |
| 1829 | "show map @<ver> <map>" if desired. The specified version number has normally |
| 1830 | been created with the "prepare map" command. The replacement is atomic. It |
| 1831 | consists in atomically updating the current version to the specified version, |
| 1832 | which will instantly cause all entries in other versions to become invisible, |
| 1833 | and all entries in the new version to become visible. It is also possible to |
| 1834 | use this command to perform an atomic removal of all visible entries of an |
| 1835 | map by calling "prepare map" first then committing without adding any |
| 1836 | entries. |
| 1837 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 1838 | commit ssl ca-file <cafile> |
| 1839 | Commit a temporary SSL CA file update transaction. |
| 1840 | |
| 1841 | In the case of an existing CA file (in a "Used" state in "show ssl ca-file"), |
| 1842 | the new CA file tree entry is inserted in the CA file tree and every instance |
| 1843 | that used the CA file entry is rebuilt, along with the SSL contexts it needs. |
| 1844 | All the contexts previously used by the rebuilt instances are removed. |
| 1845 | Upon success, the previous CA file entry is removed from the tree. |
| 1846 | Upon failure, nothing is removed or deleted, and all the original SSL |
| 1847 | contexts are kept and used. |
| 1848 | Once the temporary transaction is committed, it is destroyed. |
| 1849 | |
| 1850 | In the case of a new CA file (after a "new ssl ca-file" and in a "Unused" |
| 1851 | state in "show ssl ca-file"), the CA file will be inserted in the CA file |
| 1852 | tree but it won't be used anywhere in HAProxy. To use it and generate SSL |
| 1853 | contexts that use it, you will need to add it to a crt-list with "add ssl |
| 1854 | crt-list". |
| 1855 | |
William Lallemand | 62c0b99 | 2022-07-29 17:50:58 +0200 | [diff] [blame] | 1856 | See also "new ssl ca-file", "set ssl ca-file", "add ssl ca-file", |
| 1857 | "abort ssl ca-file" and "add ssl crt-list". |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 1858 | |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 1859 | commit ssl cert <filename> |
William Lallemand | c184d87 | 2020-06-26 15:39:57 +0200 | [diff] [blame] | 1860 | Commit a temporary SSL certificate update transaction. |
| 1861 | |
| 1862 | In the case of an existing certificate (in a "Used" state in "show ssl |
| 1863 | cert"), generate every SSL contextes and SNIs it need, insert them, and |
| 1864 | remove the previous ones. Replace in memory the previous SSL certificates |
| 1865 | everywhere the <filename> was used in the configuration. Upon failure it |
| 1866 | doesn't remove or insert anything. Once the temporary transaction is |
| 1867 | committed, it is destroyed. |
| 1868 | |
| 1869 | In the case of a new certificate (after a "new ssl cert" and in a "Unused" |
Ilya Shipitsin | 2272d8a | 2020-12-21 01:22:40 +0500 | [diff] [blame] | 1870 | state in "show ssl cert"), the certificate will be committed in a certificate |
William Lallemand | c184d87 | 2020-06-26 15:39:57 +0200 | [diff] [blame] | 1871 | storage, but it won't be used anywhere in haproxy. To use it and generate |
| 1872 | its SNIs you will need to add it to a crt-list or a directory with "add ssl |
| 1873 | crt-list". |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 1874 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 1875 | See also "new ssl cert", "set ssl cert", "abort ssl cert" and |
William Lallemand | c184d87 | 2020-06-26 15:39:57 +0200 | [diff] [blame] | 1876 | "add ssl crt-list". |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 1877 | |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 1878 | commit ssl crl-file <crlfile> |
| 1879 | Commit a temporary SSL CRL file update transaction. |
| 1880 | |
| 1881 | In the case of an existing CRL file (in a "Used" state in "show ssl |
| 1882 | crl-file"), the new CRL file entry is inserted in the CA file tree (which |
| 1883 | holds both the CA files and the CRL files) and every instance that used the |
| 1884 | CRL file entry is rebuilt, along with the SSL contexts it needs. |
| 1885 | All the contexts previously used by the rebuilt instances are removed. |
| 1886 | Upon success, the previous CRL file entry is removed from the tree. |
| 1887 | Upon failure, nothing is removed or deleted, and all the original SSL |
| 1888 | contexts are kept and used. |
| 1889 | Once the temporary transaction is committed, it is destroyed. |
| 1890 | |
| 1891 | In the case of a new CRL file (after a "new ssl crl-file" and in a "Unused" |
| 1892 | state in "show ssl crl-file"), the CRL file will be inserted in the CRL file |
| 1893 | tree but it won't be used anywhere in HAProxy. To use it and generate SSL |
| 1894 | contexts that use it, you will need to add it to a crt-list with "add ssl |
| 1895 | crt-list". |
| 1896 | |
| 1897 | See also "new ssl crl-file", "set ssl crl-file", "abort ssl crl-file" and |
| 1898 | "add ssl crt-list". |
| 1899 | |
Willy Tarreau | 6bdf3e9 | 2019-05-20 14:25:05 +0200 | [diff] [blame] | 1900 | debug dev <command> [args]* |
Willy Tarreau | b24ab22 | 2019-10-24 18:03:39 +0200 | [diff] [blame] | 1901 | Call a developer-specific command. Only supported on a CLI connection running |
| 1902 | in expert mode (see "expert-mode on"). Such commands are extremely dangerous |
| 1903 | and not forgiving, any misuse may result in a crash of the process. They are |
| 1904 | intended for experts only, and must really not be used unless told to do so. |
| 1905 | Some of them are only available when haproxy is built with DEBUG_DEV defined |
| 1906 | because they may have security implications. All of these commands require |
| 1907 | admin privileges, and are purposely not documented to avoid encouraging their |
| 1908 | use by people who are not at ease with the source code. |
Willy Tarreau | 6bdf3e9 | 2019-05-20 14:25:05 +0200 | [diff] [blame] | 1909 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1910 | del acl <acl> [<key>|#<ref>] |
| 1911 | Delete all the acl entries from the acl <acl> corresponding to the key <key>. |
| 1912 | <acl> is the #<id> or the <file> returned by "show acl". If the <ref> is used, |
| 1913 | this command delete only the listed reference. The reference can be found with |
| 1914 | listing the content of the acl. Note that if the reference <acl> is a file and |
| 1915 | is shared with a map, the entry will be also deleted in the map. |
| 1916 | |
| 1917 | del map <map> [<key>|#<ref>] |
| 1918 | Delete all the map entries from the map <map> corresponding to the key <key>. |
| 1919 | <map> is the #<id> or the <file> returned by "show map". If the <ref> is used, |
| 1920 | this command delete only the listed reference. The reference can be found with |
| 1921 | listing the content of the map. Note that if the reference <map> is a file and |
| 1922 | is shared with a acl, the entry will be also deleted in the map. |
| 1923 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 1924 | del ssl ca-file <cafile> |
| 1925 | Delete a CA file tree entry from HAProxy. The CA file must be unused and |
| 1926 | removed from any crt-list. "show ssl ca-file" displays the status of the CA |
| 1927 | files. The deletion doesn't work with a certificate referenced directly with |
| 1928 | the "ca-file" or "ca-verify-file" directives in the configuration. |
| 1929 | |
William Lallemand | 419e634 | 2020-04-08 12:05:39 +0200 | [diff] [blame] | 1930 | del ssl cert <certfile> |
| 1931 | Delete a certificate store from HAProxy. The certificate must be unused and |
| 1932 | removed from any crt-list or directory. "show ssl cert" displays the status |
| 1933 | of the certificate. The deletion doesn't work with a certificate referenced |
| 1934 | directly with the "crt" directive in the configuration. |
| 1935 | |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 1936 | del ssl crl-file <crlfile> |
| 1937 | Delete a CRL file tree entry from HAProxy. The CRL file must be unused and |
| 1938 | removed from any crt-list. "show ssl crl-file" displays the status of the CRL |
| 1939 | files. The deletion doesn't work with a certificate referenced directly with |
| 1940 | the "crl-file" directive in the configuration. |
| 1941 | |
William Lallemand | 0a9b941 | 2020-04-06 17:43:05 +0200 | [diff] [blame] | 1942 | del ssl crt-list <filename> <certfile[:line]> |
| 1943 | Delete an entry in a crt-list. This will delete every SNIs used for this |
| 1944 | entry in the frontends. If a certificate is used several time in a crt-list, |
| 1945 | you will need to provide which line you want to delete. To display the line |
| 1946 | numbers, use "show ssl crt-list -n <crtlist>". |
| 1947 | |
Amaury Denoyelle | e558043 | 2021-04-15 14:41:20 +0200 | [diff] [blame] | 1948 | del server <backend>/<server> |
Amaury Denoyelle | 14c3c5c | 2021-08-23 14:10:51 +0200 | [diff] [blame] | 1949 | Remove a server attached to the backend <backend>. All servers are eligible, |
| 1950 | except servers which are referenced by other configuration elements. The |
| 1951 | server must be put in maintenance mode prior to its deletion. The operation |
| 1952 | is cancelled if the serveur still has active or idle connection or its |
| 1953 | connection queue is not empty. |
Amaury Denoyelle | e558043 | 2021-04-15 14:41:20 +0200 | [diff] [blame] | 1954 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1955 | disable agent <backend>/<server> |
| 1956 | Mark the auxiliary agent check as temporarily stopped. |
| 1957 | |
| 1958 | In the case where an agent check is being run as a auxiliary check, due |
| 1959 | to the agent-check parameter of a server directive, new checks are only |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 1960 | initialized when the agent is in the enabled. Thus, disable agent will |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1961 | prevent any new agent checks from begin initiated until the agent |
| 1962 | re-enabled using enable agent. |
| 1963 | |
| 1964 | When an agent is disabled the processing of an auxiliary agent check that |
| 1965 | was initiated while the agent was set as enabled is as follows: All |
| 1966 | results that would alter the weight, specifically "drain" or a weight |
| 1967 | returned by the agent, are ignored. The processing of agent check is |
| 1968 | otherwise unchanged. |
| 1969 | |
| 1970 | The motivation for this feature is to allow the weight changing effects |
| 1971 | of the agent checks to be paused to allow the weight of a server to be |
| 1972 | configured using set weight without being overridden by the agent. |
| 1973 | |
| 1974 | This command is restricted and can only be issued on sockets configured for |
| 1975 | level "admin". |
| 1976 | |
Olivier Houchard | 614f8d7 | 2017-03-14 20:08:46 +0100 | [diff] [blame] | 1977 | disable dynamic-cookie backend <backend> |
Ilya Shipitsin | 2a950d0 | 2020-03-06 13:07:38 +0500 | [diff] [blame] | 1978 | Disable the generation of dynamic cookies for the backend <backend> |
Olivier Houchard | 614f8d7 | 2017-03-14 20:08:46 +0100 | [diff] [blame] | 1979 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 1980 | disable frontend <frontend> |
| 1981 | Mark the frontend as temporarily stopped. This corresponds to the mode which |
| 1982 | is used during a soft restart : the frontend releases the port but can be |
| 1983 | enabled again if needed. This should be used with care as some non-Linux OSes |
| 1984 | are unable to enable it back. This is intended to be used in environments |
| 1985 | where stopping a proxy is not even imaginable but a misconfigured proxy must |
| 1986 | be fixed. That way it's possible to release the port and bind it into another |
| 1987 | process to restore operations. The frontend will appear with status "STOP" |
| 1988 | on the stats page. |
| 1989 | |
| 1990 | The frontend may be specified either by its name or by its numeric ID, |
| 1991 | prefixed with a sharp ('#'). |
| 1992 | |
| 1993 | This command is restricted and can only be issued on sockets configured for |
| 1994 | level "admin". |
| 1995 | |
| 1996 | disable health <backend>/<server> |
| 1997 | Mark the primary health check as temporarily stopped. This will disable |
| 1998 | sending of health checks, and the last health check result will be ignored. |
| 1999 | The server will be in unchecked state and considered UP unless an auxiliary |
| 2000 | agent check forces it down. |
| 2001 | |
| 2002 | This command is restricted and can only be issued on sockets configured for |
| 2003 | level "admin". |
| 2004 | |
| 2005 | disable server <backend>/<server> |
| 2006 | Mark the server DOWN for maintenance. In this mode, no more checks will be |
| 2007 | performed on the server until it leaves maintenance. |
| 2008 | If the server is tracked by other servers, those servers will be set to DOWN |
| 2009 | during the maintenance. |
| 2010 | |
| 2011 | In the statistics page, a server DOWN for maintenance will appear with a |
| 2012 | "MAINT" status, its tracking servers with the "MAINT(via)" one. |
| 2013 | |
| 2014 | Both the backend and the server may be specified either by their name or by |
| 2015 | their numeric ID, prefixed with a sharp ('#'). |
| 2016 | |
| 2017 | This command is restricted and can only be issued on sockets configured for |
| 2018 | level "admin". |
| 2019 | |
| 2020 | enable agent <backend>/<server> |
| 2021 | Resume auxiliary agent check that was temporarily stopped. |
| 2022 | |
| 2023 | See "disable agent" for details of the effect of temporarily starting |
| 2024 | and stopping an auxiliary agent. |
| 2025 | |
| 2026 | This command is restricted and can only be issued on sockets configured for |
| 2027 | level "admin". |
| 2028 | |
Olivier Houchard | 614f8d7 | 2017-03-14 20:08:46 +0100 | [diff] [blame] | 2029 | enable dynamic-cookie backend <backend> |
n9@users.noreply.github.com | 25a1c8e | 2019-08-23 11:21:05 +0200 | [diff] [blame] | 2030 | Enable the generation of dynamic cookies for the backend <backend>. |
| 2031 | A secret key must also be provided. |
Olivier Houchard | 614f8d7 | 2017-03-14 20:08:46 +0100 | [diff] [blame] | 2032 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2033 | enable frontend <frontend> |
| 2034 | Resume a frontend which was temporarily stopped. It is possible that some of |
| 2035 | the listening ports won't be able to bind anymore (eg: if another process |
| 2036 | took them since the 'disable frontend' operation). If this happens, an error |
| 2037 | is displayed. Some operating systems might not be able to resume a frontend |
| 2038 | which was disabled. |
| 2039 | |
| 2040 | The frontend may be specified either by its name or by its numeric ID, |
| 2041 | prefixed with a sharp ('#'). |
| 2042 | |
| 2043 | This command is restricted and can only be issued on sockets configured for |
| 2044 | level "admin". |
| 2045 | |
| 2046 | enable health <backend>/<server> |
| 2047 | Resume a primary health check that was temporarily stopped. This will enable |
| 2048 | sending of health checks again. Please see "disable health" for details. |
| 2049 | |
| 2050 | This command is restricted and can only be issued on sockets configured for |
| 2051 | level "admin". |
| 2052 | |
| 2053 | enable server <backend>/<server> |
| 2054 | If the server was previously marked as DOWN for maintenance, this marks the |
| 2055 | server UP and checks are re-enabled. |
| 2056 | |
| 2057 | Both the backend and the server may be specified either by their name or by |
| 2058 | their numeric ID, prefixed with a sharp ('#'). |
| 2059 | |
| 2060 | This command is restricted and can only be issued on sockets configured for |
| 2061 | level "admin". |
| 2062 | |
Amaury Denoyelle | 18487fb | 2021-03-18 15:32:53 +0100 | [diff] [blame] | 2063 | experimental-mode [on|off] |
| 2064 | Without options, this indicates whether the experimental mode is enabled or |
| 2065 | disabled on the current connection. When passed "on", it turns the |
| 2066 | experimental mode on for the current CLI connection only. With "off" it turns |
| 2067 | it off. |
| 2068 | |
| 2069 | The experimental mode is used to access to extra features still in |
| 2070 | development. These features are currently not stable and should be used with |
Ilya Shipitsin | ba13f16 | 2021-03-19 22:21:44 +0500 | [diff] [blame] | 2071 | care. They may be subject to breaking changes across versions. |
Amaury Denoyelle | 18487fb | 2021-03-18 15:32:53 +0100 | [diff] [blame] | 2072 | |
William Lallemand | 7267f78 | 2022-02-01 16:08:50 +0100 | [diff] [blame] | 2073 | When used from the master CLI, this command shouldn't be prefixed, as it will |
| 2074 | set the mode for any worker when connecting to its CLI. |
| 2075 | |
| 2076 | Example: |
Amaury Denoyelle | 76e8b70 | 2022-03-09 15:07:31 +0100 | [diff] [blame] | 2077 | echo "@1; experimental-mode on; <experimental_cmd>..." | socat /var/run/haproxy.master - |
| 2078 | echo "experimental-mode on; @1 <experimental_cmd>..." | socat /var/run/haproxy.master - |
William Lallemand | 7267f78 | 2022-02-01 16:08:50 +0100 | [diff] [blame] | 2079 | |
Willy Tarreau | abb9f9b | 2019-10-24 17:55:53 +0200 | [diff] [blame] | 2080 | expert-mode [on|off] |
Amaury Denoyelle | 18487fb | 2021-03-18 15:32:53 +0100 | [diff] [blame] | 2081 | This command is similar to experimental-mode but is used to toggle the |
| 2082 | expert mode. |
| 2083 | |
| 2084 | The expert mode enables displaying of expert commands that can be extremely |
Willy Tarreau | abb9f9b | 2019-10-24 17:55:53 +0200 | [diff] [blame] | 2085 | dangerous for the process and which may occasionally help developers collect |
| 2086 | important information about complex bugs. Any misuse of these features will |
| 2087 | likely lead to a process crash. Do not use this option without being invited |
| 2088 | to do so. Note that this command is purposely not listed in the help message. |
| 2089 | This command is only accessible in admin level. Changing to another level |
| 2090 | automatically resets the expert mode. |
| 2091 | |
William Lallemand | 7267f78 | 2022-02-01 16:08:50 +0100 | [diff] [blame] | 2092 | When used from the master CLI, this command shouldn't be prefixed, as it will |
| 2093 | set the mode for any worker when connecting to its CLI. |
| 2094 | |
| 2095 | Example: |
| 2096 | echo "@1; expert-mode on; debug dev exit 1" | socat /var/run/haproxy.master - |
| 2097 | echo "expert-mode on; @1 debug dev exit 1" | socat /var/run/haproxy.master - |
| 2098 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2099 | get map <map> <value> |
| 2100 | get acl <acl> <value> |
| 2101 | Lookup the value <value> in the map <map> or in the ACL <acl>. <map> or <acl> |
| 2102 | are the #<id> or the <file> returned by "show map" or "show acl". This command |
| 2103 | returns all the matching patterns associated with this map. This is useful for |
| 2104 | debugging maps and ACLs. The output format is composed by one line par |
| 2105 | matching type. Each line is composed by space-delimited series of words. |
| 2106 | |
| 2107 | The first two words are: |
| 2108 | |
| 2109 | <match method>: The match method applied. It can be "found", "bool", |
| 2110 | "int", "ip", "bin", "len", "str", "beg", "sub", "dir", |
| 2111 | "dom", "end" or "reg". |
| 2112 | |
| 2113 | <match result>: The result. Can be "match" or "no-match". |
| 2114 | |
| 2115 | The following words are returned only if the pattern matches an entry. |
| 2116 | |
| 2117 | <index type>: "tree" or "list". The internal lookup algorithm. |
| 2118 | |
| 2119 | <case>: "case-insensitive" or "case-sensitive". The |
| 2120 | interpretation of the case. |
| 2121 | |
| 2122 | <entry matched>: match="<entry>". Return the matched pattern. It is |
| 2123 | useful with regular expressions. |
| 2124 | |
| 2125 | The two last word are used to show the returned value and its type. With the |
| 2126 | "acl" case, the pattern doesn't exist. |
| 2127 | |
| 2128 | return=nothing: No return because there are no "map". |
| 2129 | return="<value>": The value returned in the string format. |
| 2130 | return=cannot-display: The value cannot be converted as string. |
| 2131 | |
| 2132 | type="<type>": The type of the returned sample. |
| 2133 | |
Willy Tarreau | c35eb38 | 2021-03-26 14:51:31 +0100 | [diff] [blame] | 2134 | get var <name> |
| 2135 | Show the existence, type and contents of the process-wide variable 'name'. |
| 2136 | Only process-wide variables are readable, so the name must begin with |
| 2137 | 'proc.' otherwise no variable will be found. This command requires levels |
| 2138 | "operator" or "admin". |
| 2139 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2140 | get weight <backend>/<server> |
| 2141 | Report the current weight and the initial weight of server <server> in |
| 2142 | backend <backend> or an error if either doesn't exist. The initial weight is |
| 2143 | the one that appears in the configuration file. Both are normally equal |
| 2144 | unless the current weight has been changed. Both the backend and the server |
| 2145 | may be specified either by their name or by their numeric ID, prefixed with a |
| 2146 | sharp ('#'). |
| 2147 | |
Willy Tarreau | 0b1b830 | 2021-05-09 20:59:23 +0200 | [diff] [blame] | 2148 | help [<command>] |
| 2149 | Print the list of known keywords and their basic usage, or commands matching |
| 2150 | the requested one. The same help screen is also displayed for unknown |
| 2151 | commands. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2152 | |
William Lallemand | b175c23 | 2021-10-19 14:53:55 +0200 | [diff] [blame] | 2153 | httpclient <method> <URI> |
| 2154 | Launch an HTTP client request and print the response on the CLI. Only |
| 2155 | supported on a CLI connection running in expert mode (see "expert-mode on"). |
William Lallemand | 9ae05bb | 2022-09-29 15:00:15 +0200 | [diff] [blame] | 2156 | It's only meant for debugging. The httpclient is able to resolve a server |
| 2157 | name in the URL using the "default" resolvers section, which is populated |
| 2158 | with the DNS servers of your /etc/resolv.conf by default. However it won't be |
| 2159 | able to resolve an host from /etc/hosts if you don't use a local dns daemon |
| 2160 | which can resolve those. |
William Lallemand | b175c23 | 2021-10-19 14:53:55 +0200 | [diff] [blame] | 2161 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 2162 | new ssl ca-file <cafile> |
| 2163 | Create a new empty CA file tree entry to be filled with a set of CA |
| 2164 | certificates and added to a crt-list. This command should be used in |
William Lallemand | 62c0b99 | 2022-07-29 17:50:58 +0200 | [diff] [blame] | 2165 | combination with "set ssl ca-file", "add ssl ca-file" and "add ssl crt-list". |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 2166 | |
William Lallemand | accac23 | 2020-04-02 17:42:51 +0200 | [diff] [blame] | 2167 | new ssl cert <filename> |
| 2168 | Create a new empty SSL certificate store to be filled with a certificate and |
| 2169 | added to a directory or a crt-list. This command should be used in |
| 2170 | combination with "set ssl cert" and "add ssl crt-list". |
| 2171 | |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 2172 | new ssl crl-file <crlfile> |
| 2173 | Create a new empty CRL file tree entry to be filled with a set of CRLs |
| 2174 | and added to a crt-list. This command should be used in combination with "set |
| 2175 | ssl crl-file" and "add ssl crt-list". |
| 2176 | |
Willy Tarreau | 97218ce | 2021-04-30 14:57:03 +0200 | [diff] [blame] | 2177 | prepare acl <acl> |
| 2178 | Allocate a new version number in ACL <acl> for atomic replacement. <acl> is |
| 2179 | the #<id> or the <file> returned by "show acl". The new version number is |
| 2180 | shown in response after "New version created:". This number will then be |
| 2181 | usable to prepare additions of new entries into the ACL which will then |
| 2182 | atomically replace the current ones once committed. It is reported as |
| 2183 | "next_ver" in "show acl". There is no impact of allocating new versions, as |
| 2184 | unused versions will automatically be removed once a more recent version is |
| 2185 | committed. Version numbers are unsigned 32-bit values which wrap at the end, |
| 2186 | so care must be taken when comparing them in an external program. This |
| 2187 | command cannot be used if the reference <acl> is a file also used as a map. |
| 2188 | In this case, the "prepare map" command must be used instead. |
| 2189 | |
| 2190 | prepare map <map> |
| 2191 | Allocate a new version number in map <map> for atomic replacement. <map> is |
| 2192 | the #<id> or the <file> returned by "show map". The new version number is |
| 2193 | shown in response after "New version created:". This number will then be |
| 2194 | usable to prepare additions of new entries into the map which will then |
| 2195 | atomically replace the current ones once committed. It is reported as |
| 2196 | "next_ver" in "show map". There is no impact of allocating new versions, as |
| 2197 | unused versions will automatically be removed once a more recent version is |
| 2198 | committed. Version numbers are unsigned 32-bit values which wrap at the end, |
| 2199 | so care must be taken when comparing them in an external program. |
| 2200 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2201 | prompt |
| 2202 | Toggle the prompt at the beginning of the line and enter or leave interactive |
| 2203 | mode. In interactive mode, the connection is not closed after a command |
| 2204 | completes. Instead, the prompt will appear again, indicating the user that |
| 2205 | the interpreter is waiting for a new command. The prompt consists in a right |
| 2206 | angle bracket followed by a space "> ". This mode is particularly convenient |
| 2207 | when one wants to periodically check information such as stats or errors. |
| 2208 | It is also a good idea to enter interactive mode before issuing a "help" |
| 2209 | command. |
| 2210 | |
| 2211 | quit |
| 2212 | Close the connection when in interactive mode. |
| 2213 | |
Erwan Le Goas | 54966df | 2022-09-14 17:24:22 +0200 | [diff] [blame] | 2214 | set anon [on|off] [<key>] |
| 2215 | This command enables or disables the "anonymized mode" for the current CLI |
| 2216 | session, which replaces certain fields considered sensitive or confidential |
| 2217 | in command outputs with hashes that preserve sufficient consistency between |
| 2218 | elements to help developers identify relations between elements when trying |
| 2219 | to spot bugs, but a low enough bit count (24) to make them non-reversible due |
| 2220 | to the high number of possible matches. When turned on, if no key is |
| 2221 | specified, the global key will be used (either specified in the configuration |
Erwan Le Goas | d786931 | 2022-09-29 10:36:11 +0200 | [diff] [blame] | 2222 | file by "anonkey" or set via the CLI command "set anon global-key"). If no such |
Erwan Le Goas | 54966df | 2022-09-14 17:24:22 +0200 | [diff] [blame] | 2223 | key was set, a random one will be generated. Otherwise it's possible to |
| 2224 | specify the 32-bit key to be used for the current session, for example, to |
| 2225 | reuse the key that was used in a previous dump to help compare outputs. |
| 2226 | Developers will never need this key and it's recommended never to share it as |
| 2227 | it could allow to confirm/infirm some guesses about what certain hashes could |
| 2228 | be hiding. |
| 2229 | |
Olivier Houchard | 614f8d7 | 2017-03-14 20:08:46 +0100 | [diff] [blame] | 2230 | set dynamic-cookie-key backend <backend> <value> |
| 2231 | Modify the secret key used to generate the dynamic persistent cookies. |
| 2232 | This will break the existing sessions. |
| 2233 | |
Erwan Le Goas | d786931 | 2022-09-29 10:36:11 +0200 | [diff] [blame] | 2234 | set anon global-key <key> |
Erwan Le Goas | fad9da8 | 2022-09-14 17:24:22 +0200 | [diff] [blame] | 2235 | This sets the global anonymizing key to <key>, which must be a 32-bit |
| 2236 | integer between 0 and 4294967295 (0 disables the global key). This command |
| 2237 | requires admin privilege. |
| 2238 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2239 | set map <map> [<key>|#<ref>] <value> |
| 2240 | Modify the value corresponding to each key <key> in a map <map>. <map> is the |
| 2241 | #<id> or <file> returned by "show map". If the <ref> is used in place of |
| 2242 | <key>, only the entry pointed by <ref> is changed. The new value is <value>. |
| 2243 | |
| 2244 | set maxconn frontend <frontend> <value> |
| 2245 | Dynamically change the specified frontend's maxconn setting. Any positive |
| 2246 | value is allowed including zero, but setting values larger than the global |
| 2247 | maxconn does not make much sense. If the limit is increased and connections |
| 2248 | were pending, they will immediately be accepted. If it is lowered to a value |
| 2249 | below the current number of connections, new connections acceptation will be |
| 2250 | delayed until the threshold is reached. The frontend might be specified by |
| 2251 | either its name or its numeric ID prefixed with a sharp ('#'). |
| 2252 | |
Andrew Hayworth | edb93a7 | 2015-10-27 21:46:25 +0000 | [diff] [blame] | 2253 | set maxconn server <backend/server> <value> |
| 2254 | Dynamically change the specified server's maxconn setting. Any positive |
| 2255 | value is allowed including zero, but setting values larger than the global |
| 2256 | maxconn does not make much sense. |
| 2257 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2258 | set maxconn global <maxconn> |
| 2259 | Dynamically change the global maxconn setting within the range defined by the |
| 2260 | initial global maxconn setting. If it is increased and connections were |
| 2261 | pending, they will immediately be accepted. If it is lowered to a value below |
| 2262 | the current number of connections, new connections acceptation will be |
| 2263 | delayed until the threshold is reached. A value of zero restores the initial |
| 2264 | setting. |
| 2265 | |
Willy Tarreau | 00dd44f | 2021-05-05 16:44:23 +0200 | [diff] [blame] | 2266 | set profiling { tasks | memory } { auto | on | off } |
| 2267 | Enables or disables CPU or memory profiling for the indicated subsystem. This |
| 2268 | is equivalent to setting or clearing the "profiling" settings in the "global" |
Willy Tarreau | cfa7101 | 2021-01-29 11:56:21 +0100 | [diff] [blame] | 2269 | section of the configuration file. Please also see "show profiling". Note |
| 2270 | that manually setting the tasks profiling to "on" automatically resets the |
| 2271 | scheduler statistics, thus allows to check activity over a given interval. |
Willy Tarreau | 00dd44f | 2021-05-05 16:44:23 +0200 | [diff] [blame] | 2272 | The memory profiling is limited to certain operating systems (known to work |
| 2273 | on the linux-glibc target), and requires USE_MEMORY_PROFILING to be set at |
| 2274 | compile time. |
Willy Tarreau | 75c62c2 | 2018-11-22 11:02:09 +0100 | [diff] [blame] | 2275 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2276 | set rate-limit connections global <value> |
| 2277 | Change the process-wide connection rate limit, which is set by the global |
| 2278 | 'maxconnrate' setting. A value of zero disables the limitation. This limit |
| 2279 | applies to all frontends and the change has an immediate effect. The value |
| 2280 | is passed in number of connections per second. |
| 2281 | |
| 2282 | set rate-limit http-compression global <value> |
| 2283 | Change the maximum input compression rate, which is set by the global |
| 2284 | 'maxcomprate' setting. A value of zero disables the limitation. The value is |
| 2285 | passed in number of kilobytes per second. The value is available in the "show |
| 2286 | info" on the line "CompressBpsRateLim" in bytes. |
| 2287 | |
| 2288 | set rate-limit sessions global <value> |
| 2289 | Change the process-wide session rate limit, which is set by the global |
| 2290 | 'maxsessrate' setting. A value of zero disables the limitation. This limit |
| 2291 | applies to all frontends and the change has an immediate effect. The value |
| 2292 | is passed in number of sessions per second. |
| 2293 | |
| 2294 | set rate-limit ssl-sessions global <value> |
| 2295 | Change the process-wide SSL session rate limit, which is set by the global |
| 2296 | 'maxsslrate' setting. A value of zero disables the limitation. This limit |
| 2297 | applies to all frontends and the change has an immediate effect. The value |
| 2298 | is passed in number of sessions per second sent to the SSL stack. It applies |
| 2299 | before the handshake in order to protect the stack against handshake abuses. |
| 2300 | |
Baptiste Assmann | 3749ebf | 2016-08-03 22:34:12 +0200 | [diff] [blame] | 2301 | set server <backend>/<server> addr <ip4 or ip6 address> [port <port>] |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2302 | Replace the current IP address of a server by the one provided. |
Michael Prokop | 4438c60 | 2019-05-24 10:25:45 +0200 | [diff] [blame] | 2303 | Optionally, the port can be changed using the 'port' parameter. |
Baptiste Assmann | 3749ebf | 2016-08-03 22:34:12 +0200 | [diff] [blame] | 2304 | Note that changing the port also support switching from/to port mapping |
| 2305 | (notation with +X or -Y), only if a port is configured for the health check. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2306 | |
| 2307 | set server <backend>/<server> agent [ up | down ] |
| 2308 | Force a server's agent to a new state. This can be useful to immediately |
| 2309 | switch a server's state regardless of some slow agent checks for example. |
| 2310 | Note that the change is propagated to tracking servers if any. |
| 2311 | |
William Dauchy | 7cabc06 | 2021-02-11 22:51:24 +0100 | [diff] [blame] | 2312 | set server <backend>/<server> agent-addr <addr> [port <port>] |
Misiek | 4397290 | 2017-01-09 09:53:06 +0100 | [diff] [blame] | 2313 | Change addr for servers agent checks. Allows to migrate agent-checks to |
| 2314 | another address at runtime. You can specify both IP and hostname, it will be |
| 2315 | resolved. |
William Dauchy | 7cabc06 | 2021-02-11 22:51:24 +0100 | [diff] [blame] | 2316 | Optionally, change the port agent. |
| 2317 | |
| 2318 | set server <backend>/<server> agent-port <port> |
| 2319 | Change the port used for agent checks. |
Misiek | 4397290 | 2017-01-09 09:53:06 +0100 | [diff] [blame] | 2320 | |
| 2321 | set server <backend>/<server> agent-send <value> |
| 2322 | Change agent string sent to agent check target. Allows to update string while |
| 2323 | changing server address to keep those two matching. |
| 2324 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2325 | set server <backend>/<server> health [ up | stopping | down ] |
| 2326 | Force a server's health to a new state. This can be useful to immediately |
| 2327 | switch a server's state regardless of some slow health checks for example. |
| 2328 | Note that the change is propagated to tracking servers if any. |
| 2329 | |
William Dauchy | b456e1f | 2021-02-11 22:51:23 +0100 | [diff] [blame] | 2330 | set server <backend>/<server> check-addr <ip4 | ip6> [port <port>] |
| 2331 | Change the IP address used for server health checks. |
| 2332 | Optionally, change the port used for server health checks. |
| 2333 | |
Baptiste Assmann | 5094656 | 2016-08-31 23:26:29 +0200 | [diff] [blame] | 2334 | set server <backend>/<server> check-port <port> |
| 2335 | Change the port used for health checking to <port> |
| 2336 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2337 | set server <backend>/<server> state [ ready | drain | maint ] |
| 2338 | Force a server's administrative state to a new state. This can be useful to |
| 2339 | disable load balancing and/or any traffic to a server. Setting the state to |
| 2340 | "ready" puts the server in normal mode, and the command is the equivalent of |
| 2341 | the "enable server" command. Setting the state to "maint" disables any traffic |
| 2342 | to the server as well as any health checks. This is the equivalent of the |
| 2343 | "disable server" command. Setting the mode to "drain" only removes the server |
| 2344 | from load balancing but still allows it to be checked and to accept new |
| 2345 | persistent connections. Changes are propagated to tracking servers if any. |
| 2346 | |
| 2347 | set server <backend>/<server> weight <weight>[%] |
| 2348 | Change a server's weight to the value passed in argument. This is the exact |
| 2349 | equivalent of the "set weight" command below. |
| 2350 | |
Frédéric Lécaille | b418c12 | 2017-04-26 11:24:02 +0200 | [diff] [blame] | 2351 | set server <backend>/<server> fqdn <FQDN> |
Lukas Tribus | c5dd5a5 | 2018-08-14 11:39:35 +0200 | [diff] [blame] | 2352 | Change a server's FQDN to the value passed in argument. This requires the |
| 2353 | internal run-time DNS resolver to be configured and enabled for this server. |
Frédéric Lécaille | b418c12 | 2017-04-26 11:24:02 +0200 | [diff] [blame] | 2354 | |
William Lallemand | 9998a33 | 2022-01-19 15:17:08 +0100 | [diff] [blame] | 2355 | set server <backend>/<server> ssl [ on | off ] (deprecated) |
William Dauchy | f637044 | 2020-11-14 19:25:33 +0100 | [diff] [blame] | 2356 | This option configures SSL ciphering on outgoing connections to the server. |
William Dauchy | a087f87 | 2022-01-06 16:57:15 +0100 | [diff] [blame] | 2357 | When switch off, all traffic becomes plain text; health check path is not |
| 2358 | changed. |
William Dauchy | f637044 | 2020-11-14 19:25:33 +0100 | [diff] [blame] | 2359 | |
William Lallemand | 9998a33 | 2022-01-19 15:17:08 +0100 | [diff] [blame] | 2360 | This command is deprecated, create a new server dynamically with or without |
| 2361 | SSL instead, using the "add server" command. |
| 2362 | |
Andjelko Iharos | c4df59e | 2017-07-20 11:59:48 +0200 | [diff] [blame] | 2363 | set severity-output [ none | number | string ] |
| 2364 | Change the severity output format of the stats socket connected to for the |
| 2365 | duration of the current session. |
| 2366 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 2367 | set ssl ca-file <cafile> <payload> |
William Lallemand | 62c0b99 | 2022-07-29 17:50:58 +0200 | [diff] [blame] | 2368 | this command is part of a transaction system, the "commit ssl ca-file" and |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 2369 | "abort ssl ca-file" commands could be required. |
William Lallemand | 62c0b99 | 2022-07-29 17:50:58 +0200 | [diff] [blame] | 2370 | if there is no on-going transaction, it will create a ca file tree entry into |
| 2371 | which the certificates contained in the payload will be stored. the ca file |
| 2372 | entry will not be stored in the ca file tree and will only be kept in a |
| 2373 | temporary transaction. if a transaction with the same filename already exists, |
| 2374 | the previous ca file entry will be deleted and replaced by the new one. |
| 2375 | once the modifications are done, you have to commit the transaction through |
| 2376 | a "commit ssl ca-file" call. If you want to add multiple certificates |
| 2377 | separately, you can use the "add ssl ca-file" command |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 2378 | |
| 2379 | Example: |
| 2380 | echo -e "set ssl ca-file cafile.pem <<\n$(cat rootCA.crt)\n" | \ |
| 2381 | socat /var/run/haproxy.stat - |
| 2382 | echo "commit ssl ca-file cafile.pem" | socat /var/run/haproxy.stat - |
| 2383 | |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 2384 | set ssl cert <filename> <payload> |
| 2385 | This command is part of a transaction system, the "commit ssl cert" and |
| 2386 | "abort ssl cert" commands could be required. |
Remi Tricot-Le Breton | 3445909 | 2021-04-14 16:19:28 +0200 | [diff] [blame] | 2387 | This whole transaction system works on any certificate displayed by the |
Remi Tricot-Le Breton | b5f0fac | 2021-04-14 16:19:29 +0200 | [diff] [blame] | 2388 | "show ssl cert" command, so on any frontend or backend certificate. |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 2389 | If there is no on-going transaction, it will duplicate the certificate |
| 2390 | <filename> in memory to a temporary transaction, then update this |
| 2391 | transaction with the PEM file in the payload. If a transaction exists with |
| 2392 | the same filename, it will update this transaction. It's also possible to |
| 2393 | update the files linked to a certificate (.issuer, .sctl, .oscp etc.) |
| 2394 | Once the modification are done, you have to "commit ssl cert" the |
| 2395 | transaction. |
| 2396 | |
William Lallemand | ed8bfad | 2021-09-16 17:30:51 +0200 | [diff] [blame] | 2397 | Injection of files over the CLI must be done with caution since an empty line |
| 2398 | is used to notify the end of the payload. It is recommended to inject a PEM |
| 2399 | file which has been sanitized. A simple method would be to remove every empty |
| 2400 | line and only leave what are in the PEM sections. It could be achieved with a |
| 2401 | sed command. |
| 2402 | |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 2403 | Example: |
William Lallemand | ed8bfad | 2021-09-16 17:30:51 +0200 | [diff] [blame] | 2404 | |
| 2405 | # With some simple sanitizing |
| 2406 | echo -e "set ssl cert localhost.pem <<\n$(sed -n '/^$/d;/-BEGIN/,/-END/p' 127.0.0.1.pem)\n" | \ |
| 2407 | socat /var/run/haproxy.stat - |
| 2408 | |
| 2409 | # Complete example with commit |
William Lallemand | 6ab08b3 | 2019-11-29 16:48:43 +0100 | [diff] [blame] | 2410 | echo -e "set ssl cert localhost.pem <<\n$(cat 127.0.0.1.pem)\n" | \ |
| 2411 | socat /var/run/haproxy.stat - |
| 2412 | echo -e \ |
| 2413 | "set ssl cert localhost.pem.issuer <<\n $(cat 127.0.0.1.pem.issuer)\n" | \ |
| 2414 | socat /var/run/haproxy.stat - |
| 2415 | echo -e \ |
| 2416 | "set ssl cert localhost.pem.ocsp <<\n$(base64 -w 1000 127.0.0.1.pem.ocsp)\n" | \ |
| 2417 | socat /var/run/haproxy.stat - |
| 2418 | echo "commit ssl cert localhost.pem" | socat /var/run/haproxy.stat - |
| 2419 | |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 2420 | set ssl crl-file <crlfile> <payload> |
| 2421 | This command is part of a transaction system, the "commit ssl crl-file" and |
| 2422 | "abort ssl crl-file" commands could be required. |
| 2423 | If there is no on-going transaction, it will create a CRL file tree entry into |
| 2424 | which the Revocation Lists contained in the payload will be stored. The CRL |
| 2425 | file entry will not be stored in the CRL file tree and will only be kept in a |
| 2426 | temporary transaction. If a transaction with the same filename already exists, |
| 2427 | the previous CRL file entry will be deleted and replaced by the new one. |
| 2428 | Once the modifications are done, you have to commit the transaction through |
| 2429 | a "commit ssl crl-file" call. |
| 2430 | |
| 2431 | Example: |
| 2432 | echo -e "set ssl crl-file crlfile.pem <<\n$(cat rootCRL.pem)\n" | \ |
| 2433 | socat /var/run/haproxy.stat - |
| 2434 | echo "commit ssl crl-file crlfile.pem" | socat /var/run/haproxy.stat - |
| 2435 | |
Aurélien Nephtali | 1e0867c | 2018-04-18 14:04:58 +0200 | [diff] [blame] | 2436 | set ssl ocsp-response <response | payload> |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2437 | This command is used to update an OCSP Response for a certificate (see "crt" |
| 2438 | on "bind" lines). Same controls are performed as during the initial loading of |
| 2439 | the response. The <response> must be passed as a base64 encoded string of the |
Emmanuel Hocdet | 2c32d8f | 2017-05-22 14:58:00 +0200 | [diff] [blame] | 2440 | DER encoded response from the OCSP server. This command is not supported with |
| 2441 | BoringSSL. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2442 | |
| 2443 | Example: |
| 2444 | openssl ocsp -issuer issuer.pem -cert server.pem \ |
| 2445 | -host ocsp.issuer.com:80 -respout resp.der |
| 2446 | echo "set ssl ocsp-response $(base64 -w 10000 resp.der)" | \ |
| 2447 | socat stdio /var/run/haproxy.stat |
| 2448 | |
Aurélien Nephtali | 1e0867c | 2018-04-18 14:04:58 +0200 | [diff] [blame] | 2449 | using the payload syntax: |
| 2450 | echo -e "set ssl ocsp-response <<\n$(base64 resp.der)\n" | \ |
| 2451 | socat stdio /var/run/haproxy.stat |
| 2452 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2453 | set ssl tls-key <id> <tlskey> |
| 2454 | Set the next TLS key for the <id> listener to <tlskey>. This key becomes the |
| 2455 | ultimate key, while the penultimate one is used for encryption (others just |
| 2456 | decrypt). The oldest TLS key present is overwritten. <id> is either a numeric |
| 2457 | #<id> or <file> returned by "show tls-keys". <tlskey> is a base64 encoded 48 |
Emeric Brun | 9e75477 | 2019-01-10 17:51:55 +0100 | [diff] [blame] | 2458 | or 80 bits TLS ticket key (ex. openssl rand 80 | openssl base64 -A). |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2459 | |
| 2460 | set table <table> key <key> [data.<data_type> <value>]* |
| 2461 | Create or update a stick-table entry in the table. If the key is not present, |
| 2462 | an entry is inserted. See stick-table in section 4.2 to find all possible |
| 2463 | values for <data_type>. The most likely use consists in dynamically entering |
| 2464 | entries for source IP addresses, with a flag in gpc0 to dynamically block an |
| 2465 | IP address or affect its quality of service. It is possible to pass multiple |
| 2466 | data_types in a single call. |
| 2467 | |
| 2468 | set timeout cli <delay> |
| 2469 | Change the CLI interface timeout for current connection. This can be useful |
| 2470 | during long debugging sessions where the user needs to constantly inspect |
| 2471 | some indicators without being disconnected. The delay is passed in seconds. |
| 2472 | |
Willy Tarreau | 4000ff0 | 2021-04-30 14:45:53 +0200 | [diff] [blame] | 2473 | set var <name> <expression> |
Willy Tarreau | e93bff4 | 2021-09-03 09:47:37 +0200 | [diff] [blame] | 2474 | set var <name> expr <expression> |
| 2475 | set var <name> fmt <format> |
Willy Tarreau | 4000ff0 | 2021-04-30 14:45:53 +0200 | [diff] [blame] | 2476 | Allows to set or overwrite the process-wide variable 'name' with the result |
Willy Tarreau | e93bff4 | 2021-09-03 09:47:37 +0200 | [diff] [blame] | 2477 | of expression <expression> or format string <format>. Only process-wide |
| 2478 | variables may be used, so the name must begin with 'proc.' otherwise no |
| 2479 | variable will be set. The <expression> and <format> may only involve |
| 2480 | "internal" sample fetch keywords and converters even though the most likely |
| 2481 | useful ones will be str('something'), int(), simple strings or references to |
| 2482 | other variables. Note that the command line parser doesn't know about quotes, |
| 2483 | so any space in the expression must be preceded by a backslash. This command |
| 2484 | requires levels "operator" or "admin". This command is only supported on a |
| 2485 | CLI connection running in experimental mode (see "experimental-mode on"). |
Willy Tarreau | 4000ff0 | 2021-04-30 14:45:53 +0200 | [diff] [blame] | 2486 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2487 | set weight <backend>/<server> <weight>[%] |
| 2488 | Change a server's weight to the value passed in argument. If the value ends |
| 2489 | with the '%' sign, then the new weight will be relative to the initially |
| 2490 | configured weight. Absolute weights are permitted between 0 and 256. |
| 2491 | Relative weights must be positive with the resulting absolute weight is |
| 2492 | capped at 256. Servers which are part of a farm running a static |
| 2493 | load-balancing algorithm have stricter limitations because the weight |
| 2494 | cannot change once set. Thus for these servers, the only accepted values |
| 2495 | are 0 and 100% (or 0 and the initial weight). Changes take effect |
| 2496 | immediately, though certain LB algorithms require a certain amount of |
| 2497 | requests to consider changes. A typical usage of this command is to |
| 2498 | disable a server during an update by setting its weight to zero, then to |
| 2499 | enable it again after the update by setting it back to 100%. This command |
| 2500 | is restricted and can only be issued on sockets configured for level |
| 2501 | "admin". Both the backend and the server may be specified either by their |
| 2502 | name or by their numeric ID, prefixed with a sharp ('#'). |
| 2503 | |
Willy Tarreau | 95f753e | 2021-04-30 12:09:54 +0200 | [diff] [blame] | 2504 | show acl [[@<ver>] <acl>] |
Willy Tarreau | d6129fc | 2017-07-28 16:52:23 +0200 | [diff] [blame] | 2505 | Dump info about acl converters. Without argument, the list of all available |
Willy Tarreau | 95f753e | 2021-04-30 12:09:54 +0200 | [diff] [blame] | 2506 | acls is returned. If a <acl> is specified, its contents are dumped. <acl> is |
| 2507 | the #<id> or <file>. By default the current version of the ACL is shown (the |
| 2508 | version currently being matched against and reported as 'curr_ver' in the ACL |
| 2509 | list). It is possible to instead dump other versions by prepending '@<ver>' |
| 2510 | before the ACL's identifier. The version works as a filter and non-existing |
| 2511 | versions will simply report no result. The dump format is the same as for the |
| 2512 | maps even for the sample values. The data returned are not a list of |
| 2513 | available ACL, but are the list of all patterns composing any ACL. Many of |
Dragan Dosen | a75eea7 | 2021-05-21 16:59:15 +0200 | [diff] [blame] | 2514 | these patterns can be shared with maps. The 'entry_cnt' value represents the |
| 2515 | count of all the ACL entries, not just the active ones, which means that it |
| 2516 | also includes entries currently being added. |
Willy Tarreau | d6129fc | 2017-07-28 16:52:23 +0200 | [diff] [blame] | 2517 | |
Erwan Le Goas | 54966df | 2022-09-14 17:24:22 +0200 | [diff] [blame] | 2518 | show anon |
| 2519 | Display the current state of the anonymized mode (enabled or disabled) and |
| 2520 | the current session's key. |
| 2521 | |
Willy Tarreau | d6129fc | 2017-07-28 16:52:23 +0200 | [diff] [blame] | 2522 | show backend |
| 2523 | Dump the list of backends available in the running process |
| 2524 | |
William Lallemand | 67a234f | 2018-12-13 09:05:45 +0100 | [diff] [blame] | 2525 | show cli level |
| 2526 | Display the CLI level of the current CLI session. The result could be |
| 2527 | 'admin', 'operator' or 'user'. See also the 'operator' and 'user' commands. |
| 2528 | |
| 2529 | Example : |
| 2530 | |
| 2531 | $ socat /tmp/sock1 readline |
| 2532 | prompt |
| 2533 | > operator |
| 2534 | > show cli level |
| 2535 | operator |
| 2536 | > user |
| 2537 | > show cli level |
| 2538 | user |
| 2539 | > operator |
| 2540 | Permission denied |
| 2541 | |
| 2542 | operator |
| 2543 | Decrease the CLI level of the current CLI session to operator. It can't be |
Amaury Denoyelle | 18487fb | 2021-03-18 15:32:53 +0100 | [diff] [blame] | 2544 | increased. It also drops expert and experimental mode. See also "show cli |
| 2545 | level". |
William Lallemand | 67a234f | 2018-12-13 09:05:45 +0100 | [diff] [blame] | 2546 | |
| 2547 | user |
| 2548 | Decrease the CLI level of the current CLI session to user. It can't be |
Amaury Denoyelle | 18487fb | 2021-03-18 15:32:53 +0100 | [diff] [blame] | 2549 | increased. It also drops expert and experimental mode. See also "show cli |
| 2550 | level". |
William Lallemand | 67a234f | 2018-12-13 09:05:45 +0100 | [diff] [blame] | 2551 | |
Willy Tarreau | 9a7fa90 | 2022-07-15 16:51:16 +0200 | [diff] [blame] | 2552 | show activity [-1 | 0 | thread_num] |
Willy Tarreau | 4c35693 | 2019-05-16 17:39:32 +0200 | [diff] [blame] | 2553 | Reports some counters about internal events that will help developers and |
| 2554 | more generally people who know haproxy well enough to narrow down the causes |
| 2555 | of reports of abnormal behaviours. A typical example would be a properly |
| 2556 | running process never sleeping and eating 100% of the CPU. The output fields |
| 2557 | will be made of one line per metric, and per-thread counters on the same |
Thayne McCombs | cdbcca9 | 2021-01-07 21:24:41 -0700 | [diff] [blame] | 2558 | line. These counters are 32-bit and will wrap during the process's life, which |
Willy Tarreau | 4c35693 | 2019-05-16 17:39:32 +0200 | [diff] [blame] | 2559 | is not a problem since calls to this command will typically be performed |
| 2560 | twice. The fields are purposely not documented so that their exact meaning is |
| 2561 | verified in the code where the counters are fed. These values are also reset |
Willy Tarreau | 9a7fa90 | 2022-07-15 16:51:16 +0200 | [diff] [blame] | 2562 | by the "clear counters" command. On multi-threaded deployments, the first |
| 2563 | column will indicate the total (or average depending on the nature of the |
| 2564 | metric) for all threads, and the list of all threads' values will be |
| 2565 | represented between square brackets in the thread order. Optionally the |
| 2566 | thread number to be dumped may be specified in argument. The special value |
| 2567 | "0" will report the aggregated value (first column), and "-1", which is the |
| 2568 | default, will display all the columns. Note that just like in single-threaded |
| 2569 | mode, there will be no brackets when a single column is requested. |
Willy Tarreau | 4c35693 | 2019-05-16 17:39:32 +0200 | [diff] [blame] | 2570 | |
William Lallemand | 5113216 | 2016-12-16 16:38:58 +0100 | [diff] [blame] | 2571 | show cli sockets |
| 2572 | List CLI sockets. The output format is composed of 3 fields separated by |
| 2573 | spaces. The first field is the socket address, it can be a unix socket, a |
| 2574 | ipv4 address:port couple or a ipv6 one. Socket of other types won't be dump. |
| 2575 | The second field describe the level of the socket: 'admin', 'user' or |
| 2576 | 'operator'. The last field list the processes on which the socket is bound, |
| 2577 | separated by commas, it can be numbers or 'all'. |
| 2578 | |
| 2579 | Example : |
| 2580 | |
| 2581 | $ echo 'show cli sockets' | socat stdio /tmp/sock1 |
| 2582 | # socket lvl processes |
| 2583 | /tmp/sock1 admin all |
| 2584 | 127.0.0.1:9999 user 2,3,4 |
| 2585 | 127.0.0.2:9969 user 2 |
| 2586 | [::1]:9999 operator 2 |
| 2587 | |
William Lallemand | 86d0df0 | 2017-11-24 21:36:45 +0100 | [diff] [blame] | 2588 | show cache |
Cyril Bonté | 7b888f1 | 2017-11-26 22:24:31 +0100 | [diff] [blame] | 2589 | List the configured caches and the objects stored in each cache tree. |
William Lallemand | 86d0df0 | 2017-11-24 21:36:45 +0100 | [diff] [blame] | 2590 | |
| 2591 | $ echo 'show cache' | socat stdio /tmp/sock1 |
| 2592 | 0x7f6ac6c5b03a: foobar (shctx:0x7f6ac6c5b000, available blocks:3918) |
| 2593 | 1 2 3 4 |
| 2594 | |
| 2595 | 1. pointer to the cache structure |
| 2596 | 2. cache name |
| 2597 | 3. pointer to the mmap area (shctx) |
| 2598 | 4. number of blocks available for reuse in the shctx |
| 2599 | |
Remi Tricot-Le Breton | e3e1e5f | 2020-11-27 15:48:40 +0100 | [diff] [blame] | 2600 | 0x7f6ac6c5b4cc hash:286881868 vary:0x0011223344556677 size:39114 (39 blocks), refcount:9, expire:237 |
| 2601 | 1 2 3 4 5 6 7 |
William Lallemand | 86d0df0 | 2017-11-24 21:36:45 +0100 | [diff] [blame] | 2602 | |
| 2603 | 1. pointer to the cache entry |
| 2604 | 2. first 32 bits of the hash |
Remi Tricot-Le Breton | e3e1e5f | 2020-11-27 15:48:40 +0100 | [diff] [blame] | 2605 | 3. secondary hash of the entry in case of vary |
| 2606 | 4. size of the object in bytes |
| 2607 | 5. number of blocks used for the object |
| 2608 | 6. number of transactions using the entry |
| 2609 | 7. expiration time, can be negative if already expired |
William Lallemand | 86d0df0 | 2017-11-24 21:36:45 +0100 | [diff] [blame] | 2610 | |
Willy Tarreau | ae79572 | 2016-02-16 11:27:28 +0100 | [diff] [blame] | 2611 | show env [<name>] |
| 2612 | Dump one or all environment variables known by the process. Without any |
| 2613 | argument, all variables are dumped. With an argument, only the specified |
| 2614 | variable is dumped if it exists. Otherwise "Variable not found" is emitted. |
| 2615 | Variables are dumped in the same format as they are stored or returned by the |
| 2616 | "env" utility, that is, "<name>=<value>". This can be handy when debugging |
| 2617 | certain configuration files making heavy use of environment variables to |
| 2618 | ensure that they contain the expected values. This command is restricted and |
| 2619 | can only be issued on sockets configured for levels "operator" or "admin". |
| 2620 | |
Willy Tarreau | 35069f8 | 2016-11-25 09:16:37 +0100 | [diff] [blame] | 2621 | show errors [<iid>|<proxy>] [request|response] |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2622 | Dump last known request and response errors collected by frontends and |
| 2623 | backends. If <iid> is specified, the limit the dump to errors concerning |
Willy Tarreau | 234ba2d | 2016-11-25 08:39:10 +0100 | [diff] [blame] | 2624 | either frontend or backend whose ID is <iid>. Proxy ID "-1" will cause |
| 2625 | all instances to be dumped. If a proxy name is specified instead, its ID |
Willy Tarreau | 35069f8 | 2016-11-25 09:16:37 +0100 | [diff] [blame] | 2626 | will be used as the filter. If "request" or "response" is added after the |
| 2627 | proxy name or ID, only request or response errors will be dumped. This |
| 2628 | command is restricted and can only be issued on sockets configured for |
| 2629 | levels "operator" or "admin". |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2630 | |
| 2631 | The errors which may be collected are the last request and response errors |
| 2632 | caused by protocol violations, often due to invalid characters in header |
| 2633 | names. The report precisely indicates what exact character violated the |
| 2634 | protocol. Other important information such as the exact date the error was |
| 2635 | detected, frontend and backend names, the server name (when known), the |
| 2636 | internal session ID and the source address which has initiated the session |
| 2637 | are reported too. |
| 2638 | |
| 2639 | All characters are returned, and non-printable characters are encoded. The |
| 2640 | most common ones (\t = 9, \n = 10, \r = 13 and \e = 27) are encoded as one |
| 2641 | letter following a backslash. The backslash itself is encoded as '\\' to |
| 2642 | avoid confusion. Other non-printable characters are encoded '\xNN' where |
| 2643 | NN is the two-digits hexadecimal representation of the character's ASCII |
| 2644 | code. |
| 2645 | |
| 2646 | Lines are prefixed with the position of their first character, starting at 0 |
| 2647 | for the beginning of the buffer. At most one input line is printed per line, |
| 2648 | and large lines will be broken into multiple consecutive output lines so that |
| 2649 | the output never goes beyond 79 characters wide. It is easy to detect if a |
| 2650 | line was broken, because it will not end with '\n' and the next line's offset |
| 2651 | will be followed by a '+' sign, indicating it is a continuation of previous |
| 2652 | line. |
| 2653 | |
| 2654 | Example : |
Willy Tarreau | 35069f8 | 2016-11-25 09:16:37 +0100 | [diff] [blame] | 2655 | $ echo "show errors -1 response" | socat stdio /tmp/sock1 |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2656 | >>> [04/Mar/2009:15:46:56.081] backend http-in (#2) : invalid response |
| 2657 | src 127.0.0.1, session #54, frontend fe-eth0 (#1), server s2 (#1) |
| 2658 | response length 213 bytes, error at position 23: |
| 2659 | |
| 2660 | 00000 HTTP/1.0 200 OK\r\n |
| 2661 | 00017 header/bizarre:blah\r\n |
| 2662 | 00038 Location: blah\r\n |
| 2663 | 00054 Long-line: this is a very long line which should b |
| 2664 | 00104+ e broken into multiple lines on the output buffer, |
| 2665 | 00154+ otherwise it would be too large to print in a ter |
| 2666 | 00204+ minal\r\n |
| 2667 | 00211 \r\n |
| 2668 | |
| 2669 | In the example above, we see that the backend "http-in" which has internal |
| 2670 | ID 2 has blocked an invalid response from its server s2 which has internal |
| 2671 | ID 1. The request was on session 54 initiated by source 127.0.0.1 and |
| 2672 | received by frontend fe-eth0 whose ID is 1. The total response length was |
| 2673 | 213 bytes when the error was detected, and the error was at byte 23. This |
| 2674 | is the slash ('/') in header name "header/bizarre", which is not a valid |
| 2675 | HTTP character for a header name. |
| 2676 | |
Willy Tarreau | 1d181e4 | 2019-08-30 11:17:01 +0200 | [diff] [blame] | 2677 | show events [<sink>] [-w] [-n] |
Willy Tarreau | 9f830d7 | 2019-08-26 18:17:04 +0200 | [diff] [blame] | 2678 | With no option, this lists all known event sinks and their types. With an |
| 2679 | option, it will dump all available events in the designated sink if it is of |
Willy Tarreau | 1d181e4 | 2019-08-30 11:17:01 +0200 | [diff] [blame] | 2680 | type buffer. If option "-w" is passed after the sink name, then once the end |
| 2681 | of the buffer is reached, the command will wait for new events and display |
| 2682 | them. It is possible to stop the operation by entering any input (which will |
| 2683 | be discarded) or by closing the session. Finally, option "-n" is used to |
| 2684 | directly seek to the end of the buffer, which is often convenient when |
| 2685 | combined with "-w" to only report new events. For convenience, "-wn" or "-nw" |
| 2686 | may be used to enable both options at once. |
Willy Tarreau | 9f830d7 | 2019-08-26 18:17:04 +0200 | [diff] [blame] | 2687 | |
Willy Tarreau | 7a4a0ac | 2017-07-25 19:32:50 +0200 | [diff] [blame] | 2688 | show fd [<fd>] |
| 2689 | Dump the list of either all open file descriptors or just the one number <fd> |
| 2690 | if specified. This is only aimed at developers who need to observe internal |
| 2691 | states in order to debug complex issues such as abnormal CPU usages. One fd |
| 2692 | is reported per lines, and for each of them, its state in the poller using |
| 2693 | upper case letters for enabled flags and lower case for disabled flags, using |
| 2694 | "P" for "polled", "R" for "ready", "A" for "active", the events status using |
| 2695 | "H" for "hangup", "E" for "error", "O" for "output", "P" for "priority" and |
| 2696 | "I" for "input", a few other flags like "N" for "new" (just added into the fd |
| 2697 | cache), "U" for "updated" (received an update in the fd cache), "L" for |
| 2698 | "linger_risk", "C" for "cloned", then the cached entry position, the pointer |
| 2699 | to the internal owner, the pointer to the I/O callback and its name when |
| 2700 | known. When the owner is a connection, the connection flags, and the target |
| 2701 | are reported (frontend, proxy or server). When the owner is a listener, the |
| 2702 | listener's state and its frontend are reported. There is no point in using |
| 2703 | this command without a good knowledge of the internals. It's worth noting |
| 2704 | that the output format may evolve over time so this output must not be parsed |
Willy Tarreau | 8050efe | 2021-01-21 08:26:06 +0100 | [diff] [blame] | 2705 | by tools designed to be durable. Some internal structure states may look |
| 2706 | suspicious to the function listing them, in this case the output line will be |
| 2707 | suffixed with an exclamation mark ('!'). This may help find a starting point |
| 2708 | when trying to diagnose an incident. |
Willy Tarreau | 7a4a0ac | 2017-07-25 19:32:50 +0200 | [diff] [blame] | 2709 | |
Willy Tarreau | 2745620 | 2021-05-08 07:54:24 +0200 | [diff] [blame] | 2710 | show info [typed|json] [desc] [float] |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 2711 | Dump info about haproxy status on current process. If "typed" is passed as an |
| 2712 | optional argument, field numbers, names and types are emitted as well so that |
| 2713 | external monitoring products can easily retrieve, possibly aggregate, then |
| 2714 | report information found in fields they don't know. Each field is dumped on |
Simon Horman | 05ee213 | 2017-01-04 09:37:25 +0100 | [diff] [blame] | 2715 | its own line. If "json" is passed as an optional argument then |
| 2716 | information provided by "typed" output is provided in JSON format as a |
| 2717 | list of JSON objects. By default, the format contains only two columns |
| 2718 | delimited by a colon (':'). The left one is the field name and the right |
| 2719 | one is the value. It is very important to note that in typed output |
| 2720 | format, the dump for a single object is contiguous so that there is no |
Willy Tarreau | 2745620 | 2021-05-08 07:54:24 +0200 | [diff] [blame] | 2721 | need for a consumer to store everything at once. If "float" is passed as an |
| 2722 | optional argument, some fields usually emitted as integers may switch to |
| 2723 | floats for higher accuracy. It is purposely unspecified which ones are |
| 2724 | concerned as this might evolve over time. Using this option implies that the |
| 2725 | consumer is able to process floats. The output format used is sprintf("%f"). |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 2726 | |
| 2727 | When using the typed output format, each line is made of 4 columns delimited |
| 2728 | by colons (':'). The first column is a dot-delimited series of 3 elements. The |
| 2729 | first element is the numeric position of the field in the list (starting at |
| 2730 | zero). This position shall not change over time, but holes are to be expected, |
| 2731 | depending on build options or if some fields are deleted in the future. The |
| 2732 | second element is the field name as it appears in the default "show info" |
| 2733 | output. The third element is the relative process number starting at 1. |
| 2734 | |
| 2735 | The rest of the line starting after the first colon follows the "typed output |
| 2736 | format" described in the section above. In short, the second column (after the |
| 2737 | first ':') indicates the origin, nature and scope of the variable. The third |
| 2738 | column indicates the type of the field, among "s32", "s64", "u32", "u64" and |
| 2739 | "str". Then the fourth column is the value itself, which the consumer knows |
| 2740 | how to parse thanks to column 3 and how to process thanks to column 2. |
| 2741 | |
| 2742 | Thus the overall line format in typed mode is : |
| 2743 | |
| 2744 | <field_pos>.<field_name>.<process_num>:<tags>:<type>:<value> |
| 2745 | |
Willy Tarreau | 6b19b14 | 2019-10-09 15:44:21 +0200 | [diff] [blame] | 2746 | When "desc" is appended to the command, one extra colon followed by a quoted |
| 2747 | string is appended with a description for the metric. At the time of writing, |
| 2748 | this is only supported for the "typed" and default output formats. |
| 2749 | |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 2750 | Example : |
| 2751 | |
| 2752 | > show info |
| 2753 | Name: HAProxy |
| 2754 | Version: 1.7-dev1-de52ea-146 |
| 2755 | Release_date: 2016/03/11 |
| 2756 | Nbproc: 1 |
| 2757 | Process_num: 1 |
| 2758 | Pid: 28105 |
| 2759 | Uptime: 0d 0h00m04s |
| 2760 | Uptime_sec: 4 |
| 2761 | Memmax_MB: 0 |
| 2762 | PoolAlloc_MB: 0 |
| 2763 | PoolUsed_MB: 0 |
| 2764 | PoolFailed: 0 |
| 2765 | (...) |
| 2766 | |
| 2767 | > show info typed |
| 2768 | 0.Name.1:POS:str:HAProxy |
| 2769 | 1.Version.1:POS:str:1.7-dev1-de52ea-146 |
| 2770 | 2.Release_date.1:POS:str:2016/03/11 |
| 2771 | 3.Nbproc.1:CGS:u32:1 |
| 2772 | 4.Process_num.1:KGP:u32:1 |
| 2773 | 5.Pid.1:SGP:u32:28105 |
| 2774 | 6.Uptime.1:MDP:str:0d 0h00m08s |
| 2775 | 7.Uptime_sec.1:MDP:u32:8 |
| 2776 | 8.Memmax_MB.1:CLP:u32:0 |
| 2777 | 9.PoolAlloc_MB.1:MGP:u32:0 |
| 2778 | 10.PoolUsed_MB.1:MGP:u32:0 |
| 2779 | 11.PoolFailed.1:MCP:u32:0 |
| 2780 | (...) |
| 2781 | |
Simon Horman | 1084a36 | 2016-11-21 17:00:24 +0100 | [diff] [blame] | 2782 | In the typed format, the presence of the process ID at the end of the |
| 2783 | first column makes it very easy to visually aggregate outputs from |
| 2784 | multiple processes. |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 2785 | Example : |
| 2786 | |
| 2787 | $ ( echo show info typed | socat /var/run/haproxy.sock1 ; \ |
| 2788 | echo show info typed | socat /var/run/haproxy.sock2 ) | \ |
| 2789 | sort -t . -k 1,1n -k 2,2 -k 3,3n |
| 2790 | 0.Name.1:POS:str:HAProxy |
| 2791 | 0.Name.2:POS:str:HAProxy |
| 2792 | 1.Version.1:POS:str:1.7-dev1-868ab3-148 |
| 2793 | 1.Version.2:POS:str:1.7-dev1-868ab3-148 |
| 2794 | 2.Release_date.1:POS:str:2016/03/11 |
| 2795 | 2.Release_date.2:POS:str:2016/03/11 |
| 2796 | 3.Nbproc.1:CGS:u32:2 |
| 2797 | 3.Nbproc.2:CGS:u32:2 |
| 2798 | 4.Process_num.1:KGP:u32:1 |
| 2799 | 4.Process_num.2:KGP:u32:2 |
| 2800 | 5.Pid.1:SGP:u32:30120 |
| 2801 | 5.Pid.2:SGP:u32:30121 |
| 2802 | 6.Uptime.1:MDP:str:0d 0h01m28s |
| 2803 | 6.Uptime.2:MDP:str:0d 0h01m28s |
| 2804 | (...) |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2805 | |
Simon Horman | 05ee213 | 2017-01-04 09:37:25 +0100 | [diff] [blame] | 2806 | The format of JSON output is described in a schema which may be output |
Simon Horman | 6f6bb38 | 2017-01-04 09:37:26 +0100 | [diff] [blame] | 2807 | using "show schema json". |
Simon Horman | 05ee213 | 2017-01-04 09:37:25 +0100 | [diff] [blame] | 2808 | |
| 2809 | The JSON output contains no extra whitespace in order to reduce the |
| 2810 | volume of output. For human consumption passing the output through a |
| 2811 | pretty printer may be helpful. Example : |
| 2812 | |
| 2813 | $ echo "show info json" | socat /var/run/haproxy.sock stdio | \ |
| 2814 | python -m json.tool |
| 2815 | |
Simon Horman | 6f6bb38 | 2017-01-04 09:37:26 +0100 | [diff] [blame] | 2816 | The JSON output contains no extra whitespace in order to reduce the |
| 2817 | volume of output. For human consumption passing the output through a |
| 2818 | pretty printer may be helpful. Example : |
| 2819 | |
| 2820 | $ echo "show info json" | socat /var/run/haproxy.sock stdio | \ |
| 2821 | python -m json.tool |
| 2822 | |
Willy Tarreau | 6ab7b21 | 2021-12-28 09:57:10 +0100 | [diff] [blame] | 2823 | show libs |
| 2824 | Dump the list of loaded shared dynamic libraries and object files, on systems |
| 2825 | that support it. When available, for each shared object the range of virtual |
| 2826 | addresses will be indicated, the size and the path to the object. This can be |
| 2827 | used for example to try to estimate what library provides a function that |
| 2828 | appears in a dump. Note that on many systems, addresses will change upon each |
| 2829 | restart (address space randomization), so that this list would need to be |
| 2830 | retrieved upon startup if it is expected to be used to analyse a core file. |
| 2831 | This command may only be issued on sockets configured for levels "operator" |
| 2832 | or "admin". Note that the output format may vary between operating systems, |
| 2833 | architectures and even haproxy versions, and ought not to be relied on in |
| 2834 | scripts. |
| 2835 | |
Willy Tarreau | 95f753e | 2021-04-30 12:09:54 +0200 | [diff] [blame] | 2836 | show map [[@<ver>] <map>] |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2837 | Dump info about map converters. Without argument, the list of all available |
| 2838 | maps is returned. If a <map> is specified, its contents are dumped. <map> is |
Willy Tarreau | 95f753e | 2021-04-30 12:09:54 +0200 | [diff] [blame] | 2839 | the #<id> or <file>. By default the current version of the map is shown (the |
| 2840 | version currently being matched against and reported as 'curr_ver' in the map |
| 2841 | list). It is possible to instead dump other versions by prepending '@<ver>' |
| 2842 | before the map's identifier. The version works as a filter and non-existing |
Dragan Dosen | a75eea7 | 2021-05-21 16:59:15 +0200 | [diff] [blame] | 2843 | versions will simply report no result. The 'entry_cnt' value represents the |
| 2844 | count of all the map entries, not just the active ones, which means that it |
| 2845 | also includes entries currently being added. |
Willy Tarreau | 95f753e | 2021-04-30 12:09:54 +0200 | [diff] [blame] | 2846 | |
| 2847 | In the output, the first column is a unique entry identifier, which is usable |
| 2848 | as a reference for operations "del map" and "set map". The second column is |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2849 | the pattern and the third column is the sample if available. The data returned |
| 2850 | are not directly a list of available maps, but are the list of all patterns |
| 2851 | composing any map. Many of these patterns can be shared with ACL. |
| 2852 | |
Willy Tarreau | 49962b5 | 2021-02-12 16:56:22 +0100 | [diff] [blame] | 2853 | show peers [dict|-] [<peers section>] |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2854 | Dump info about the peers configured in "peers" sections. Without argument, |
| 2855 | the list of the peers belonging to all the "peers" sections are listed. If |
| 2856 | <peers section> is specified, only the information about the peers belonging |
Willy Tarreau | 49962b5 | 2021-02-12 16:56:22 +0100 | [diff] [blame] | 2857 | to this "peers" section are dumped. When "dict" is specified before the peers |
| 2858 | section name, the entire Tx/Rx dictionary caches will also be dumped (very |
| 2859 | large). Passing "-" may be required to dump a peers section called "dict". |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2860 | |
Michael Prokop | 4438c60 | 2019-05-24 10:25:45 +0200 | [diff] [blame] | 2861 | Here are two examples of outputs where hostA, hostB and hostC peers belong to |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2862 | "sharedlb" peers sections. Only hostA and hostB are connected. Only hostA has |
| 2863 | sent data to hostB. |
| 2864 | |
| 2865 | $ echo "show peers" | socat - /tmp/hostA |
| 2866 | 0x55deb0224320: [15/Apr/2019:11:28:01] id=sharedlb state=0 flags=0x3 \ |
Emeric Brun | 0bbec0f | 2019-04-18 11:39:43 +0200 | [diff] [blame] | 2867 | resync_timeout=<PAST> task_calls=45122 |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2868 | 0x55deb022b540: id=hostC(remote) addr=127.0.0.12:10002 status=CONN \ |
| 2869 | reconnect=4s confirm=0 |
| 2870 | flags=0x0 |
| 2871 | 0x55deb022a440: id=hostA(local) addr=127.0.0.10:10000 status=NONE \ |
| 2872 | reconnect=<NEVER> confirm=0 |
| 2873 | flags=0x0 |
| 2874 | 0x55deb0227d70: id=hostB(remote) addr=127.0.0.11:10001 status=ESTA |
| 2875 | reconnect=2s confirm=0 |
Emeric Brun | 0bbec0f | 2019-04-18 11:39:43 +0200 | [diff] [blame] | 2876 | flags=0x20000200 appctx:0x55deb028fba0 st0=7 st1=0 task_calls=14456 \ |
| 2877 | state=EST |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2878 | xprt=RAW src=127.0.0.1:37257 addr=127.0.0.10:10000 |
| 2879 | remote_table:0x55deb0224a10 id=stkt local_id=1 remote_id=1 |
| 2880 | last_local_table:0x55deb0224a10 id=stkt local_id=1 remote_id=1 |
| 2881 | shared tables: |
| 2882 | 0x55deb0224a10 local_id=1 remote_id=1 flags=0x0 remote_data=0x65 |
| 2883 | last_acked=0 last_pushed=3 last_get=0 teaching_origin=0 update=3 |
| 2884 | table:0x55deb022d6a0 id=stkt update=3 localupdate=3 \ |
| 2885 | commitupdate=3 syncing=0 |
| 2886 | |
| 2887 | $ echo "show peers" | socat - /tmp/hostB |
| 2888 | 0x55871b5ab320: [15/Apr/2019:11:28:03] id=sharedlb state=0 flags=0x3 \ |
Emeric Brun | 0bbec0f | 2019-04-18 11:39:43 +0200 | [diff] [blame] | 2889 | resync_timeout=<PAST> task_calls=3 |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2890 | 0x55871b5b2540: id=hostC(remote) addr=127.0.0.12:10002 status=CONN \ |
| 2891 | reconnect=3s confirm=0 |
| 2892 | flags=0x0 |
| 2893 | 0x55871b5b1440: id=hostB(local) addr=127.0.0.11:10001 status=NONE \ |
| 2894 | reconnect=<NEVER> confirm=0 |
| 2895 | flags=0x0 |
| 2896 | 0x55871b5aed70: id=hostA(remote) addr=127.0.0.10:10000 status=ESTA \ |
| 2897 | reconnect=2s confirm=0 |
Emeric Brun | 0bbec0f | 2019-04-18 11:39:43 +0200 | [diff] [blame] | 2898 | flags=0x20000200 appctx:0x7fa46800ee00 st0=7 st1=0 task_calls=62356 \ |
| 2899 | state=EST |
Frédéric Lécaille | 21dde50 | 2019-04-15 13:50:23 +0200 | [diff] [blame] | 2900 | remote_table:0x55871b5ab960 id=stkt local_id=1 remote_id=1 |
| 2901 | last_local_table:0x55871b5ab960 id=stkt local_id=1 remote_id=1 |
| 2902 | shared tables: |
| 2903 | 0x55871b5ab960 local_id=1 remote_id=1 flags=0x0 remote_data=0x65 |
| 2904 | last_acked=3 last_pushed=0 last_get=3 teaching_origin=0 update=0 |
| 2905 | table:0x55871b5b46a0 id=stkt update=1 localupdate=0 \ |
| 2906 | commitupdate=0 syncing=0 |
| 2907 | |
Willy Tarreau | 7583c36 | 2022-11-21 10:02:29 +0100 | [diff] [blame] | 2908 | show pools [byname|bysize|byusage] [match <pfx>] [<nb>] |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2909 | Dump the status of internal memory pools. This is useful to track memory |
| 2910 | usage when suspecting a memory leak for example. It does exactly the same |
Willy Tarreau | 2fba08f | 2022-11-21 09:34:02 +0100 | [diff] [blame] | 2911 | as the SIGQUIT when running in foreground except that it does not flush the |
| 2912 | pools. The output is not sorted by default. If "byname" is specified, it is |
| 2913 | sorted by pool name; if "bysize" is specified, it is sorted by item size in |
| 2914 | reverse order; if "byusage" is specified, it is sorted by total usage in |
| 2915 | reverse order, and only used entries are shown. It is also possible to limit |
Willy Tarreau | 7583c36 | 2022-11-21 10:02:29 +0100 | [diff] [blame] | 2916 | the output to the <nb> first entries (e.g. when sorting by usage). Finally, |
| 2917 | if "match" followed by a prefix is specified, then only pools whose name |
| 2918 | starts with this prefix will be shown. The reported total only concerns pools |
| 2919 | matching the filtering criteria. Example: |
| 2920 | |
| 2921 | $ socat - /tmp/haproxy.sock <<< "show pools match quic byusage" |
| 2922 | Dumping pools usage. Use SIGQUIT to flush them. |
| 2923 | - Pool quic_conn_r (65560 bytes) : 1337 allocated (87653720 bytes), ... |
| 2924 | - Pool quic_crypto (1048 bytes) : 6685 allocated (7005880 bytes), ... |
| 2925 | - Pool quic_conn (4056 bytes) : 1337 allocated (5422872 bytes), ... |
| 2926 | - Pool quic_rxbuf (262168 bytes) : 8 allocated (2097344 bytes), ... |
| 2927 | - Pool quic_connne (184 bytes) : 9359 allocated (1722056 bytes), ... |
| 2928 | - Pool quic_frame (184 bytes) : 7938 allocated (1460592 bytes), ... |
| 2929 | - Pool quic_tx_pac (152 bytes) : 6454 allocated (981008 bytes), ... |
| 2930 | - Pool quic_tls_ke (56 bytes) : 12033 allocated (673848 bytes), ... |
| 2931 | - Pool quic_rx_pac (408 bytes) : 1596 allocated (651168 bytes), ... |
| 2932 | - Pool quic_tls_se (88 bytes) : 6685 allocated (588280 bytes), ... |
| 2933 | - Pool quic_cstrea (88 bytes) : 4011 allocated (352968 bytes), ... |
| 2934 | - Pool quic_tls_iv (24 bytes) : 12033 allocated (288792 bytes), ... |
| 2935 | - Pool quic_dgram (344 bytes) : 732 allocated (251808 bytes), ... |
| 2936 | - Pool quic_arng (56 bytes) : 4011 allocated (224616 bytes), ... |
| 2937 | - Pool quic_conn_c (152 bytes) : 1337 allocated (203224 bytes), ... |
| 2938 | Total: 15 pools, 109578176 bytes allocated, 109578176 used ... |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2939 | |
Willy Tarreau | e86bc35 | 2022-09-08 16:38:10 +0200 | [diff] [blame] | 2940 | show profiling [{all | status | tasks | memory}] [byaddr|bytime|aggr|<max_lines>]* |
Willy Tarreau | 75c62c2 | 2018-11-22 11:02:09 +0100 | [diff] [blame] | 2941 | Dumps the current profiling settings, one per line, as well as the command |
Willy Tarreau | 1bd67e9 | 2021-01-29 00:07:40 +0100 | [diff] [blame] | 2942 | needed to change them. When tasks profiling is enabled, some per-function |
| 2943 | statistics collected by the scheduler will also be emitted, with a summary |
Willy Tarreau | 42712cb | 2021-05-05 17:48:13 +0200 | [diff] [blame] | 2944 | covering the number of calls, total/avg CPU time and total/avg latency. When |
| 2945 | memory profiling is enabled, some information such as the number of |
| 2946 | allocations/releases and their sizes will be reported. It is possible to |
| 2947 | limit the dump to only the profiling status, the tasks, or the memory |
| 2948 | profiling by specifying the respective keywords; by default all profiling |
| 2949 | information are dumped. It is also possible to limit the number of lines |
Willy Tarreau | f1c8a38 | 2021-05-13 10:00:17 +0200 | [diff] [blame] | 2950 | of output of each category by specifying a numeric limit. If is possible to |
Willy Tarreau | e86bc35 | 2022-09-08 16:38:10 +0200 | [diff] [blame] | 2951 | request that the output is sorted by address or by total execution time |
| 2952 | instead of usage, e.g. to ease comparisons between subsequent calls or to |
| 2953 | check what needs to be optimized, and to aggregate task activity by called |
| 2954 | function instead of seeing the details. Please note that profiling is |
Willy Tarreau | f1c8a38 | 2021-05-13 10:00:17 +0200 | [diff] [blame] | 2955 | essentially aimed at developers since it gives hints about where CPU cycles |
| 2956 | or memory are wasted in the code. There is nothing useful to monitor there. |
Willy Tarreau | 75c62c2 | 2018-11-22 11:02:09 +0100 | [diff] [blame] | 2957 | |
Willy Tarreau | 87ef323 | 2021-01-29 12:01:46 +0100 | [diff] [blame] | 2958 | show resolvers [<resolvers section id>] |
| 2959 | Dump statistics for the given resolvers section, or all resolvers sections |
| 2960 | if no section is supplied. |
| 2961 | |
| 2962 | For each name server, the following counters are reported: |
| 2963 | sent: number of DNS requests sent to this server |
| 2964 | valid: number of DNS valid responses received from this server |
| 2965 | update: number of DNS responses used to update the server's IP address |
| 2966 | cname: number of CNAME responses |
| 2967 | cname_error: CNAME errors encountered with this server |
| 2968 | any_err: number of empty response (IE: server does not support ANY type) |
| 2969 | nx: non existent domain response received from this server |
| 2970 | timeout: how many time this server did not answer in time |
| 2971 | refused: number of requests refused by this server |
| 2972 | other: any other DNS errors |
| 2973 | invalid: invalid DNS response (from a protocol point of view) |
| 2974 | too_big: too big response |
Michael Prokop | 9a62e35 | 2022-12-09 12:28:46 +0100 | [diff] [blame] | 2975 | outdated: number of response arrived too late (after another name server) |
Willy Tarreau | 87ef323 | 2021-01-29 12:01:46 +0100 | [diff] [blame] | 2976 | |
Amaury Denoyelle | 3f9758e | 2023-02-01 17:31:02 +0100 | [diff] [blame] | 2977 | show quic [all] |
Amaury Denoyelle | 15c7470 | 2023-02-01 10:18:26 +0100 | [diff] [blame] | 2978 | Dump information on all active QUIC frontend connections. This command is |
| 2979 | restricted and can only be issued on sockets configured for levels "operator" |
Amaury Denoyelle | 3f9758e | 2023-02-01 17:31:02 +0100 | [diff] [blame] | 2980 | or "admin". By default, connections on closing or draining state are not |
| 2981 | displayed. Use the extra argument "all" to include them in the output. |
Amaury Denoyelle | 15c7470 | 2023-02-01 10:18:26 +0100 | [diff] [blame] | 2982 | |
Willy Tarreau | 69f591e | 2020-07-01 07:00:59 +0200 | [diff] [blame] | 2983 | show servers conn [<backend>] |
| 2984 | Dump the current and idle connections state of the servers belonging to the |
| 2985 | designated backend (or all backends if none specified). A backend name or |
| 2986 | identifier may be used. |
| 2987 | |
| 2988 | The output consists in a header line showing the fields titles, then one |
| 2989 | server per line with for each, the backend name and ID, server name and ID, |
| 2990 | the address, port and a series or values. The number of fields varies |
| 2991 | depending on thread count. |
| 2992 | |
| 2993 | Given the threaded nature of idle connections, it's important to understand |
| 2994 | that some values may change once read, and that as such, consistency within a |
| 2995 | line isn't granted. This output is mostly provided as a debugging tool and is |
| 2996 | not relevant to be routinely monitored nor graphed. |
| 2997 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 2998 | show servers state [<backend>] |
| 2999 | Dump the state of the servers found in the running configuration. A backend |
| 3000 | name or identifier may be provided to limit the output to this backend only. |
| 3001 | |
| 3002 | The dump has the following format: |
| 3003 | - first line contains the format version (1 in this specification); |
| 3004 | - second line contains the column headers, prefixed by a sharp ('#'); |
| 3005 | - third line and next ones contain data; |
| 3006 | - each line starting by a sharp ('#') is considered as a comment. |
| 3007 | |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 3008 | Since multiple versions of the output may co-exist, below is the list of |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3009 | fields and their order per file format version : |
| 3010 | 1: |
| 3011 | be_id: Backend unique id. |
| 3012 | be_name: Backend label. |
| 3013 | srv_id: Server unique id (in the backend). |
| 3014 | srv_name: Server label. |
| 3015 | srv_addr: Server IP address. |
| 3016 | srv_op_state: Server operational state (UP/DOWN/...). |
Cyril Bonté | 5b2ce8a | 2016-11-02 00:19:58 +0100 | [diff] [blame] | 3017 | 0 = SRV_ST_STOPPED |
| 3018 | The server is down. |
| 3019 | 1 = SRV_ST_STARTING |
| 3020 | The server is warming up (up but |
| 3021 | throttled). |
| 3022 | 2 = SRV_ST_RUNNING |
| 3023 | The server is fully up. |
| 3024 | 3 = SRV_ST_STOPPING |
| 3025 | The server is up but soft-stopping |
| 3026 | (eg: 404). |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3027 | srv_admin_state: Server administrative state (MAINT/DRAIN/...). |
Cyril Bonté | 5b2ce8a | 2016-11-02 00:19:58 +0100 | [diff] [blame] | 3028 | The state is actually a mask of values : |
| 3029 | 0x01 = SRV_ADMF_FMAINT |
| 3030 | The server was explicitly forced into |
| 3031 | maintenance. |
| 3032 | 0x02 = SRV_ADMF_IMAINT |
| 3033 | The server has inherited the maintenance |
| 3034 | status from a tracked server. |
| 3035 | 0x04 = SRV_ADMF_CMAINT |
| 3036 | The server is in maintenance because of |
| 3037 | the configuration. |
| 3038 | 0x08 = SRV_ADMF_FDRAIN |
| 3039 | The server was explicitly forced into |
| 3040 | drain state. |
| 3041 | 0x10 = SRV_ADMF_IDRAIN |
| 3042 | The server has inherited the drain status |
| 3043 | from a tracked server. |
Baptiste Assmann | 89aa7f3 | 2016-11-02 21:31:27 +0100 | [diff] [blame] | 3044 | 0x20 = SRV_ADMF_RMAINT |
| 3045 | The server is in maintenance because of an |
| 3046 | IP address resolution failure. |
Frédéric Lécaille | b418c12 | 2017-04-26 11:24:02 +0200 | [diff] [blame] | 3047 | 0x40 = SRV_ADMF_HMAINT |
| 3048 | The server FQDN was set from stats socket. |
| 3049 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3050 | srv_uweight: User visible server's weight. |
| 3051 | srv_iweight: Server's initial weight. |
| 3052 | srv_time_since_last_change: Time since last operational change. |
| 3053 | srv_check_status: Last health check status. |
| 3054 | srv_check_result: Last check result (FAILED/PASSED/...). |
Cyril Bonté | 5b2ce8a | 2016-11-02 00:19:58 +0100 | [diff] [blame] | 3055 | 0 = CHK_RES_UNKNOWN |
| 3056 | Initialized to this by default. |
| 3057 | 1 = CHK_RES_NEUTRAL |
| 3058 | Valid check but no status information. |
| 3059 | 2 = CHK_RES_FAILED |
| 3060 | Check failed. |
| 3061 | 3 = CHK_RES_PASSED |
| 3062 | Check succeeded and server is fully up |
| 3063 | again. |
| 3064 | 4 = CHK_RES_CONDPASS |
| 3065 | Check reports the server doesn't want new |
| 3066 | sessions. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3067 | srv_check_health: Checks rise / fall current counter. |
| 3068 | srv_check_state: State of the check (ENABLED/PAUSED/...). |
Cyril Bonté | 5b2ce8a | 2016-11-02 00:19:58 +0100 | [diff] [blame] | 3069 | The state is actually a mask of values : |
| 3070 | 0x01 = CHK_ST_INPROGRESS |
| 3071 | A check is currently running. |
| 3072 | 0x02 = CHK_ST_CONFIGURED |
| 3073 | This check is configured and may be |
| 3074 | enabled. |
| 3075 | 0x04 = CHK_ST_ENABLED |
| 3076 | This check is currently administratively |
| 3077 | enabled. |
| 3078 | 0x08 = CHK_ST_PAUSED |
| 3079 | Checks are paused because of maintenance |
| 3080 | (health only). |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3081 | srv_agent_state: State of the agent check (ENABLED/PAUSED/...). |
Cyril Bonté | 5b2ce8a | 2016-11-02 00:19:58 +0100 | [diff] [blame] | 3082 | This state uses the same mask values as |
| 3083 | "srv_check_state", adding this specific one : |
| 3084 | 0x10 = CHK_ST_AGENT |
| 3085 | Check is an agent check (otherwise it's a |
| 3086 | health check). |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3087 | bk_f_forced_id: Flag to know if the backend ID is forced by |
| 3088 | configuration. |
| 3089 | srv_f_forced_id: Flag to know if the server's ID is forced by |
| 3090 | configuration. |
Frédéric Lécaille | b418c12 | 2017-04-26 11:24:02 +0200 | [diff] [blame] | 3091 | srv_fqdn: Server FQDN. |
Frédéric Lécaille | 3169471 | 2017-08-01 08:47:19 +0200 | [diff] [blame] | 3092 | srv_port: Server port. |
Baptiste Assmann | 6d0f38f | 2018-07-02 17:00:54 +0200 | [diff] [blame] | 3093 | srvrecord: DNS SRV record associated to this SRV. |
William Dauchy | f637044 | 2020-11-14 19:25:33 +0100 | [diff] [blame] | 3094 | srv_use_ssl: use ssl for server connections. |
William Dauchy | d1a7b85 | 2021-02-11 22:51:26 +0100 | [diff] [blame] | 3095 | srv_check_port: Server health check port. |
| 3096 | srv_check_addr: Server health check address. |
| 3097 | srv_agent_addr: Server health agent address. |
| 3098 | srv_agent_port: Server health agent port. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3099 | |
| 3100 | show sess |
| 3101 | Dump all known sessions. Avoid doing this on slow connections as this can |
| 3102 | be huge. This command is restricted and can only be issued on sockets |
Willy Tarreau | c6e7a1b | 2020-06-28 01:24:12 +0200 | [diff] [blame] | 3103 | configured for levels "operator" or "admin". Note that on machines with |
| 3104 | quickly recycled connections, it is possible that this output reports less |
| 3105 | entries than really exist because it will dump all existing sessions up to |
| 3106 | the last one that was created before the command was entered; those which |
| 3107 | die in the mean time will not appear. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3108 | |
| 3109 | show sess <id> |
| 3110 | Display a lot of internal information about the specified session identifier. |
| 3111 | This identifier is the first field at the beginning of the lines in the dumps |
| 3112 | of "show sess" (it corresponds to the session pointer). Those information are |
| 3113 | useless to most users but may be used by haproxy developers to troubleshoot a |
| 3114 | complex bug. The output format is intentionally not documented so that it can |
| 3115 | freely evolve depending on demands. You may find a description of all fields |
| 3116 | returned in src/dumpstats.c |
| 3117 | |
| 3118 | The special id "all" dumps the states of all sessions, which must be avoided |
| 3119 | as much as possible as it is highly CPU intensive and can take a lot of time. |
| 3120 | |
Daniel Corbett | c40edac | 2020-11-01 10:54:17 -0500 | [diff] [blame] | 3121 | show stat [domain <dns|proxy>] [{<iid>|<proxy>} <type> <sid>] [typed|json] \ |
Willy Tarreau | 698097b | 2020-10-23 20:19:47 +0200 | [diff] [blame] | 3122 | [desc] [up|no-maint] |
Daniel Corbett | c40edac | 2020-11-01 10:54:17 -0500 | [diff] [blame] | 3123 | Dump statistics. The domain is used to select which statistics to print; dns |
| 3124 | and proxy are available for now. By default, the CSV format is used; you can |
Amaury Denoyelle | 072f97e | 2020-10-05 11:49:37 +0200 | [diff] [blame] | 3125 | activate the extended typed output format described in the section above if |
| 3126 | "typed" is passed after the other arguments; or in JSON if "json" is passed |
| 3127 | after the other arguments. By passing <id>, <type> and <sid>, it is possible |
| 3128 | to dump only selected items : |
Willy Tarreau | a1b1ed5 | 2016-11-25 08:50:58 +0100 | [diff] [blame] | 3129 | - <iid> is a proxy ID, -1 to dump everything. Alternatively, a proxy name |
| 3130 | <proxy> may be specified. In this case, this proxy's ID will be used as |
| 3131 | the ID selector. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3132 | - <type> selects the type of dumpable objects : 1 for frontends, 2 for |
| 3133 | backends, 4 for servers, -1 for everything. These values can be ORed, |
| 3134 | for example: |
| 3135 | 1 + 2 = 3 -> frontend + backend. |
| 3136 | 1 + 2 + 4 = 7 -> frontend + backend + server. |
| 3137 | - <sid> is a server ID, -1 to dump everything from the selected proxy. |
| 3138 | |
| 3139 | Example : |
| 3140 | $ echo "show info;show stat" | socat stdio unix-connect:/tmp/sock1 |
| 3141 | >>> Name: HAProxy |
| 3142 | Version: 1.4-dev2-49 |
| 3143 | Release_date: 2009/09/23 |
| 3144 | Nbproc: 1 |
| 3145 | Process_num: 1 |
| 3146 | (...) |
| 3147 | |
| 3148 | # pxname,svname,qcur,qmax,scur,smax,slim,stot,bin,bout,dreq, (...) |
| 3149 | stats,FRONTEND,,,0,0,1000,0,0,0,0,0,0,,,,,OPEN,,,,,,,,,1,1,0, (...) |
| 3150 | stats,BACKEND,0,0,0,0,1000,0,0,0,0,0,,0,0,0,0,UP,0,0,0,,0,250,(...) |
| 3151 | (...) |
| 3152 | www1,BACKEND,0,0,0,0,1000,0,0,0,0,0,,0,0,0,0,UP,1,1,0,,0,250, (...) |
| 3153 | |
| 3154 | $ |
| 3155 | |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 3156 | In this example, two commands have been issued at once. That way it's easy to |
| 3157 | find which process the stats apply to in multi-process mode. This is not |
| 3158 | needed in the typed output format as the process number is reported on each |
| 3159 | line. Notice the empty line after the information output which marks the end |
| 3160 | of the first block. A similar empty line appears at the end of the second |
| 3161 | block (stats) so that the reader knows the output has not been truncated. |
| 3162 | |
| 3163 | When "typed" is specified, the output format is more suitable to monitoring |
| 3164 | tools because it provides numeric positions and indicates the type of each |
| 3165 | output field. Each value stands on its own line with process number, element |
| 3166 | number, nature, origin and scope. This same format is available via the HTTP |
| 3167 | stats by passing ";typed" after the URI. It is very important to note that in |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 3168 | typed output format, the dump for a single object is contiguous so that there |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 3169 | is no need for a consumer to store everything at once. |
| 3170 | |
Willy Tarreau | 698097b | 2020-10-23 20:19:47 +0200 | [diff] [blame] | 3171 | The "up" modifier will result in listing only servers which reportedly up or |
| 3172 | not checked. Those down, unresolved, or in maintenance will not be listed. |
| 3173 | This is analogous to the ";up" option on the HTTP stats. Similarly, the |
| 3174 | "no-maint" modifier will act like the ";no-maint" HTTP modifier and will |
| 3175 | result in disabled servers not to be listed. The difference is that those |
| 3176 | which are enabled but down will not be evicted. |
| 3177 | |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 3178 | When using the typed output format, each line is made of 4 columns delimited |
| 3179 | by colons (':'). The first column is a dot-delimited series of 5 elements. The |
| 3180 | first element is a letter indicating the type of the object being described. |
| 3181 | At the moment the following object types are known : 'F' for a frontend, 'B' |
| 3182 | for a backend, 'L' for a listener, and 'S' for a server. The second element |
| 3183 | The second element is a positive integer representing the unique identifier of |
| 3184 | the proxy the object belongs to. It is equivalent to the "iid" column of the |
| 3185 | CSV output and matches the value in front of the optional "id" directive found |
| 3186 | in the frontend or backend section. The third element is a positive integer |
| 3187 | containing the unique object identifier inside the proxy, and corresponds to |
| 3188 | the "sid" column of the CSV output. ID 0 is reported when dumping a frontend |
| 3189 | or a backend. For a listener or a server, this corresponds to their respective |
| 3190 | ID inside the proxy. The fourth element is the numeric position of the field |
| 3191 | in the list (starting at zero). This position shall not change over time, but |
| 3192 | holes are to be expected, depending on build options or if some fields are |
| 3193 | deleted in the future. The fifth element is the field name as it appears in |
| 3194 | the CSV output. The sixth element is a positive integer and is the relative |
| 3195 | process number starting at 1. |
| 3196 | |
| 3197 | The rest of the line starting after the first colon follows the "typed output |
| 3198 | format" described in the section above. In short, the second column (after the |
| 3199 | first ':') indicates the origin, nature and scope of the variable. The third |
Willy Tarreau | 589722e | 2021-05-08 07:46:44 +0200 | [diff] [blame] | 3200 | column indicates the field type, among "s32", "s64", "u32", "u64", "flt' and |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 3201 | "str". Then the fourth column is the value itself, which the consumer knows |
| 3202 | how to parse thanks to column 3 and how to process thanks to column 2. |
| 3203 | |
Willy Tarreau | 6b19b14 | 2019-10-09 15:44:21 +0200 | [diff] [blame] | 3204 | When "desc" is appended to the command, one extra colon followed by a quoted |
| 3205 | string is appended with a description for the metric. At the time of writing, |
| 3206 | this is only supported for the "typed" output format. |
| 3207 | |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 3208 | Thus the overall line format in typed mode is : |
| 3209 | |
| 3210 | <obj>.<px_id>.<id>.<fpos>.<fname>.<process_num>:<tags>:<type>:<value> |
| 3211 | |
| 3212 | Here's an example of typed output format : |
| 3213 | |
| 3214 | $ echo "show stat typed" | socat stdio unix-connect:/tmp/sock1 |
| 3215 | F.2.0.0.pxname.1:MGP:str:private-frontend |
| 3216 | F.2.0.1.svname.1:MGP:str:FRONTEND |
| 3217 | F.2.0.8.bin.1:MGP:u64:0 |
| 3218 | F.2.0.9.bout.1:MGP:u64:0 |
| 3219 | F.2.0.40.hrsp_2xx.1:MGP:u64:0 |
| 3220 | L.2.1.0.pxname.1:MGP:str:private-frontend |
| 3221 | L.2.1.1.svname.1:MGP:str:sock-1 |
| 3222 | L.2.1.17.status.1:MGP:str:OPEN |
| 3223 | L.2.1.73.addr.1:MGP:str:0.0.0.0:8001 |
| 3224 | S.3.13.60.rtime.1:MCP:u32:0 |
| 3225 | S.3.13.61.ttime.1:MCP:u32:0 |
| 3226 | S.3.13.62.agent_status.1:MGP:str:L4TOUT |
| 3227 | S.3.13.64.agent_duration.1:MGP:u64:2001 |
| 3228 | S.3.13.65.check_desc.1:MCP:str:Layer4 timeout |
| 3229 | S.3.13.66.agent_desc.1:MCP:str:Layer4 timeout |
| 3230 | S.3.13.67.check_rise.1:MCP:u32:2 |
| 3231 | S.3.13.68.check_fall.1:MCP:u32:3 |
| 3232 | S.3.13.69.check_health.1:SGP:u32:0 |
| 3233 | S.3.13.70.agent_rise.1:MaP:u32:1 |
| 3234 | S.3.13.71.agent_fall.1:SGP:u32:1 |
| 3235 | S.3.13.72.agent_health.1:SGP:u32:1 |
| 3236 | S.3.13.73.addr.1:MCP:str:1.255.255.255:8888 |
| 3237 | S.3.13.75.mode.1:MAP:str:http |
| 3238 | B.3.0.0.pxname.1:MGP:str:private-backend |
| 3239 | B.3.0.1.svname.1:MGP:str:BACKEND |
| 3240 | B.3.0.2.qcur.1:MGP:u32:0 |
| 3241 | B.3.0.3.qmax.1:MGP:u32:0 |
| 3242 | B.3.0.4.scur.1:MGP:u32:0 |
| 3243 | B.3.0.5.smax.1:MGP:u32:0 |
| 3244 | B.3.0.6.slim.1:MGP:u32:1000 |
| 3245 | B.3.0.55.lastsess.1:MMP:s32:-1 |
| 3246 | (...) |
| 3247 | |
Simon Horman | 1084a36 | 2016-11-21 17:00:24 +0100 | [diff] [blame] | 3248 | In the typed format, the presence of the process ID at the end of the |
| 3249 | first column makes it very easy to visually aggregate outputs from |
| 3250 | multiple processes, as show in the example below where each line appears |
| 3251 | for each process : |
Willy Tarreau | 5d8b979 | 2016-03-11 11:09:34 +0100 | [diff] [blame] | 3252 | |
| 3253 | $ ( echo show stat typed | socat /var/run/haproxy.sock1 - ; \ |
| 3254 | echo show stat typed | socat /var/run/haproxy.sock2 - ) | \ |
| 3255 | sort -t . -k 1,1 -k 2,2n -k 3,3n -k 4,4n -k 5,5 -k 6,6n |
| 3256 | B.3.0.0.pxname.1:MGP:str:private-backend |
| 3257 | B.3.0.0.pxname.2:MGP:str:private-backend |
| 3258 | B.3.0.1.svname.1:MGP:str:BACKEND |
| 3259 | B.3.0.1.svname.2:MGP:str:BACKEND |
| 3260 | B.3.0.2.qcur.1:MGP:u32:0 |
| 3261 | B.3.0.2.qcur.2:MGP:u32:0 |
| 3262 | B.3.0.3.qmax.1:MGP:u32:0 |
| 3263 | B.3.0.3.qmax.2:MGP:u32:0 |
| 3264 | B.3.0.4.scur.1:MGP:u32:0 |
| 3265 | B.3.0.4.scur.2:MGP:u32:0 |
| 3266 | B.3.0.5.smax.1:MGP:u32:0 |
| 3267 | B.3.0.5.smax.2:MGP:u32:0 |
| 3268 | B.3.0.6.slim.1:MGP:u32:1000 |
| 3269 | B.3.0.6.slim.2:MGP:u32:1000 |
| 3270 | (...) |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3271 | |
Simon Horman | 05ee213 | 2017-01-04 09:37:25 +0100 | [diff] [blame] | 3272 | The format of JSON output is described in a schema which may be output |
Simon Horman | 6f6bb38 | 2017-01-04 09:37:26 +0100 | [diff] [blame] | 3273 | using "show schema json". |
| 3274 | |
| 3275 | The JSON output contains no extra whitespace in order to reduce the |
| 3276 | volume of output. For human consumption passing the output through a |
| 3277 | pretty printer may be helpful. Example : |
| 3278 | |
| 3279 | $ echo "show stat json" | socat /var/run/haproxy.sock stdio | \ |
| 3280 | python -m json.tool |
Simon Horman | 05ee213 | 2017-01-04 09:37:25 +0100 | [diff] [blame] | 3281 | |
| 3282 | The JSON output contains no extra whitespace in order to reduce the |
| 3283 | volume of output. For human consumption passing the output through a |
| 3284 | pretty printer may be helpful. Example : |
| 3285 | |
| 3286 | $ echo "show stat json" | socat /var/run/haproxy.sock stdio | \ |
| 3287 | python -m json.tool |
| 3288 | |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 3289 | show ssl ca-file [<cafile>[:<index>]] |
William Lallemand | 0c39526 | 2023-01-10 14:44:27 +0100 | [diff] [blame] | 3290 | Display the list of CA files loaded into the process and their respective |
| 3291 | certificate counts. The certificates are not used by any frontend or backend |
| 3292 | until their status is "Used". |
William Lallemand | f29c415 | 2023-01-10 15:07:12 +0100 | [diff] [blame] | 3293 | A "@system-ca" entry can appear in the list, it is loaded by the httpclient |
| 3294 | by default. It contains the list of trusted CA of your system returned by |
| 3295 | OpenSSL. |
William Lallemand | 0c39526 | 2023-01-10 14:44:27 +0100 | [diff] [blame] | 3296 | If a filename is prefixed by an asterisk, it is a transaction which |
Remi Tricot-Le Breton | e88a2ca | 2021-04-08 15:30:23 +0200 | [diff] [blame] | 3297 | is not committed yet. If a <cafile> is specified without <index>, it will show |
| 3298 | the status of the CA file ("Used"/"Unused") followed by details about all the |
| 3299 | certificates contained in the CA file. The details displayed for every |
| 3300 | certificate are the same as the ones displayed by a "show ssl cert" command. |
| 3301 | If a <cafile> is specified followed by an <index>, it will only display the |
| 3302 | details of the certificate having the specified index. Indexes start from 1. |
| 3303 | If the index is invalid (too big for instance), nothing will be displayed. |
| 3304 | This command can be useful to check if a CA file was properly updated. |
| 3305 | You can also display the details of an ongoing transaction by prefixing the |
| 3306 | filename by an asterisk. |
| 3307 | |
| 3308 | Example : |
| 3309 | |
| 3310 | $ echo "show ssl ca-file" | socat /var/run/haproxy.master - |
| 3311 | # transaction |
| 3312 | *cafile.crt - 2 certificate(s) |
| 3313 | # filename |
| 3314 | cafile.crt - 1 certificate(s) |
| 3315 | |
| 3316 | $ echo "show ssl ca-file cafile.crt" | socat /var/run/haproxy.master - |
| 3317 | Filename: /home/tricot/work/haproxy/reg-tests/ssl/set_cafile_ca2.crt |
| 3318 | Status: Used |
| 3319 | |
| 3320 | Certificate #1: |
| 3321 | Serial: 11A4D2200DC84376E7D233CAFF39DF44BF8D1211 |
| 3322 | notBefore: Apr 1 07:40:53 2021 GMT |
| 3323 | notAfter: Aug 17 07:40:53 2048 GMT |
| 3324 | Subject Alternative Name: |
| 3325 | Algorithm: RSA4096 |
| 3326 | SHA1 FingerPrint: A111EF0FEFCDE11D47FE3F33ADCA8435EBEA4864 |
| 3327 | Subject: /C=FR/ST=Some-State/O=HAProxy Technologies/CN=HAProxy Technologies CA |
| 3328 | Issuer: /C=FR/ST=Some-State/O=HAProxy Technologies/CN=HAProxy Technologies CA |
| 3329 | |
| 3330 | $ echo "show ssl ca-file *cafile.crt:2" | socat /var/run/haproxy.master - |
| 3331 | Filename: */home/tricot/work/haproxy/reg-tests/ssl/set_cafile_ca2.crt |
| 3332 | Status: Unused |
| 3333 | |
| 3334 | Certificate #2: |
| 3335 | Serial: 587A1CE5ED855040A0C82BF255FF300ADB7C8136 |
| 3336 | [...] |
| 3337 | |
William Lallemand | d4f946c | 2019-12-05 10:26:40 +0100 | [diff] [blame] | 3338 | show ssl cert [<filename>] |
William Lallemand | 0c39526 | 2023-01-10 14:44:27 +0100 | [diff] [blame] | 3339 | Display the list of certificates loaded into the process. They are not used |
| 3340 | by any frontend or backend until their status is "Used". |
Remi Tricot-Le Breton | b5f0fac | 2021-04-14 16:19:29 +0200 | [diff] [blame] | 3341 | If a filename is prefixed by an asterisk, it is a transaction which is not |
| 3342 | committed yet. If a filename is specified, it will show details about the |
| 3343 | certificate. This command can be useful to check if a certificate was well |
| 3344 | updated. You can also display details on a transaction by prefixing the |
| 3345 | filename by an asterisk. |
Remi Tricot-Le Breton | 6056e61 | 2021-06-10 13:51:15 +0200 | [diff] [blame] | 3346 | This command can also be used to display the details of a certificate's OCSP |
| 3347 | response by suffixing the filename with a ".ocsp" extension. It works for |
| 3348 | committed certificates as well as for ongoing transactions. On a committed |
| 3349 | certificate, this command is equivalent to calling "show ssl ocsp-response" |
| 3350 | with the certificate's corresponding OCSP response ID. |
William Lallemand | d4f946c | 2019-12-05 10:26:40 +0100 | [diff] [blame] | 3351 | |
| 3352 | Example : |
| 3353 | |
| 3354 | $ echo "@1 show ssl cert" | socat /var/run/haproxy.master - |
| 3355 | # transaction |
| 3356 | *test.local.pem |
| 3357 | # filename |
| 3358 | test.local.pem |
| 3359 | |
| 3360 | $ echo "@1 show ssl cert test.local.pem" | socat /var/run/haproxy.master - |
| 3361 | Filename: test.local.pem |
William Lallemand | 0c39526 | 2023-01-10 14:44:27 +0100 | [diff] [blame] | 3362 | Status: Used |
William Lallemand | d4f946c | 2019-12-05 10:26:40 +0100 | [diff] [blame] | 3363 | Serial: 03ECC19BA54B25E85ABA46EE561B9A10D26F |
| 3364 | notBefore: Sep 13 21:20:24 2019 GMT |
| 3365 | notAfter: Dec 12 21:20:24 2019 GMT |
| 3366 | Issuer: /C=US/O=Let's Encrypt/CN=Let's Encrypt Authority X3 |
| 3367 | Subject: /CN=test.local |
| 3368 | Subject Alternative Name: DNS:test.local, DNS:imap.test.local |
| 3369 | Algorithm: RSA2048 |
| 3370 | SHA1 FingerPrint: 417A11CAE25F607B24F638B4A8AEE51D1E211477 |
| 3371 | |
| 3372 | $ echo "@1 show ssl cert *test.local.pem" | socat /var/run/haproxy.master - |
| 3373 | Filename: *test.local.pem |
William Lallemand | 0c39526 | 2023-01-10 14:44:27 +0100 | [diff] [blame] | 3374 | Status: Unused |
William Lallemand | d4f946c | 2019-12-05 10:26:40 +0100 | [diff] [blame] | 3375 | [...] |
| 3376 | |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 3377 | show ssl crl-file [<crlfile>[:<index>]] |
William Lallemand | 0c39526 | 2023-01-10 14:44:27 +0100 | [diff] [blame] | 3378 | Display the list of CRL files loaded into the process. They are not used |
| 3379 | by any frontend or backend until their status is "Used". |
Remi Tricot-Le Breton | 3c222bd | 2021-04-27 16:28:25 +0200 | [diff] [blame] | 3380 | If a filename is prefixed by an asterisk, it is a transaction which is not |
| 3381 | committed yet. If a <crlfile> is specified without <index>, it will show the |
| 3382 | status of the CRL file ("Used"/"Unused") followed by details about all the |
| 3383 | Revocation Lists contained in the CRL file. The details displayed for every |
| 3384 | list are based on the output of "openssl crl -text -noout -in <file>". |
| 3385 | If a <crlfile> is specified followed by an <index>, it will only display the |
| 3386 | details of the list having the specified index. Indexes start from 1. |
| 3387 | If the index is invalid (too big for instance), nothing will be displayed. |
| 3388 | This command can be useful to check if a CRL file was properly updated. |
| 3389 | You can also display the details of an ongoing transaction by prefixing the |
| 3390 | filename by an asterisk. |
| 3391 | |
| 3392 | Example : |
| 3393 | |
| 3394 | $ echo "show ssl crl-file" | socat /var/run/haproxy.master - |
| 3395 | # transaction |
| 3396 | *crlfile.pem |
| 3397 | # filename |
| 3398 | crlfile.pem |
| 3399 | |
| 3400 | $ echo "show ssl crl-file crlfile.pem" | socat /var/run/haproxy.master - |
| 3401 | Filename: /home/tricot/work/haproxy/reg-tests/ssl/crlfile.pem |
| 3402 | Status: Used |
| 3403 | |
| 3404 | Certificate Revocation List #1: |
| 3405 | Version 1 |
| 3406 | Signature Algorithm: sha256WithRSAEncryption |
| 3407 | Issuer: /C=FR/O=HAProxy Technologies/CN=Intermediate CA2 |
| 3408 | Last Update: Apr 23 14:45:39 2021 GMT |
| 3409 | Next Update: Sep 8 14:45:39 2048 GMT |
| 3410 | Revoked Certificates: |
| 3411 | Serial Number: 1008 |
| 3412 | Revocation Date: Apr 23 14:45:36 2021 GMT |
| 3413 | |
| 3414 | Certificate Revocation List #2: |
| 3415 | Version 1 |
| 3416 | Signature Algorithm: sha256WithRSAEncryption |
| 3417 | Issuer: /C=FR/O=HAProxy Technologies/CN=Root CA |
| 3418 | Last Update: Apr 23 14:30:44 2021 GMT |
| 3419 | Next Update: Sep 8 14:30:44 2048 GMT |
| 3420 | No Revoked Certificates. |
| 3421 | |
William Lallemand | c69f02d | 2020-04-06 19:07:03 +0200 | [diff] [blame] | 3422 | show ssl crt-list [-n] [<filename>] |
William Lallemand | accac23 | 2020-04-02 17:42:51 +0200 | [diff] [blame] | 3423 | Display the list of crt-list and directories used in the HAProxy |
William Lallemand | c69f02d | 2020-04-06 19:07:03 +0200 | [diff] [blame] | 3424 | configuration. If a filename is specified, dump the content of a crt-list or |
| 3425 | a directory. Once dumped the output can be used as a crt-list file. |
| 3426 | The '-n' option can be used to display the line number, which is useful when |
| 3427 | combined with the 'del ssl crt-list' option when a entry is duplicated. The |
| 3428 | output with the '-n' option is not compatible with the crt-list format and |
| 3429 | not loadable by haproxy. |
William Lallemand | accac23 | 2020-04-02 17:42:51 +0200 | [diff] [blame] | 3430 | |
| 3431 | Example: |
William Lallemand | c69f02d | 2020-04-06 19:07:03 +0200 | [diff] [blame] | 3432 | echo "show ssl crt-list -n localhost.crt-list" | socat /tmp/sock1 - |
William Lallemand | accac23 | 2020-04-02 17:42:51 +0200 | [diff] [blame] | 3433 | # localhost.crt-list |
William Lallemand | c69f02d | 2020-04-06 19:07:03 +0200 | [diff] [blame] | 3434 | common.pem:1 !not.test1.com *.test1.com !localhost |
| 3435 | common.pem:2 |
| 3436 | ecdsa.pem:3 [verify none allow-0rtt ssl-min-ver TLSv1.0 ssl-max-ver TLSv1.3] localhost !www.test1.com |
| 3437 | ecdsa.pem:4 [verify none allow-0rtt ssl-min-ver TLSv1.0 ssl-max-ver TLSv1.3] |
William Lallemand | accac23 | 2020-04-02 17:42:51 +0200 | [diff] [blame] | 3438 | |
Remi Tricot-Le Breton | dafc068 | 2023-03-13 15:56:34 +0100 | [diff] [blame] | 3439 | show ssl ocsp-response [[text|base64] <id|path>] |
Remi Tricot-Le Breton | d92fd11 | 2021-06-10 13:51:13 +0200 | [diff] [blame] | 3440 | Display the IDs of the OCSP tree entries corresponding to all the OCSP |
Remi Tricot-Le Breton | 7716f27 | 2023-03-13 15:56:35 +0100 | [diff] [blame] | 3441 | responses used in HAProxy, as well as the corresponding frontend |
| 3442 | certificate's path, the issuer's name and key hash and the serial number of |
| 3443 | the certificate for which the OCSP response was built. |
Remi Tricot-Le Breton | dafc068 | 2023-03-13 15:56:34 +0100 | [diff] [blame] | 3444 | If a valid <id> or the <path> of a valid frontend certificate is provided, |
| 3445 | display the contents of the corresponding OCSP response. When an <id> is |
| 3446 | provided, it it possible to define the format in which the data is dumped. |
| 3447 | The 'text' option is the default one and it allows to display detailed |
| 3448 | information about the OCSP response the same way as in an "openssl ocsp |
| 3449 | -respin <ocsp-response> -text" call. The 'base64' format allows to dump the |
| 3450 | contents of an OCSP response in base64. |
Remi Tricot-Le Breton | d92fd11 | 2021-06-10 13:51:13 +0200 | [diff] [blame] | 3451 | |
| 3452 | Example : |
| 3453 | |
| 3454 | $ echo "show ssl ocsp-response" | socat /var/run/haproxy.master - |
| 3455 | # Certificate IDs |
| 3456 | Certificate ID key : 303b300906052b0e03021a050004148a83e0060faff709ca7e9b95522a2e81635fda0a0414f652b0e435d5ea923851508f0adbe92d85de007a0202100a |
Remi Tricot-Le Breton | 7716f27 | 2023-03-13 15:56:35 +0100 | [diff] [blame] | 3457 | Certificate path : /path_to_cert/foo.pem |
Remi Tricot-Le Breton | d92fd11 | 2021-06-10 13:51:13 +0200 | [diff] [blame] | 3458 | Certificate ID: |
Remi Tricot-Le Breton | d92fd11 | 2021-06-10 13:51:13 +0200 | [diff] [blame] | 3459 | Issuer Name Hash: 8A83E0060FAFF709CA7E9B95522A2E81635FDA0A |
| 3460 | Issuer Key Hash: F652B0E435D5EA923851508F0ADBE92D85DE007A |
| 3461 | Serial Number: 100A |
| 3462 | |
| 3463 | $ echo "show ssl ocsp-response 303b300906052b0e03021a050004148a83e0060faff709ca7e9b95522a2e81635fda0a0414f652b0e435d5ea923851508f0adbe92d85de007a0202100a" | socat /var/run/haproxy.master - |
| 3464 | OCSP Response Data: |
| 3465 | OCSP Response Status: successful (0x0) |
| 3466 | Response Type: Basic OCSP Response |
| 3467 | Version: 1 (0x0) |
| 3468 | Responder Id: C = FR, O = HAProxy Technologies, CN = ocsp.haproxy.com |
| 3469 | Produced At: May 27 15:43:38 2021 GMT |
| 3470 | Responses: |
| 3471 | Certificate ID: |
| 3472 | Hash Algorithm: sha1 |
| 3473 | Issuer Name Hash: 8A83E0060FAFF709CA7E9B95522A2E81635FDA0A |
| 3474 | Issuer Key Hash: F652B0E435D5EA923851508F0ADBE92D85DE007A |
| 3475 | Serial Number: 100A |
| 3476 | Cert Status: good |
| 3477 | This Update: May 27 15:43:38 2021 GMT |
| 3478 | Next Update: Oct 12 15:43:38 2048 GMT |
| 3479 | [...] |
| 3480 | |
Remi Tricot-Le Breton | dafc068 | 2023-03-13 15:56:34 +0100 | [diff] [blame] | 3481 | $ echo "show ssl ocsp-response base64 /path_to_cert/foo.pem" | socat /var/run/haproxy.sock - |
Remi Tricot-Le Breton | 9c4437d | 2023-02-28 17:46:28 +0100 | [diff] [blame] | 3482 | MIIB8woBAKCCAewwggHoBgkrBgEFBQcwAQEEggHZMIIB1TCBvqE[...] |
| 3483 | |
Remi Tricot-Le Breton | d14fc51 | 2023-02-28 17:46:23 +0100 | [diff] [blame] | 3484 | show ssl ocsp-updates |
| 3485 | Display information about the entries concerned by the OCSP update mechanism. |
| 3486 | The command will output one line per OCSP response and will contain the |
| 3487 | expected update time of the response as well as the time of the last |
| 3488 | successful update and counters of successful and failed updates. It will also |
| 3489 | give the status of the last update (successful or not) in numerical form as |
| 3490 | well as text form. See below for a full list of possible errors. The lines |
| 3491 | will be sorted by ascending 'Next Update' time. The lines will also contain a |
| 3492 | path to the first frontend certificate that uses the OCSP response. |
| 3493 | See "show ssl ocsp-response" command and "ocsp-update" option for more |
| 3494 | information on the OCSP auto update. |
| 3495 | |
| 3496 | The update error codes and error strings can be the following: |
| 3497 | |
| 3498 | +----+-------------------------------------+ |
| 3499 | | ID | message | |
| 3500 | +----+-------------------------------------+ |
| 3501 | | 0 | "Unknown" | |
| 3502 | | 1 | "Update successful" | |
| 3503 | | 2 | "HTTP error" | |
| 3504 | | 3 | "Missing \"ocsp-response\" header" | |
| 3505 | | 4 | "OCSP response check failure" | |
| 3506 | | 5 | "Error during insertion" | |
| 3507 | +----+-------------------------------------+ |
| 3508 | |
| 3509 | Example : |
| 3510 | $ echo "show ssl ocsp-updates" | socat /tmp/haproxy.sock - |
| 3511 | OCSP Certid | Path | Next Update | Last Update | Successes | Failures | Last Update Status | Last Update Status (str) |
| 3512 | 303b300906052b0e03021a050004148a83e0060faff709ca7e9b95522a2e81635fda0a0414f652b0e435d5ea923851508f0adbe92d85de007a02021015 | /path_to_cert/cert.pem | 30/Jan/2023:00:08:09 +0000 | - | 0 | 1 | 2 | HTTP error |
| 3513 | 304b300906052b0e03021a0500041448dac9a0fb2bd32d4ff0de68d2f567b735f9b3c40414142eb317b75856cbae500940e61faf9d8b14c2c6021203e16a7aa01542f291237b454a627fdea9c1 | /path_to_cert/other_cert.pem | 30/Jan/2023:01:07:09 +0000 | 30/Jan/2023:00:07:09 +0000 | 1 | 0 | 1 | Update successful |
| 3514 | |
Remi Tricot-Le Breton | f87c67e | 2022-04-21 12:06:41 +0200 | [diff] [blame] | 3515 | show ssl providers |
| 3516 | Display the names of the providers loaded by OpenSSL during init. Provider |
| 3517 | loading can indeed be configured via the OpenSSL configuration file and this |
| 3518 | option allows to check that the right providers were loaded. This command is |
| 3519 | only available with OpenSSL v3. |
| 3520 | |
| 3521 | Example : |
| 3522 | $ echo "show ssl providers" | socat /var/run/haproxy.master - |
| 3523 | Loaded providers : |
| 3524 | - fips |
| 3525 | - base |
| 3526 | |
William Lallemand | f76b3b4 | 2022-10-14 15:29:07 +0200 | [diff] [blame] | 3527 | show startup-logs |
| 3528 | Dump all messages emitted during the startup of the current haproxy process, |
| 3529 | each startup-logs buffer is unique to its haproxy worker. |
| 3530 | |
William Lallemand | 5d1e131 | 2022-10-14 15:41:55 +0200 | [diff] [blame] | 3531 | This keyword also exists on the master CLI, which shows the latest startup or |
| 3532 | reload tentative. |
| 3533 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3534 | show table |
| 3535 | Dump general information on all known stick-tables. Their name is returned |
| 3536 | (the name of the proxy which holds them), their type (currently zero, always |
| 3537 | IP), their size in maximum possible number of entries, and the number of |
| 3538 | entries currently in use. |
| 3539 | |
| 3540 | Example : |
| 3541 | $ echo "show table" | socat stdio /tmp/sock1 |
| 3542 | >>> # table: front_pub, type: ip, size:204800, used:171454 |
| 3543 | >>> # table: back_rdp, type: ip, size:204800, used:0 |
| 3544 | |
Adis Nezirovic | 1a693fc | 2020-01-16 15:19:29 +0100 | [diff] [blame] | 3545 | show table <name> [ data.<type> <operator> <value> [data.<type> ...]] | [ key <key> ] |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3546 | Dump contents of stick-table <name>. In this mode, a first line of generic |
| 3547 | information about the table is reported as with "show table", then all |
| 3548 | entries are dumped. Since this can be quite heavy, it is possible to specify |
| 3549 | a filter in order to specify what entries to display. |
| 3550 | |
| 3551 | When the "data." form is used the filter applies to the stored data (see |
| 3552 | "stick-table" in section 4.2). A stored data type must be specified |
| 3553 | in <type>, and this data type must be stored in the table otherwise an |
| 3554 | error is reported. The data is compared according to <operator> with the |
| 3555 | 64-bit integer <value>. Operators are the same as with the ACLs : |
| 3556 | |
| 3557 | - eq : match entries whose data is equal to this value |
| 3558 | - ne : match entries whose data is not equal to this value |
| 3559 | - le : match entries whose data is less than or equal to this value |
| 3560 | - ge : match entries whose data is greater than or equal to this value |
| 3561 | - lt : match entries whose data is less than this value |
| 3562 | - gt : match entries whose data is greater than this value |
| 3563 | |
Adis Nezirovic | 1a693fc | 2020-01-16 15:19:29 +0100 | [diff] [blame] | 3564 | In this form, you can use multiple data filter entries, up to a maximum |
| 3565 | defined during build time (4 by default). |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3566 | |
| 3567 | When the key form is used the entry <key> is shown. The key must be of the |
| 3568 | same type as the table, which currently is limited to IPv4, IPv6, integer, |
| 3569 | and string. |
| 3570 | |
| 3571 | Example : |
| 3572 | $ echo "show table http_proxy" | socat stdio /tmp/sock1 |
| 3573 | >>> # table: http_proxy, type: ip, size:204800, used:2 |
| 3574 | >>> 0x80e6a4c: key=127.0.0.1 use=0 exp=3594729 gpc0=0 conn_rate(30000)=1 \ |
| 3575 | bytes_out_rate(60000)=187 |
| 3576 | >>> 0x80e6a80: key=127.0.0.2 use=0 exp=3594740 gpc0=1 conn_rate(30000)=10 \ |
| 3577 | bytes_out_rate(60000)=191 |
| 3578 | |
| 3579 | $ echo "show table http_proxy data.gpc0 gt 0" | socat stdio /tmp/sock1 |
| 3580 | >>> # table: http_proxy, type: ip, size:204800, used:2 |
| 3581 | >>> 0x80e6a80: key=127.0.0.2 use=0 exp=3594740 gpc0=1 conn_rate(30000)=10 \ |
| 3582 | bytes_out_rate(60000)=191 |
| 3583 | |
| 3584 | $ echo "show table http_proxy data.conn_rate gt 5" | \ |
| 3585 | socat stdio /tmp/sock1 |
| 3586 | >>> # table: http_proxy, type: ip, size:204800, used:2 |
| 3587 | >>> 0x80e6a80: key=127.0.0.2 use=0 exp=3594740 gpc0=1 conn_rate(30000)=10 \ |
| 3588 | bytes_out_rate(60000)=191 |
| 3589 | |
| 3590 | $ echo "show table http_proxy key 127.0.0.2" | \ |
| 3591 | socat stdio /tmp/sock1 |
| 3592 | >>> # table: http_proxy, type: ip, size:204800, used:2 |
| 3593 | >>> 0x80e6a80: key=127.0.0.2 use=0 exp=3594740 gpc0=1 conn_rate(30000)=10 \ |
| 3594 | bytes_out_rate(60000)=191 |
| 3595 | |
| 3596 | When the data criterion applies to a dynamic value dependent on time such as |
| 3597 | a bytes rate, the value is dynamically computed during the evaluation of the |
| 3598 | entry in order to decide whether it has to be dumped or not. This means that |
| 3599 | such a filter could match for some time then not match anymore because as |
| 3600 | time goes, the average event rate drops. |
| 3601 | |
| 3602 | It is possible to use this to extract lists of IP addresses abusing the |
| 3603 | service, in order to monitor them or even blacklist them in a firewall. |
| 3604 | Example : |
| 3605 | $ echo "show table http_proxy data.gpc0 gt 0" \ |
| 3606 | | socat stdio /tmp/sock1 \ |
| 3607 | | fgrep 'key=' | cut -d' ' -f2 | cut -d= -f2 > abusers-ip.txt |
| 3608 | ( or | awk '/key/{ print a[split($2,a,"=")]; }' ) |
| 3609 | |
Willy Tarreau | 16b282f | 2022-11-29 11:55:18 +0100 | [diff] [blame] | 3610 | When the stick-table is synchronized to a peers section supporting sharding, |
| 3611 | the shard number will be displayed for each key (otherwise '0' is reported). |
| 3612 | This allows to know which peers will receive this key. |
| 3613 | Example: |
| 3614 | $ echo "show table http_proxy" | socat stdio /tmp/sock1 | fgrep shard= |
| 3615 | 0x7f23b0c822a8: key=10.0.0.2 use=0 exp=296398 shard=9 gpc0=0 |
| 3616 | 0x7f23a063f948: key=10.0.0.6 use=0 exp=296075 shard=12 gpc0=0 |
| 3617 | 0x7f23b03920b8: key=10.0.0.8 use=0 exp=296766 shard=1 gpc0=0 |
| 3618 | 0x7f23a43c09e8: key=10.0.0.12 use=0 exp=295368 shard=8 gpc0=0 |
| 3619 | |
Willy Tarreau | 7eff06e | 2021-01-29 11:32:55 +0100 | [diff] [blame] | 3620 | show tasks |
| 3621 | Dumps the number of tasks currently in the run queue, with the number of |
| 3622 | occurrences for each function, and their average latency when it's known |
| 3623 | (for pure tasks with task profiling enabled). The dump is a snapshot of the |
| 3624 | instant it's done, and there may be variations depending on what tasks are |
| 3625 | left in the queue at the moment it happens, especially in mono-thread mode |
| 3626 | as there's less chance that I/Os can refill the queue (unless the queue is |
| 3627 | full). This command takes exclusive access to the process and can cause |
| 3628 | minor but measurable latencies when issued on a highly loaded process, so |
| 3629 | it must not be abused by monitoring bots. |
| 3630 | |
Willy Tarreau | 4e2b646 | 2019-05-16 17:44:30 +0200 | [diff] [blame] | 3631 | show threads |
| 3632 | Dumps some internal states and structures for each thread, that may be useful |
| 3633 | to help developers understand a problem. The output tries to be readable by |
Willy Tarreau | c7091d8 | 2019-05-17 10:08:49 +0200 | [diff] [blame] | 3634 | showing one block per thread. When haproxy is built with USE_THREAD_DUMP=1, |
| 3635 | an advanced dump mechanism involving thread signals is used so that each |
| 3636 | thread can dump its own state in turn. Without this option, the thread |
| 3637 | processing the command shows all its details but the other ones are less |
Willy Tarreau | e6a02fa | 2019-05-22 07:06:44 +0200 | [diff] [blame] | 3638 | detailed. A star ('*') is displayed in front of the thread handling the |
| 3639 | command. A right angle bracket ('>') may also be displayed in front of |
| 3640 | threads which didn't make any progress since last invocation of this command, |
| 3641 | indicating a bug in the code which must absolutely be reported. When this |
| 3642 | happens between two threads it usually indicates a deadlock. If a thread is |
| 3643 | alone, it's a different bug like a corrupted list. In all cases the process |
| 3644 | needs is not fully functional anymore and needs to be restarted. |
| 3645 | |
| 3646 | The output format is purposely not documented so that it can easily evolve as |
| 3647 | new needs are identified, without having to maintain any form of backwards |
| 3648 | compatibility, and just like with "show activity", the values are meaningless |
| 3649 | without the code at hand. |
Willy Tarreau | 4e2b646 | 2019-05-16 17:44:30 +0200 | [diff] [blame] | 3650 | |
William Lallemand | bb93346 | 2016-05-31 21:09:53 +0200 | [diff] [blame] | 3651 | show tls-keys [id|*] |
| 3652 | Dump all loaded TLS ticket keys references. The TLS ticket key reference ID |
| 3653 | and the file from which the keys have been loaded is shown. Both of those |
| 3654 | can be used to update the TLS keys using "set ssl tls-key". If an ID is |
| 3655 | specified as parameter, it will dump the tickets, using * it will dump every |
| 3656 | keys from every references. |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3657 | |
Simon Horman | 6f6bb38 | 2017-01-04 09:37:26 +0100 | [diff] [blame] | 3658 | show schema json |
| 3659 | Dump the schema used for the output of "show info json" and "show stat json". |
| 3660 | |
| 3661 | The contains no extra whitespace in order to reduce the volume of output. |
| 3662 | For human consumption passing the output through a pretty printer may be |
| 3663 | helpful. Example : |
| 3664 | |
| 3665 | $ echo "show schema json" | socat /var/run/haproxy.sock stdio | \ |
| 3666 | python -m json.tool |
| 3667 | |
| 3668 | The schema follows "JSON Schema" (json-schema.org) and accordingly |
| 3669 | verifiers may be used to verify the output of "show info json" and "show |
| 3670 | stat json" against the schema. |
| 3671 | |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3672 | show trace [<source>] |
| 3673 | Show the current trace status. For each source a line is displayed with a |
| 3674 | single-character status indicating if the trace is stopped, waiting, or |
| 3675 | running. The output sink used by the trace is indicated (or "none" if none |
| 3676 | was set), as well as the number of dropped events in this sink, followed by a |
| 3677 | brief description of the source. If a source name is specified, a detailed |
| 3678 | list of all events supported by the source, and their status for each action |
| 3679 | (report, start, pause, stop), indicated by a "+" if they are enabled, or a |
| 3680 | "-" otherwise. All these events are independent and an event might trigger |
| 3681 | a start without being reported and conversely. |
Simon Horman | 6f6bb38 | 2017-01-04 09:37:26 +0100 | [diff] [blame] | 3682 | |
William Lallemand | 740629e | 2021-12-14 15:22:29 +0100 | [diff] [blame] | 3683 | show version |
| 3684 | Show the version of the current HAProxy process. This is available from |
| 3685 | master and workers CLI. |
| 3686 | Example: |
| 3687 | |
| 3688 | $ echo "show version" | socat /var/run/haproxy.sock stdio |
| 3689 | 2.4.9 |
| 3690 | |
| 3691 | $ echo "show version" | socat /var/run/haproxy-master.sock stdio |
| 3692 | 2.5.0 |
| 3693 | |
Willy Tarreau | 44aed90 | 2015-10-13 14:45:29 +0200 | [diff] [blame] | 3694 | shutdown frontend <frontend> |
| 3695 | Completely delete the specified frontend. All the ports it was bound to will |
| 3696 | be released. It will not be possible to enable the frontend anymore after |
| 3697 | this operation. This is intended to be used in environments where stopping a |
| 3698 | proxy is not even imaginable but a misconfigured proxy must be fixed. That |
| 3699 | way it's possible to release the port and bind it into another process to |
| 3700 | restore operations. The frontend will not appear at all on the stats page |
| 3701 | once it is terminated. |
| 3702 | |
| 3703 | The frontend may be specified either by its name or by its numeric ID, |
| 3704 | prefixed with a sharp ('#'). |
| 3705 | |
| 3706 | This command is restricted and can only be issued on sockets configured for |
| 3707 | level "admin". |
| 3708 | |
| 3709 | shutdown session <id> |
| 3710 | Immediately terminate the session matching the specified session identifier. |
| 3711 | This identifier is the first field at the beginning of the lines in the dumps |
| 3712 | of "show sess" (it corresponds to the session pointer). This can be used to |
| 3713 | terminate a long-running session without waiting for a timeout or when an |
| 3714 | endless transfer is ongoing. Such terminated sessions are reported with a 'K' |
| 3715 | flag in the logs. |
| 3716 | |
| 3717 | shutdown sessions server <backend>/<server> |
| 3718 | Immediately terminate all the sessions attached to the specified server. This |
| 3719 | can be used to terminate long-running sessions after a server is put into |
| 3720 | maintenance mode, for instance. Such terminated sessions are reported with a |
| 3721 | 'K' flag in the logs. |
| 3722 | |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3723 | trace |
| 3724 | The "trace" command alone lists the trace sources, their current status, and |
| 3725 | their brief descriptions. It is only meant as a menu to enter next levels, |
| 3726 | see other "trace" commands below. |
| 3727 | |
| 3728 | trace 0 |
| 3729 | Immediately stops all traces. This is made to be used as a quick solution |
| 3730 | to terminate a debugging session or as an emergency action to be used in case |
| 3731 | complex traces were enabled on multiple sources and impact the service. |
| 3732 | |
| 3733 | trace <source> event [ [+|-|!]<name> ] |
| 3734 | Without argument, this will list all the events supported by the designated |
| 3735 | source. They are prefixed with a "-" if they are not enabled, or a "+" if |
| 3736 | they are enabled. It is important to note that a single trace may be labelled |
| 3737 | with multiple events, and as long as any of the enabled events matches one of |
| 3738 | the events labelled on the trace, the event will be passed to the trace |
| 3739 | subsystem. For example, receiving an HTTP/2 frame of type HEADERS may trigger |
| 3740 | a frame event and a stream event since the frame creates a new stream. If |
| 3741 | either the frame event or the stream event are enabled for this source, the |
| 3742 | frame will be passed to the trace framework. |
| 3743 | |
| 3744 | With an argument, it is possible to toggle the state of each event and |
| 3745 | individually enable or disable them. Two special keywords are supported, |
| 3746 | "none", which matches no event, and is used to disable all events at once, |
| 3747 | and "any" which matches all events, and is used to enable all events at |
| 3748 | once. Other events are specific to the event source. It is possible to |
| 3749 | enable one event by specifying its name, optionally prefixed with '+' for |
| 3750 | better readability. It is possible to disable one event by specifying its |
| 3751 | name prefixed by a '-' or a '!'. |
| 3752 | |
| 3753 | One way to completely disable a trace source is to pass "event none", and |
| 3754 | this source will instantly be totally ignored. |
| 3755 | |
| 3756 | trace <source> level [<level>] |
Willy Tarreau | 2ea549b | 2019-08-29 08:01:48 +0200 | [diff] [blame] | 3757 | Without argument, this will list all trace levels for this source, and the |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3758 | current one will be indicated by a star ('*') prepended in front of it. With |
Willy Tarreau | 2ea549b | 2019-08-29 08:01:48 +0200 | [diff] [blame] | 3759 | an argument, this will change the trace level to the specified level. Detail |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3760 | levels are a form of filters that are applied before reporting the events. |
Willy Tarreau | 2ea549b | 2019-08-29 08:01:48 +0200 | [diff] [blame] | 3761 | These filters are used to selectively include or exclude events depending on |
| 3762 | their level of importance. For example a developer might need to know |
| 3763 | precisely where in the code an HTTP header was considered invalid while the |
| 3764 | end user may not even care about this header's validity at all. There are |
| 3765 | currently 5 distinct levels for a trace : |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3766 | |
| 3767 | user this will report information that are suitable for use by a |
| 3768 | regular haproxy user who wants to observe his traffic. |
| 3769 | Typically some HTTP requests and responses will be reported |
| 3770 | without much detail. Most sources will set this as the |
| 3771 | default level to ease operations. |
| 3772 | |
Willy Tarreau | 2ea549b | 2019-08-29 08:01:48 +0200 | [diff] [blame] | 3773 | proto in addition to what is reported at the "user" level, it also |
| 3774 | displays protocol-level updates. This can for example be the |
| 3775 | frame types or HTTP headers after decoding. |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3776 | |
| 3777 | state in addition to what is reported at the "proto" level, it |
| 3778 | will also display state transitions (or failed transitions) |
| 3779 | which happen in parsers, so this will show attempts to |
| 3780 | perform an operation while the "proto" level only shows |
| 3781 | the final operation. |
| 3782 | |
Willy Tarreau | 2ea549b | 2019-08-29 08:01:48 +0200 | [diff] [blame] | 3783 | data in addition to what is reported at the "state" level, it |
| 3784 | will also include data transfers between the various layers. |
| 3785 | |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3786 | developer it reports everything available, which can include advanced |
| 3787 | information such as "breaking out of this loop" that are |
| 3788 | only relevant to a developer trying to understand a bug that |
Willy Tarreau | 09fb0df | 2019-08-29 08:40:59 +0200 | [diff] [blame] | 3789 | only happens once in a while in field. Function names are |
| 3790 | only reported at this level. |
Willy Tarreau | f909c91 | 2019-08-22 20:06:04 +0200 | [diff] [blame] | 3791 | |
| 3792 | It is highly recommended to always use the "user" level only and switch to |
| 3793 | other levels only if instructed to do so by a developer. Also it is a good |
| 3794 | idea to first configure the events before switching to higher levels, as it |
| 3795 | may save from dumping many lines if no filter is applied. |
| 3796 | |
| 3797 | trace <source> lock [criterion] |
| 3798 | Without argument, this will list all the criteria supported by this source |
| 3799 | for lock-on processing, and display the current choice by a star ('*') in |
| 3800 | front of it. Lock-on means that the source will focus on the first matching |
| 3801 | event and only stick to the criterion which triggered this event, and ignore |
| 3802 | all other ones until the trace stops. This allows for example to take a trace |
| 3803 | on a single connection or on a single stream. The following criteria are |
| 3804 | supported by some traces, though not necessarily all, since some of them |
| 3805 | might not be available to the source : |
| 3806 | |
| 3807 | backend lock on the backend that started the trace |
| 3808 | connection lock on the connection that started the trace |
| 3809 | frontend lock on the frontend that started the trace |
| 3810 | listener lock on the listener that started the trace |
| 3811 | nothing do not lock on anything |
| 3812 | server lock on the server that started the trace |
| 3813 | session lock on the session that started the trace |
| 3814 | thread lock on the thread that started the trace |
| 3815 | |
| 3816 | In addition to this, each source may provide up to 4 specific criteria such |
| 3817 | as internal states or connection IDs. For example in HTTP/2 it is possible |
| 3818 | to lock on the H2 stream and ignore other streams once a strace starts. |
| 3819 | |
| 3820 | When a criterion is passed in argument, this one is used instead of the |
| 3821 | other ones and any existing tracking is immediately terminated so that it can |
| 3822 | restart with the new criterion. The special keyword "nothing" is supported by |
| 3823 | all sources to permanently disable tracking. |
| 3824 | |
| 3825 | trace <source> { pause | start | stop } [ [+|-|!]event] |
| 3826 | Without argument, this will list the events enabled to automatically pause, |
| 3827 | start, or stop a trace for this source. These events are specific to each |
| 3828 | trace source. With an argument, this will either enable the event for the |
| 3829 | specified action (if optionally prefixed by a '+') or disable it (if |
| 3830 | prefixed by a '-' or '!'). The special keyword "now" is not an event and |
| 3831 | requests to take the action immediately. The keywords "none" and "any" are |
| 3832 | supported just like in "trace event". |
| 3833 | |
| 3834 | The 3 supported actions are respectively "pause", "start" and "stop". The |
| 3835 | "pause" action enumerates events which will cause a running trace to stop and |
| 3836 | wait for a new start event to restart it. The "start" action enumerates the |
| 3837 | events which switch the trace into the waiting mode until one of the start |
| 3838 | events appears. And the "stop" action enumerates the events which definitely |
| 3839 | stop the trace until it is manually enabled again. In practice it makes sense |
| 3840 | to manually start a trace using "start now" without caring about events, and |
| 3841 | to stop it using "stop now". In order to capture more subtle event sequences, |
| 3842 | setting "start" to a normal event (like receiving an HTTP request) and "stop" |
| 3843 | to a very rare event like emitting a certain error, will ensure that the last |
| 3844 | captured events will match the desired criteria. And the pause event is |
| 3845 | useful to detect the end of a sequence, disable the lock-on and wait for |
| 3846 | another opportunity to take a capture. In this case it can make sense to |
| 3847 | enable lock-on to spot only one specific criterion (e.g. a stream), and have |
| 3848 | "start" set to anything that starts this criterion (e.g. all events which |
| 3849 | create a stream), "stop" set to the expected anomaly, and "pause" to anything |
| 3850 | that ends that criterion (e.g. any end of stream event). In this case the |
| 3851 | trace log will contain complete sequences of perfectly clean series affecting |
| 3852 | a single object, until the last sequence containing everything from the |
| 3853 | beginning to the anomaly. |
| 3854 | |
| 3855 | trace <source> sink [<sink>] |
| 3856 | Without argument, this will list all event sinks available for this source, |
| 3857 | and the currently configured one will have a star ('*') prepended in front |
| 3858 | of it. Sink "none" is always available and means that all events are simply |
| 3859 | dropped, though their processing is not ignored (e.g. lock-on does occur). |
| 3860 | Other sinks are available depending on configuration and build options, but |
| 3861 | typically "stdout" and "stderr" will be usable in debug mode, and in-memory |
| 3862 | ring buffers should be available as well. When a name is specified, the sink |
| 3863 | instantly changes for the specified source. Events are not changed during a |
| 3864 | sink change. In the worst case some may be lost if an invalid sink is used |
| 3865 | (or "none"), but operations do continue to a different destination. |
| 3866 | |
Willy Tarreau | 370a694 | 2019-08-29 08:24:16 +0200 | [diff] [blame] | 3867 | trace <source> verbosity [<level>] |
| 3868 | Without argument, this will list all verbosity levels for this source, and the |
| 3869 | current one will be indicated by a star ('*') prepended in front of it. With |
| 3870 | an argument, this will change the verbosity level to the specified one. |
| 3871 | |
| 3872 | Verbosity levels indicate how far the trace decoder should go to provide |
| 3873 | detailed information. It depends on the trace source, since some sources will |
| 3874 | not even provide a specific decoder. Level "quiet" is always available and |
| 3875 | disables any decoding. It can be useful when trying to figure what's |
| 3876 | happening before trying to understand the details, since it will have a very |
| 3877 | low impact on performance and trace size. When no verbosity levels are |
| 3878 | declared by a source, level "default" is available and will cause a decoder |
| 3879 | to be called when specified in the traces. It is an opportunistic decoding. |
| 3880 | When the source declares some verbosity levels, these ones are listed with |
| 3881 | a description of what they correspond to. In this case the trace decoder |
| 3882 | provided by the source will be as accurate as possible based on the |
| 3883 | information available at the trace point. The first level above "quiet" is |
| 3884 | set by default. |
| 3885 | |
Remi Tricot-Le Breton | eeaa29b | 2022-12-20 11:11:07 +0100 | [diff] [blame] | 3886 | update ssl ocsp-response <certfile> |
| 3887 | Create an OCSP request for the specified <certfile> and send it to the OCSP |
| 3888 | responder whose URI should be specified in the "Authority Information Access" |
| 3889 | section of the certificate. Only the first URI is taken into account. The |
| 3890 | OCSP response that we should receive in return is then checked and inserted |
| 3891 | in the local OCSP response tree. This command will only work for certificates |
| 3892 | that already had a stored OCSP response, either because it was provided |
| 3893 | during init or if it was previously set through the "set ssl cert" or "set |
| 3894 | ssl ocsp-response" commands. |
| 3895 | If the received OCSP response is valid and was properly inserted into the |
| 3896 | local tree, its contents will be displayed on the standard output. The format |
| 3897 | is the same as the one described in "show ssl ocsp-response". |
| 3898 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 3899 | |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3900 | 9.4. Master CLI |
| 3901 | --------------- |
| 3902 | |
| 3903 | The master CLI is a socket bound to the master process in master-worker mode. |
| 3904 | This CLI gives access to the unix socket commands in every running or leaving |
| 3905 | processes and allows a basic supervision of those processes. |
| 3906 | |
| 3907 | The master CLI is configurable only from the haproxy program arguments with |
| 3908 | the -S option. This option also takes bind options separated by commas. |
| 3909 | |
| 3910 | Example: |
| 3911 | |
| 3912 | # haproxy -W -S 127.0.0.1:1234 -f test1.cfg |
| 3913 | # haproxy -Ws -S /tmp/master-socket,uid,1000,gid,1000,mode,600 -f test1.cfg |
William Lallemand | b7ea141 | 2018-12-13 09:05:47 +0100 | [diff] [blame] | 3914 | # haproxy -W -S /tmp/master-socket,level,user -f test1.cfg |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3915 | |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3916 | |
William Lallemand | a662275 | 2022-03-31 15:26:51 +0200 | [diff] [blame] | 3917 | 9.4.1. Master CLI commands |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3918 | -------------------------- |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3919 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3920 | @<[!]pid> |
| 3921 | The master CLI uses a special prefix notation to access the multiple |
| 3922 | processes. This notation is easily identifiable as it begins by a @. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3923 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3924 | A @ prefix can be followed by a relative process number or by an exclamation |
| 3925 | point and a PID. (e.g. @1 or @!1271). A @ alone could be use to specify the |
| 3926 | master. Leaving processes are only accessible with the PID as relative process |
| 3927 | number are only usable with the current processes. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3928 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3929 | Examples: |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3930 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3931 | $ socat /var/run/haproxy-master.sock readline |
| 3932 | prompt |
| 3933 | master> @1 show info; @2 show info |
| 3934 | [...] |
| 3935 | Process_num: 1 |
| 3936 | Pid: 1271 |
| 3937 | [...] |
| 3938 | Process_num: 2 |
| 3939 | Pid: 1272 |
| 3940 | [...] |
| 3941 | master> |
Willy Tarreau | 52880f9 | 2018-12-15 13:30:03 +0100 | [diff] [blame] | 3942 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3943 | $ echo '@!1271 show info; @!1272 show info' | socat /var/run/haproxy-master.sock - |
| 3944 | [...] |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3945 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3946 | A prefix could be use as a command, which will send every next commands to |
| 3947 | the specified process. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3948 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3949 | Examples: |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3950 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3951 | $ socat /var/run/haproxy-master.sock readline |
| 3952 | prompt |
| 3953 | master> @1 |
| 3954 | 1271> show info |
| 3955 | [...] |
| 3956 | 1271> show stat |
| 3957 | [...] |
| 3958 | 1271> @ |
| 3959 | master> |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3960 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3961 | $ echo '@1; show info; show stat; @2; show info; show stat' | socat /var/run/haproxy-master.sock - |
| 3962 | [...] |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3963 | |
William Lallemand | a5ce28b | 2022-02-02 15:29:21 +0100 | [diff] [blame] | 3964 | expert-mode [on|off] |
| 3965 | This command activates the "expert-mode" for every worker accessed from the |
William Lallemand | 2a17191 | 2022-02-02 11:43:20 +0100 | [diff] [blame] | 3966 | master CLI. Combined with "mcli-debug-mode" it also activates the command on |
William Lallemand | dae12c7 | 2022-02-02 14:13:54 +0100 | [diff] [blame] | 3967 | the master. Display the flag "e" in the master CLI prompt. |
William Lallemand | a5ce28b | 2022-02-02 15:29:21 +0100 | [diff] [blame] | 3968 | |
William Lallemand | 2a17191 | 2022-02-02 11:43:20 +0100 | [diff] [blame] | 3969 | See also "expert-mode" in Section 9.3 and "mcli-debug-mode" in 9.4.1. |
William Lallemand | a5ce28b | 2022-02-02 15:29:21 +0100 | [diff] [blame] | 3970 | |
| 3971 | experimental-mode [on|off] |
| 3972 | This command activates the "experimental-mode" for every worker accessed from |
William Lallemand | 2a17191 | 2022-02-02 11:43:20 +0100 | [diff] [blame] | 3973 | the master CLI. Combined with "mcli-debug-mode" it also activates the command on |
William Lallemand | dae12c7 | 2022-02-02 14:13:54 +0100 | [diff] [blame] | 3974 | the master. Display the flag "x" in the master CLI prompt. |
William Lallemand | 2a17191 | 2022-02-02 11:43:20 +0100 | [diff] [blame] | 3975 | |
| 3976 | See also "experimental-mode" in Section 9.3 and "mcli-debug-mode" in 9.4.1. |
William Lallemand | a5ce28b | 2022-02-02 15:29:21 +0100 | [diff] [blame] | 3977 | |
William Lallemand | 2a17191 | 2022-02-02 11:43:20 +0100 | [diff] [blame] | 3978 | mcli-debug-mode [on|off] |
| 3979 | This keyword allows a special mode in the master CLI which enables every |
| 3980 | keywords that were meant for a worker CLI on the master CLI, allowing to debug |
| 3981 | the master process. Once activated, you list the new available keywords with |
| 3982 | "help". Combined with "experimental-mode" or "expert-mode" it enables even |
William Lallemand | dae12c7 | 2022-02-02 14:13:54 +0100 | [diff] [blame] | 3983 | more keywords. Display the flag "d" in the master CLI prompt. |
William Lallemand | a5ce28b | 2022-02-02 15:29:21 +0100 | [diff] [blame] | 3984 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 3985 | prompt |
| 3986 | When the prompt is enabled (via the "prompt" command), the context the CLI is |
| 3987 | working on is displayed in the prompt. The master is identified by the "master" |
| 3988 | string, and other processes are identified with their PID. In case the last |
| 3989 | reload failed, the master prompt will be changed to "master[ReloadFailed]>" so |
| 3990 | that it becomes visible that the process is still running on the previous |
| 3991 | configuration and that the new configuration is not operational. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 3992 | |
William Lallemand | dae12c7 | 2022-02-02 14:13:54 +0100 | [diff] [blame] | 3993 | The prompt of the master CLI is able to display several flags which are the |
| 3994 | enable modes. "d" for mcli-debug-mode, "e" for expert-mode, "x" for |
| 3995 | experimental-mode. |
| 3996 | |
| 3997 | Example: |
| 3998 | $ socat /var/run/haproxy-master.sock - |
| 3999 | prompt |
| 4000 | master> expert-mode on |
| 4001 | master(e)> experimental-mode on |
| 4002 | master(xe)> mcli-debug-mode on |
| 4003 | master(xed)> @1 |
| 4004 | 95191(xed)> |
| 4005 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 4006 | reload |
| 4007 | You can also reload the HAProxy master process with the "reload" command which |
| 4008 | does the same as a `kill -USR2` on the master process, provided that the user |
| 4009 | has at least "operator" or "admin" privileges. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 4010 | |
William Lallemand | 70c5ad4 | 2022-09-24 16:44:44 +0200 | [diff] [blame] | 4011 | This command allows you to perform a synchronous reload, the command will |
| 4012 | return a reload status, once the reload was performed. Be careful with the |
| 4013 | timeout if a tool is used to parse it, it is only returned once the |
William Lallemand | bb650f2 | 2022-09-27 11:38:10 +0200 | [diff] [blame] | 4014 | configuration is parsed and the new worker is forked. The "socat" command uses |
| 4015 | a timeout of 0.5s by default so it will quits before showing the message if |
| 4016 | the reload is too long. "ncat" does not have a timeout by default. |
William Lallemand | ef3e5a1 | 2022-10-13 18:14:55 +0200 | [diff] [blame] | 4017 | When compiled with USE_SHM_OPEN=1, the reload command is also able to dump |
| 4018 | the startup-logs of the master. |
William Lallemand | 70c5ad4 | 2022-09-24 16:44:44 +0200 | [diff] [blame] | 4019 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 4020 | Example: |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 4021 | |
William Lallemand | bb650f2 | 2022-09-27 11:38:10 +0200 | [diff] [blame] | 4022 | $ echo "reload" | socat -t300 /var/run/haproxy-master.sock stdin |
William Lallemand | ef3e5a1 | 2022-10-13 18:14:55 +0200 | [diff] [blame] | 4023 | Success=1 |
| 4024 | -- |
| 4025 | [NOTICE] (482713) : haproxy version is 2.7-dev7-4827fb-69 |
| 4026 | [NOTICE] (482713) : path to executable is ./haproxy |
| 4027 | [WARNING] (482713) : config : 'http-request' rules ignored for proxy 'frt1' as they require HTTP mode. |
| 4028 | [NOTICE] (482713) : New worker (482720) forked |
| 4029 | [NOTICE] (482713) : Loading success. |
William Lallemand | 70c5ad4 | 2022-09-24 16:44:44 +0200 | [diff] [blame] | 4030 | |
William Lallemand | bb650f2 | 2022-09-27 11:38:10 +0200 | [diff] [blame] | 4031 | $ echo "reload" | socat -t300 /var/run/haproxy-master.sock stdin |
William Lallemand | ef3e5a1 | 2022-10-13 18:14:55 +0200 | [diff] [blame] | 4032 | Success=0 |
| 4033 | -- |
| 4034 | [NOTICE] (482886) : haproxy version is 2.7-dev7-4827fb-69 |
| 4035 | [NOTICE] (482886) : path to executable is ./haproxy |
| 4036 | [ALERT] (482886) : config : parsing [test3.cfg:1]: unknown keyword 'Aglobal' out of section. |
| 4037 | [ALERT] (482886) : config : Fatal errors found in configuration. |
| 4038 | [WARNING] (482886) : Loading failure! |
| 4039 | |
| 4040 | $ |
William Lallemand | 70c5ad4 | 2022-09-24 16:44:44 +0200 | [diff] [blame] | 4041 | |
| 4042 | The reload command is the last executed on the master CLI, every other |
| 4043 | command after it are ignored. Once the reload command returns its status, it |
| 4044 | will close the connection to the CLI. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 4045 | |
William Lallemand | 70c5ad4 | 2022-09-24 16:44:44 +0200 | [diff] [blame] | 4046 | Note that a reload will close all connections to the master CLI. |
William Lallemand | a57b7e3 | 2018-12-14 21:11:31 +0100 | [diff] [blame] | 4047 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 4048 | show proc |
| 4049 | The master CLI introduces a 'show proc' command to surpervise the |
| 4050 | processe. |
William Lallemand | a57b7e3 | 2018-12-14 21:11:31 +0100 | [diff] [blame] | 4051 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 4052 | Example: |
William Lallemand | a57b7e3 | 2018-12-14 21:11:31 +0100 | [diff] [blame] | 4053 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 4054 | $ echo 'show proc' | socat /var/run/haproxy-master.sock - |
| 4055 | #<PID> <type> <reloads> <uptime> <version> |
| 4056 | 1162 master 5 [failed: 0] 0d00h02m07s 2.5-dev13 |
| 4057 | # workers |
| 4058 | 1271 worker 1 0d00h00m00s 2.5-dev13 |
| 4059 | # old workers |
| 4060 | 1233 worker 3 0d00h00m43s 2.0-dev3-6019f6-289 |
| 4061 | # programs |
| 4062 | 1244 foo 0 0d00h00m00s - |
| 4063 | 1255 bar 0 0d00h00m00s - |
William Lallemand | a57b7e3 | 2018-12-14 21:11:31 +0100 | [diff] [blame] | 4064 | |
William Lallemand | af140ab | 2022-02-02 14:44:19 +0100 | [diff] [blame] | 4065 | In this example, the master has been reloaded 5 times but one of the old |
| 4066 | worker is still running and survived 3 reloads. You could access the CLI of |
| 4067 | this worker to understand what's going on. |
William Lallemand | 142db37 | 2018-12-11 18:56:45 +0100 | [diff] [blame] | 4068 | |
William Lallemand | 5d1e131 | 2022-10-14 15:41:55 +0200 | [diff] [blame] | 4069 | show startup-logs |
| 4070 | HAProxy needs to be compiled with USE_SHM_OPEN=1 to be used correctly on the |
| 4071 | master CLI or all messages won't be visible. |
| 4072 | |
| 4073 | Like its counterpart on the stats socket, this command is able to show the |
| 4074 | startup messages of HAProxy. However it does not dump the startup messages |
| 4075 | of the current worker, but the startup messages of the latest startup or |
| 4076 | reload, which means it is able to dump the parsing messages of a failed |
| 4077 | reload. |
| 4078 | |
| 4079 | Those messages are also dumped with the "reload" command. |
| 4080 | |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4081 | 10. Tricks for easier configuration management |
| 4082 | ---------------------------------------------- |
| 4083 | |
| 4084 | It is very common that two HAProxy nodes constituting a cluster share exactly |
| 4085 | the same configuration modulo a few addresses. Instead of having to maintain a |
| 4086 | duplicate configuration for each node, which will inevitably diverge, it is |
| 4087 | possible to include environment variables in the configuration. Thus multiple |
| 4088 | configuration may share the exact same file with only a few different system |
| 4089 | wide environment variables. This started in version 1.5 where only addresses |
| 4090 | were allowed to include environment variables, and 1.6 goes further by |
| 4091 | supporting environment variables everywhere. The syntax is the same as in the |
| 4092 | UNIX shell, a variable starts with a dollar sign ('$'), followed by an opening |
| 4093 | curly brace ('{'), then the variable name followed by the closing brace ('}'). |
| 4094 | Except for addresses, environment variables are only interpreted in arguments |
| 4095 | surrounded with double quotes (this was necessary not to break existing setups |
| 4096 | using regular expressions involving the dollar symbol). |
| 4097 | |
| 4098 | Environment variables also make it convenient to write configurations which are |
| 4099 | expected to work on various sites where only the address changes. It can also |
| 4100 | permit to remove passwords from some configs. Example below where the the file |
| 4101 | "site1.env" file is sourced by the init script upon startup : |
| 4102 | |
| 4103 | $ cat site1.env |
| 4104 | LISTEN=192.168.1.1 |
| 4105 | CACHE_PFX=192.168.11 |
| 4106 | SERVER_PFX=192.168.22 |
| 4107 | LOGGER=192.168.33.1 |
| 4108 | STATSLP=admin:pa$$w0rd |
| 4109 | ABUSERS=/etc/haproxy/abuse.lst |
| 4110 | TIMEOUT=10s |
| 4111 | |
| 4112 | $ cat haproxy.cfg |
| 4113 | global |
| 4114 | log "${LOGGER}:514" local0 |
| 4115 | |
| 4116 | defaults |
| 4117 | mode http |
| 4118 | timeout client "${TIMEOUT}" |
| 4119 | timeout server "${TIMEOUT}" |
| 4120 | timeout connect 5s |
| 4121 | |
| 4122 | frontend public |
| 4123 | bind "${LISTEN}:80" |
| 4124 | http-request reject if { src -f "${ABUSERS}" } |
| 4125 | stats uri /stats |
| 4126 | stats auth "${STATSLP}" |
| 4127 | use_backend cache if { path_end .jpg .css .ico } |
| 4128 | default_backend server |
| 4129 | |
| 4130 | backend cache |
| 4131 | server cache1 "${CACHE_PFX}.1:18080" check |
| 4132 | server cache2 "${CACHE_PFX}.2:18080" check |
| 4133 | |
| 4134 | backend server |
| 4135 | server cache1 "${SERVER_PFX}.1:8080" check |
| 4136 | server cache2 "${SERVER_PFX}.2:8080" check |
| 4137 | |
| 4138 | |
| 4139 | 11. Well-known traps to avoid |
| 4140 | ----------------------------- |
| 4141 | |
| 4142 | Once in a while, someone reports that after a system reboot, the haproxy |
| 4143 | service wasn't started, and that once they start it by hand it works. Most |
| 4144 | often, these people are running a clustered IP address mechanism such as |
| 4145 | keepalived, to assign the service IP address to the master node only, and while |
| 4146 | it used to work when they used to bind haproxy to address 0.0.0.0, it stopped |
| 4147 | working after they bound it to the virtual IP address. What happens here is |
| 4148 | that when the service starts, the virtual IP address is not yet owned by the |
| 4149 | local node, so when HAProxy wants to bind to it, the system rejects this |
| 4150 | because it is not a local IP address. The fix doesn't consist in delaying the |
| 4151 | haproxy service startup (since it wouldn't stand a restart), but instead to |
| 4152 | properly configure the system to allow binding to non-local addresses. This is |
| 4153 | easily done on Linux by setting the net.ipv4.ip_nonlocal_bind sysctl to 1. This |
| 4154 | is also needed in order to transparently intercept the IP traffic that passes |
| 4155 | through HAProxy for a specific target address. |
| 4156 | |
| 4157 | Multi-process configurations involving source port ranges may apparently seem |
| 4158 | to work but they will cause some random failures under high loads because more |
| 4159 | than one process may try to use the same source port to connect to the same |
| 4160 | server, which is not possible. The system will report an error and a retry will |
| 4161 | happen, picking another port. A high value in the "retries" parameter may hide |
| 4162 | the effect to a certain extent but this also comes with increased CPU usage and |
| 4163 | processing time. Logs will also report a certain number of retries. For this |
| 4164 | reason, port ranges should be avoided in multi-process configurations. |
| 4165 | |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4166 | Since HAProxy uses SO_REUSEPORT and supports having multiple independent |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4167 | processes bound to the same IP:port, during troubleshooting it can happen that |
| 4168 | an old process was not stopped before a new one was started. This provides |
| 4169 | absurd test results which tend to indicate that any change to the configuration |
| 4170 | is ignored. The reason is that in fact even the new process is restarted with a |
| 4171 | new configuration, the old one also gets some incoming connections and |
| 4172 | processes them, returning unexpected results. When in doubt, just stop the new |
| 4173 | process and try again. If it still works, it very likely means that an old |
| 4174 | process remains alive and has to be stopped. Linux's "netstat -lntp" is of good |
| 4175 | help here. |
| 4176 | |
| 4177 | When adding entries to an ACL from the command line (eg: when blacklisting a |
| 4178 | source address), it is important to keep in mind that these entries are not |
| 4179 | synchronized to the file and that if someone reloads the configuration, these |
| 4180 | updates will be lost. While this is often the desired effect (for blacklisting) |
| 4181 | it may not necessarily match expectations when the change was made as a fix for |
| 4182 | a problem. See the "add acl" action of the CLI interface. |
| 4183 | |
| 4184 | |
| 4185 | 12. Debugging and performance issues |
| 4186 | ------------------------------------ |
| 4187 | |
| 4188 | When HAProxy is started with the "-d" option, it will stay in the foreground |
| 4189 | and will print one line per event, such as an incoming connection, the end of a |
| 4190 | connection, and for each request or response header line seen. This debug |
| 4191 | output is emitted before the contents are processed, so they don't consider the |
| 4192 | local modifications. The main use is to show the request and response without |
| 4193 | having to run a network sniffer. The output is less readable when multiple |
| 4194 | connections are handled in parallel, though the "debug2ansi" and "debug2html" |
| 4195 | scripts found in the examples/ directory definitely help here by coloring the |
| 4196 | output. |
| 4197 | |
| 4198 | If a request or response is rejected because HAProxy finds it is malformed, the |
| 4199 | best thing to do is to connect to the CLI and issue "show errors", which will |
| 4200 | report the last captured faulty request and response for each frontend and |
| 4201 | backend, with all the necessary information to indicate precisely the first |
| 4202 | character of the input stream that was rejected. This is sometimes needed to |
| 4203 | prove to customers or to developers that a bug is present in their code. In |
| 4204 | this case it is often possible to relax the checks (but still keep the |
| 4205 | captures) using "option accept-invalid-http-request" or its equivalent for |
| 4206 | responses coming from the server "option accept-invalid-http-response". Please |
| 4207 | see the configuration manual for more details. |
| 4208 | |
| 4209 | Example : |
| 4210 | |
| 4211 | > show errors |
| 4212 | Total events captured on [13/Oct/2015:13:43:47.169] : 1 |
| 4213 | |
| 4214 | [13/Oct/2015:13:43:40.918] frontend HAProxyLocalStats (#2): invalid request |
| 4215 | backend <NONE> (#-1), server <NONE> (#-1), event #0 |
| 4216 | src 127.0.0.1:51981, session #0, session flags 0x00000080 |
| 4217 | HTTP msg state 26, msg flags 0x00000000, tx flags 0x00000000 |
| 4218 | HTTP chunk len 0 bytes, HTTP body len 0 bytes |
| 4219 | buffer flags 0x00808002, out 0 bytes, total 31 bytes |
| 4220 | pending 31 bytes, wrapping at 8040, error at position 13: |
| 4221 | |
| 4222 | 00000 GET /invalid request HTTP/1.1\r\n |
| 4223 | |
| 4224 | |
| 4225 | The output of "show info" on the CLI provides a number of useful information |
| 4226 | regarding the maximum connection rate ever reached, maximum SSL key rate ever |
| 4227 | reached, and in general all information which can help to explain temporary |
| 4228 | issues regarding CPU or memory usage. Example : |
| 4229 | |
| 4230 | > show info |
| 4231 | Name: HAProxy |
| 4232 | Version: 1.6-dev7-e32d18-17 |
| 4233 | Release_date: 2015/10/12 |
| 4234 | Nbproc: 1 |
| 4235 | Process_num: 1 |
| 4236 | Pid: 7949 |
| 4237 | Uptime: 0d 0h02m39s |
| 4238 | Uptime_sec: 159 |
| 4239 | Memmax_MB: 0 |
| 4240 | Ulimit-n: 120032 |
| 4241 | Maxsock: 120032 |
| 4242 | Maxconn: 60000 |
| 4243 | Hard_maxconn: 60000 |
| 4244 | CurrConns: 0 |
| 4245 | CumConns: 3 |
| 4246 | CumReq: 3 |
| 4247 | MaxSslConns: 0 |
| 4248 | CurrSslConns: 0 |
| 4249 | CumSslConns: 0 |
| 4250 | Maxpipes: 0 |
| 4251 | PipesUsed: 0 |
| 4252 | PipesFree: 0 |
| 4253 | ConnRate: 0 |
| 4254 | ConnRateLimit: 0 |
| 4255 | MaxConnRate: 1 |
| 4256 | SessRate: 0 |
| 4257 | SessRateLimit: 0 |
| 4258 | MaxSessRate: 1 |
| 4259 | SslRate: 0 |
| 4260 | SslRateLimit: 0 |
| 4261 | MaxSslRate: 0 |
| 4262 | SslFrontendKeyRate: 0 |
| 4263 | SslFrontendMaxKeyRate: 0 |
| 4264 | SslFrontendSessionReuse_pct: 0 |
| 4265 | SslBackendKeyRate: 0 |
| 4266 | SslBackendMaxKeyRate: 0 |
| 4267 | SslCacheLookups: 0 |
| 4268 | SslCacheMisses: 0 |
| 4269 | CompressBpsIn: 0 |
| 4270 | CompressBpsOut: 0 |
| 4271 | CompressBpsRateLim: 0 |
| 4272 | ZlibMemUsage: 0 |
| 4273 | MaxZlibMemUsage: 0 |
| 4274 | Tasks: 5 |
| 4275 | Run_queue: 1 |
| 4276 | Idle_pct: 100 |
| 4277 | node: wtap |
| 4278 | description: |
| 4279 | |
| 4280 | When an issue seems to randomly appear on a new version of HAProxy (eg: every |
| 4281 | second request is aborted, occasional crash, etc), it is worth trying to enable |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4282 | memory poisoning so that each call to malloc() is immediately followed by the |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4283 | filling of the memory area with a configurable byte. By default this byte is |
| 4284 | 0x50 (ASCII for 'P'), but any other byte can be used, including zero (which |
| 4285 | will have the same effect as a calloc() and which may make issues disappear). |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4286 | Memory poisoning is enabled on the command line using the "-dM" option. It |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4287 | slightly hurts performance and is not recommended for use in production. If |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4288 | an issue happens all the time with it or never happens when poisoning uses |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4289 | byte zero, it clearly means you've found a bug and you definitely need to |
| 4290 | report it. Otherwise if there's no clear change, the problem it is not related. |
| 4291 | |
| 4292 | When debugging some latency issues, it is important to use both strace and |
| 4293 | tcpdump on the local machine, and another tcpdump on the remote system. The |
| 4294 | reason for this is that there are delays everywhere in the processing chain and |
| 4295 | it is important to know which one is causing latency to know where to act. In |
| 4296 | practice, the local tcpdump will indicate when the input data come in. Strace |
| 4297 | will indicate when haproxy receives these data (using recv/recvfrom). Warning, |
| 4298 | openssl uses read()/write() syscalls instead of recv()/send(). Strace will also |
| 4299 | show when haproxy sends the data, and tcpdump will show when the system sends |
| 4300 | these data to the interface. Then the external tcpdump will show when the data |
| 4301 | sent are really received (since the local one only shows when the packets are |
| 4302 | queued). The benefit of sniffing on the local system is that strace and tcpdump |
| 4303 | will use the same reference clock. Strace should be used with "-tts200" to get |
| 4304 | complete timestamps and report large enough chunks of data to read them. |
| 4305 | Tcpdump should be used with "-nvvttSs0" to report full packets, real sequence |
| 4306 | numbers and complete timestamps. |
| 4307 | |
| 4308 | In practice, received data are almost always immediately received by haproxy |
| 4309 | (unless the machine has a saturated CPU or these data are invalid and not |
| 4310 | delivered). If these data are received but not sent, it generally is because |
| 4311 | the output buffer is saturated (ie: recipient doesn't consume the data fast |
| 4312 | enough). This can be confirmed by seeing that the polling doesn't notify of |
| 4313 | the ability to write on the output file descriptor for some time (it's often |
| 4314 | easier to spot in the strace output when the data finally leave and then roll |
| 4315 | back to see when the write event was notified). It generally matches an ACK |
| 4316 | received from the recipient, and detected by tcpdump. Once the data are sent, |
| 4317 | they may spend some time in the system doing nothing. Here again, the TCP |
| 4318 | congestion window may be limited and not allow these data to leave, waiting for |
| 4319 | an ACK to open the window. If the traffic is idle and the data take 40 ms or |
| 4320 | 200 ms to leave, it's a different issue (which is not an issue), it's the fact |
| 4321 | that the Nagle algorithm prevents empty packets from leaving immediately, in |
| 4322 | hope that they will be merged with subsequent data. HAProxy automatically |
| 4323 | disables Nagle in pure TCP mode and in tunnels. However it definitely remains |
| 4324 | enabled when forwarding an HTTP body (and this contributes to the performance |
| 4325 | improvement there by reducing the number of packets). Some HTTP non-compliant |
| 4326 | applications may be sensitive to the latency when delivering incomplete HTTP |
| 4327 | response messages. In this case you will have to enable "option http-no-delay" |
| 4328 | to disable Nagle in order to work around their design, keeping in mind that any |
| 4329 | other proxy in the chain may similarly be impacted. If tcpdump reports that data |
| 4330 | leave immediately but the other end doesn't see them quickly, it can mean there |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4331 | is a congested WAN link, a congested LAN with flow control enabled and |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4332 | preventing the data from leaving, or more commonly that HAProxy is in fact |
| 4333 | running in a virtual machine and that for whatever reason the hypervisor has |
| 4334 | decided that the data didn't need to be sent immediately. In virtualized |
| 4335 | environments, latency issues are almost always caused by the virtualization |
| 4336 | layer, so in order to save time, it's worth first comparing tcpdump in the VM |
| 4337 | and on the external components. Any difference has to be credited to the |
| 4338 | hypervisor and its accompanying drivers. |
| 4339 | |
| 4340 | When some TCP SACK segments are seen in tcpdump traces (using -vv), it always |
| 4341 | means that the side sending them has got the proof of a lost packet. While not |
| 4342 | seeing them doesn't mean there are no losses, seeing them definitely means the |
| 4343 | network is lossy. Losses are normal on a network, but at a rate where SACKs are |
| 4344 | not noticeable at the naked eye. If they appear a lot in the traces, it is |
| 4345 | worth investigating exactly what happens and where the packets are lost. HTTP |
| 4346 | doesn't cope well with TCP losses, which introduce huge latencies. |
| 4347 | |
| 4348 | The "netstat -i" command will report statistics per interface. An interface |
| 4349 | where the Rx-Ovr counter grows indicates that the system doesn't have enough |
| 4350 | resources to receive all incoming packets and that they're lost before being |
| 4351 | processed by the network driver. Rx-Drp indicates that some received packets |
| 4352 | were lost in the network stack because the application doesn't process them |
| 4353 | fast enough. This can happen during some attacks as well. Tx-Drp means that |
| 4354 | the output queues were full and packets had to be dropped. When using TCP it |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4355 | should be very rare, but will possibly indicate a saturated outgoing link. |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4356 | |
| 4357 | |
| 4358 | 13. Security considerations |
| 4359 | --------------------------- |
| 4360 | |
| 4361 | HAProxy is designed to run with very limited privileges. The standard way to |
| 4362 | use it is to isolate it into a chroot jail and to drop its privileges to a |
| 4363 | non-root user without any permissions inside this jail so that if any future |
| 4364 | vulnerability were to be discovered, its compromise would not affect the rest |
| 4365 | of the system. |
| 4366 | |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4367 | In order to perform a chroot, it first needs to be started as a root user. It is |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4368 | pointless to build hand-made chroots to start the process there, these ones are |
| 4369 | painful to build, are never properly maintained and always contain way more |
| 4370 | bugs than the main file-system. And in case of compromise, the intruder can use |
| 4371 | the purposely built file-system. Unfortunately many administrators confuse |
| 4372 | "start as root" and "run as root", resulting in the uid change to be done prior |
| 4373 | to starting haproxy, and reducing the effective security restrictions. |
| 4374 | |
| 4375 | HAProxy will need to be started as root in order to : |
| 4376 | - adjust the file descriptor limits |
| 4377 | - bind to privileged port numbers |
| 4378 | - bind to a specific network interface |
| 4379 | - transparently listen to a foreign address |
| 4380 | - isolate itself inside the chroot jail |
| 4381 | - drop to another non-privileged UID |
| 4382 | |
| 4383 | HAProxy may require to be run as root in order to : |
| 4384 | - bind to an interface for outgoing connections |
| 4385 | - bind to privileged source ports for outgoing connections |
Dan Lloyd | 8e48b87 | 2016-07-01 21:01:18 -0400 | [diff] [blame] | 4386 | - transparently bind to a foreign address for outgoing connections |
Willy Tarreau | 2212e6a | 2015-10-13 14:40:55 +0200 | [diff] [blame] | 4387 | |
| 4388 | Most users will never need the "run as root" case. But the "start as root" |
| 4389 | covers most usages. |
| 4390 | |
| 4391 | A safe configuration will have : |
| 4392 | |
| 4393 | - a chroot statement pointing to an empty location without any access |
| 4394 | permissions. This can be prepared this way on the UNIX command line : |
| 4395 | |
| 4396 | # mkdir /var/empty && chmod 0 /var/empty || echo "Failed" |
| 4397 | |
| 4398 | and referenced like this in the HAProxy configuration's global section : |
| 4399 | |
| 4400 | chroot /var/empty |
| 4401 | |
| 4402 | - both a uid/user and gid/group statements in the global section : |
| 4403 | |
| 4404 | user haproxy |
| 4405 | group haproxy |
| 4406 | |
| 4407 | - a stats socket whose mode, uid and gid are set to match the user and/or |
| 4408 | group allowed to access the CLI so that nobody may access it : |
| 4409 | |
| 4410 | stats socket /var/run/haproxy.stat uid hatop gid hatop mode 600 |
| 4411 | |