mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-09-21 05:41:26 +02:00
The commit 9425aeaffb ("BUG/MAJOR: peers: Update peers section state from a thread-safe manner") introduced regressions about state transitions of a peer. A peer may be in a connected, accepted or released state. Before, changes for these states were performed synchronously. Since the commit above, changes are mainly performed in the sync process task. The first regression was about the released then accepted state transition, called the renewed state. In reality the state was always crushed by the accepted state. After some review, the state was just removed to always perform the cleanup in the sync process task before acknowledging the connected or accepted states. Then, a wakeup of the peer applet was missing from the sync process task after the ack of connected or accepted states, blocking the applet. Finally, when a peer is in released, connected or accepted state, we must take care to wait the sync process task wakeup before trying to receive or send messages. This patch must only be backported if the above commit is backported.
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%