mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-09-22 14:21:25 +02:00
When errors are encountered in sink_new_from_logsrv() function, incompetely allocated ressources are freed to prevent memory leaks. For instance: logsrv implicit server is manually cleaned up on error prior to returning from the function. However, since 198e92a8e5 ("MINOR: server: add a global list of all known servers") every server created using new_server() is registered to the global list, but unfortunately the manual srv cleanup in sink_new_from_logsrv() doesn't remove the srv from the global list, so the freed server will still be referenced there, which can result in invalid reads later. Moreover, server API has evolved since, and now the srv_drop() function is available for that purpose, so let's use it, but make sure that srv is freed before the proxy because on older versions srv_drop() expects the srv to be linked to a valid proxy pointer. This must be backported up to 2.4. [For 2.4 version, free_server() must be used instead of srv_drop()]
The HAProxy documentation has been split into a number of different files for ease of use. Please refer to the following files depending on what you're looking for : - INSTALL for instructions on how to build and install HAProxy - BRANCHES to understand the project's life cycle and what version to use - LICENSE for the project's license - CONTRIBUTING for the process to follow to submit contributions The more detailed documentation is located into the doc/ directory : - doc/intro.txt for a quick introduction on HAProxy - doc/configuration.txt for the configuration's reference manual - doc/lua.txt for the Lua's reference manual - doc/SPOE.txt for how to use the SPOE engine - doc/network-namespaces.txt for how to use network namespaces under Linux - doc/management.txt for the management guide - doc/regression-testing.txt for how to use the regression testing suite - doc/peers.txt for the peers protocol reference - doc/coding-style.txt for how to adopt HAProxy's coding style - doc/internals for developer-specific documentation (not all up to date)
Description
Languages
C
98.1%
Shell
0.8%
Makefile
0.5%
Lua
0.2%
Python
0.2%