MINOR: proxy: Add support of 429-Too-Many-Requests in retry-on status

The "429" status can now be specified on retry-on directives. PR_RE_* flags
were updated to remains sorted.

This patch should fix the issue #2687. It is quite simple so it may safely
be backported to 3.0 if necessary.

(cherry picked from commit 0d142e0756986b56819ecb2d131a0c4b30ae899f)
Signed-off-by: Willy Tarreau <w@1wt.eu>
This commit is contained in:
Christopher Faulet 2024-08-27 19:09:08 +02:00 committed by Willy Tarreau
parent edc6b40079
commit ac2dc762f8
3 changed files with 15 additions and 11 deletions

View File

@ -11154,9 +11154,10 @@ retry-on [space-delimited list of keywords]
<status> any HTTP status code among "401" (Unauthorized), "403"
(Forbidden), "404" (Not Found), "408" (Request Timeout),
"425" (Too Early), "500" (Server Error), "501" (Not
Implemented), "502" (Bad Gateway), "503" (Service
Unavailable), "504" (Gateway Timeout).
"425" (Too Early), "429" (Too Many Requests), "500"
(Server Error), "501" (Not Implemented), "502"
(Bad Gateway), "503" (Service Unavailable), "504"
(Gateway Timeout).
all-retryable-errors
retry request for any error that are considered

View File

@ -192,15 +192,16 @@ enum PR_SRV_STATE_FILE {
#define PR_RE_404 0x00000020 /* Retry if we got a 404 */
#define PR_RE_408 0x00000040 /* Retry if we got a 408 */
#define PR_RE_425 0x00000080 /* Retry if we got a 425 */
#define PR_RE_500 0x00000100 /* Retry if we got a 500 */
#define PR_RE_501 0x00000200 /* Retry if we got a 501 */
#define PR_RE_502 0x00000400 /* Retry if we got a 502 */
#define PR_RE_503 0x00000800 /* Retry if we got a 503 */
#define PR_RE_504 0x00001000 /* Retry if we got a 504 */
#define PR_RE_429 0x00000100 /* Retry if we got a 429 */
#define PR_RE_500 0x00000200 /* Retry if we got a 500 */
#define PR_RE_501 0x00000400 /* Retry if we got a 501 */
#define PR_RE_502 0x00000800 /* Retry if we got a 502 */
#define PR_RE_503 0x00001000 /* Retry if we got a 503 */
#define PR_RE_504 0x00002000 /* Retry if we got a 504 */
#define PR_RE_STATUS_MASK (PR_RE_401 | PR_RE_403 | PR_RE_404 | \
PR_RE_408 | PR_RE_425 | PR_RE_500 | \
PR_RE_501 | PR_RE_502 | PR_RE_503 | \
PR_RE_504)
PR_RE_408 | PR_RE_425 | PR_RE_429 | \
PR_RE_500 | PR_RE_501 | PR_RE_502 | \
PR_RE_503 | PR_RE_504)
/* 0x00000800, 0x00001000, 0x00002000, 0x00004000 and 0x00008000 unused,
* reserved for eventual future status codes
*/

View File

@ -847,6 +847,8 @@ proxy_parse_retry_on(char **args, int section, struct proxy *curpx,
curpx->retry_type |= PR_RE_408;
else if (strcmp(args[i], "425") == 0)
curpx->retry_type |= PR_RE_425;
else if (strcmp(args[i], "429") == 0)
curpx->retry_type |= PR_RE_429;
else if (strcmp(args[i], "500") == 0)
curpx->retry_type |= PR_RE_500;
else if (strcmp(args[i], "501") == 0)