]> git.ipfire.org Git - thirdparty/haproxy.git/log
thirdparty/haproxy.git
16 years ago[BUILD] fix a minor build warning on AIX
Willy Tarreau [Thu, 23 Jul 2009 11:40:20 +0000 (13:40 +0200)] 
[BUILD] fix a minor build warning on AIX

AIX wants string.h in signal.c (and is right to do so) :

gcc -Iinclude -Wall  -O2 -g       -DTPROXY -DENABLE_POLL  -DCONFIG_HAPROXY_VERSION=\"1.3.18\" -DCONFIG_HAPROXY_DATE=\"2009/05/10\" -c -o src/signal.o src/signal.c
src/signal.c: In function 'signal_init':
src/signal.c:32: warning: implicit declaration of function 'memset'
src/signal.c:32: warning: incompatible implicit declaration of built-in function 'memset'
(cherry picked from commit be8c736cca24f3981a3e9dee868605ae76b9565c)

16 years ago[MINOR] config: improve error reporting when checking configuration
Willy Tarreau [Thu, 23 Jul 2009 11:36:36 +0000 (13:36 +0200)] 
[MINOR] config: improve error reporting when checking configuration

Do not exit early at the first error found while checking configuration
validity. This particularly helps spotting multiple wrong tracked server
names at once.
(cherry picked from commit bb9250104fdf1096b708181c82172df737341a95)

16 years ago[MINOR] config: the "capture" keyword is not allowed in backends
Willy Tarreau [Thu, 23 Jul 2009 11:24:23 +0000 (13:24 +0200)] 
[MINOR] config: the "capture" keyword is not allowed in backends

The "capture" keyword is only supported by frontends, fix the check.
(cherry picked from commit 3b6b1a984d6a587892afc88d03862c3fc3681bce)

16 years ago[MINOR] config: improve error reporting in listen sections
Willy Tarreau [Thu, 23 Jul 2009 11:19:11 +0000 (13:19 +0200)] 
[MINOR] config: improve error reporting in listen sections

Try not to immediately exit on non-fatal errors while parsing a
listen section, so that the user has a chance to get most of the
errors at once, which is quite convenient especially during config
checks with the -c argument.
(cherry picked from commit 9389379f608d0776988125e52cbac12a2a2ad165)

16 years ago[MINOR] config: improve error reporting in global section
Willy Tarreau [Mon, 20 Jul 2009 07:30:05 +0000 (09:30 +0200)] 
[MINOR] config: improve error reporting in global section

Try not to immediately exit on non-fatal errors while parsing the
global section, so that the user has a chance to get most of the
errors at once, which is quite convenient especially during config
checks with the -c argument. Some other errors such as unresolved
server names also don't make the parser exit too early.
(cherry picked from commit 058e9074865abd23912127d8847cccb6b5f4eb8b)

16 years ago[MINOR] stats: better displaying in MSIE
Willy Tarreau [Wed, 15 Jul 2009 08:07:05 +0000 (10:07 +0200)] 
[MINOR] stats: better displaying in MSIE

MSIE does not correctly display spaced digits. It requires a margin of
at least one pixel. Also, it does not correctly hide empty cells, so we
work around this by setting the background white. Last, the H1 font was
too large, so we reduce it by one size, which is still OK in other
browsers.
(cherry picked from commit da6721ba28d4c917e07ffa7fef1d8707c80c54b6)

16 years ago[BUG] task: fix possible timer drift after update
Willy Tarreau [Tue, 14 Jul 2009 21:48:55 +0000 (23:48 +0200)] 
[BUG] task: fix possible timer drift after update

When the scheduler detected that a task was misplaced in the timer
queue, it used to place it right again. Unfortunately, it did not
check whether it would still call the new task from its new place.
This resulted in some tasks not getting called on timeout once in
a while, causing a minor drift for repetitive timers. This effect
was only observable with slow health checks and without any activity
because no other task would cause the scheduler to be immediately
called again.

In practice, it does not affect any real-world configuration, but
it's still better to fix it.
(cherry picked from commit 814c978fb67782ceeaf1db74abfe7083938bedff)

16 years ago[BUG] config: tcp-request content only accepts "if" or "unless"
Willy Tarreau [Tue, 14 Jul 2009 19:17:05 +0000 (21:17 +0200)] 
[BUG] config: tcp-request content only accepts "if" or "unless"

As reported by Maik Broemme, if something different from "if" or
"unless" was specified after "tcp-request content accept", the
condition would silently remain void. The parser must obviously
complain since this typically corresponds to a forgotten "if".
(cherry picked from commit 606ad73e73600275aae944f00bda4af9976c0be8)

16 years ago[BUG] stream_sock: don't stop reading when the poller reports an error
Willy Tarreau [Tue, 14 Jul 2009 17:55:05 +0000 (19:55 +0200)] 
[BUG] stream_sock: don't stop reading when the poller reports an error

As reported by Jean-Baptiste Quenot and Robbie Aelter, sometimes a
backend server error is converted to a 502 error if the backend stops
before reading all the request. The reason is that the remote system
sends a TCP RST packet because there are still unread data pending in
the socket buffer. This RST is translated as a socket error on the
local system, and this error is reported by the poller.

However, most of the time, it's a write error, but the system is
still able to read the remaining pending data, such as in the trace
below :

send(7, "GET /aaa HTTP/1.0\r\nUser-Agent: Mo"..., 1123, MSG_DONTWAIT|MSG_NOSIGNAL) = 1123
epoll_ctl(3, EPOLL_CTL_ADD, 7, {EPOLLIN, {u32=7, u64=7}}) = 0
epoll_wait(3, {{EPOLLIN|EPOLLERR|EPOLLHUP, {u32=7, u64=7}}}, 8, 1000) = 1
gettimeofday({1247593958, 643572}, NULL) = 0
recv(7, "HTTP/1.0 400 Bad request\r\nCache-C"..., 7000, MSG_NOSIGNAL) = 187
setsockopt(6, SOL_TCP, TCP_NODELAY, [0], 4) = 0
setsockopt(6, SOL_TCP, TCP_CORK, [1], 4) = 0
send(6, "HTTP/1.0 400 Bad request\r\nCache-C"..., 187, MSG_DONTWAIT|MSG_NOSIGNAL) = 187
shutdown(6, 1 /* send */)               = 0

The recv succeeded while epoll_wait() reported an error.

Note: This case is very hard to reproduce and requires that the backend
server is reached via the loopback in order to minimise latency and
reduce the risk of sent data being ACKed.
(cherry picked from commit 7154365cc60b124b543db4e98faedc75c0f3a2cb)

16 years ago[BUG] stream_sock: always shutdown(SHUT_WR) before closing
Willy Tarreau [Tue, 14 Jul 2009 17:21:50 +0000 (19:21 +0200)] 
[BUG] stream_sock: always shutdown(SHUT_WR) before closing

When we close a socket with unread data in the buffer, or when the
nolinger option is set, we regularly lose the last fragment, which
often contains the error message. This typically occurs when sending
too large a request. Only the RST is seen due to the close() (since
not all data were read) and the output message never reaches the
network.

Doing a shutdown() before the close() solves this annoying issue
because the data are really pushed before the system sends the RST.
(cherry picked from commit 720058cdcbd5285dc4e4a48216b10c9b96000141)

16 years ago[BUILD] report commit date and not author's date as build date
Willy Tarreau [Tue, 14 Jul 2009 11:24:16 +0000 (13:24 +0200)] 
[BUILD] report commit date and not author's date as build date

By default, when building from a git tree, haproxy's release date is
set to the last commit's date. But it was the wrong date which was
used, the initial patch's date, which can cause time jumps in the
past when an old patch gets merged. What we want is the commit date,
which reflects the correct code history.
(cherry picked from commit 446024e7fb5faef86cd6e2c0aba3c4524ad77705)

16 years ago[BUG] default ACLs did not properly set the ->requires flag
Willy Tarreau [Sun, 12 Jul 2009 07:21:30 +0000 (09:21 +0200)] 
[BUG] default ACLs did not properly set the ->requires flag

This bug caused TCP proxies not to report incorrect use of some
aliases of HTTP ACLs.
(cherry picked from commit a55b7dc52877ee81609db688f327e7e9586498f0)

16 years ago[CLEANUP] remove unused DEBUG_PARSE_NO_SPEEDUP define
Willy Tarreau [Tue, 7 Jul 2009 06:56:15 +0000 (08:56 +0200)] 
[CLEANUP] remove unused DEBUG_PARSE_NO_SPEEDUP define

This one has become useless with the new HTTP parser.
(cherry picked from commit 571ec98baaacd68205ada1cda898ae359a41bc83)

16 years ago[BUG] http: redirect rules were processed too early
Willy Tarreau [Mon, 6 Jul 2009 14:34:52 +0000 (16:34 +0200)] 
[BUG] http: redirect rules were processed too early

redirect rules are documented as being processed last before
use_backend but were mistakenly processed before block rules.
Fortunately very few people use a mix of block and redirect
rules, so this bug has never been reported yet.
(cherry picked from commit 06b917c7abcd7313263d551eaecda1b31b9c03b1)

16 years ago[MEDIUM] config: support loading multiple configuration files
Willy Tarreau [Mon, 22 Jun 2009 14:02:30 +0000 (16:02 +0200)] 
[MEDIUM] config: support loading multiple configuration files

We now support up to 10 distinct configuration files. They are
all loaded in the order defined by -f <file1> -f <file2> ...

This can be useful in order to store global, private, public,
etc... configurations in distinct files.
(cherry picked from commit 5d01a63b7862235fdd3119cb29d5a0cfd04edb91)

16 years ago[MEDIUM] config: split parser and checker in two functions
Willy Tarreau [Mon, 22 Jun 2009 13:48:36 +0000 (15:48 +0200)] 
[MEDIUM] config: split parser and checker in two functions

This is a first step towards support of multiple configuration files.
Now readcfgfile() only reads a file in memory and performs very minimal
parsing. The checks are performed afterwards.
(cherry picked from commit 915e1ebe63b2137fa1634ebc9553f5b73ae2fd75)

16 years ago[MINOR] make DEFAULT_MAXCONN user-configurable at build time
Willy Tarreau [Mon, 15 Jun 2009 14:33:36 +0000 (16:33 +0200)] 
[MINOR] make DEFAULT_MAXCONN user-configurable at build time

The only way to set this previously was to set SYSTEM_MAXCONN
which serves a different purpose.
(cherry picked from commit c9fe4562c24ebacdfdf55631636e5a5a0395e43c)

16 years ago[MEDIUM] support setting a server weight to zero
Willy Tarreau [Mon, 15 Jun 2009 08:56:05 +0000 (10:56 +0200)] 
[MEDIUM] support setting a server weight to zero

Sometimes it is useful to be able to set a server's weight to zero.
It allows the server to receive only persistent traffic but never
normal traffic.
(cherry picked from commit 6704d67d656574a602ddf81a603cdb4f482f90a9)

16 years ago[BUILD] add support for build under Cygwin
Yitzhak Sapir [Sun, 14 Jun 2009 16:27:54 +0000 (18:27 +0200)] 
[BUILD] add support for build under Cygwin

After considering various possibilities, we compiled haproxy under cygwin.
Attached is an updated full diff that also has the TARGET=cygwin documented.
The whole thing compiles and installs with this diff only.

In cygwin 1.7 (now in beta), there is apparently support for ipv6.  Cygwin
1.5 (later versions, anyway) already includes some support in the form of a
define USE_IPV6.  When defined, it declares the sockaddr_in6 struct and
possibly other things.  The above definition AF_INET6=23 is taken from
their /usr/include/socket.h file (where it is #if 0'd out).

We are running into a socket limit.  It appears that Cygwin (running on
Windows 2003 Server) will only allow us to set ulimit -n (maximum open
files) to 3200, which means we're a little short of 1600 connections.

The limit of 3200 is an internal Cygwin limit.  Perhaps they can raise it in
the future.  Using the nbproc option, I was able to bring up 10 servers.  It
seems to me that they were able to handle over 2000 connections (even though
each had maxconn 1500 set, and the hard Cygwin fd limit).
(cherry picked from commit 32087312e3a4ad483440d371b0b1769db23946d3)

16 years ago[MEDIUM] add support for binding to source port ranges during connect
Willy Tarreau [Wed, 10 Jun 2009 09:09:37 +0000 (11:09 +0200)] 
[MEDIUM] add support for binding to source port ranges during connect

Some users are already hitting the 64k source port limit when
connecting to servers. The system usually maintains a list of
unused source ports, regardless of the source IP they're bound
to. So in order to go beyond the 64k concurrent connections, we
have to manage the source ip:port lists ourselves.

The solution consists in assigning a source port range to each
server and use a free port in that range when connecting to that
server, either for a proxied connection or for a health check.
The port must then be put back into the server's range when the
connection is closed.

This mechanism is used only when a port range is specified on
a server. It makes it possible to reach 64k connections per
server, possibly all from the same IP address. Right now it
should be more than enough even for huge deployments.
(cherry picked from commit c6f4ce8fc4a9da9f4c31e8d088fab1ed4f631ed0)

16 years ago[BUG] ensure that we correctly re-start old process in case of error
Willy Tarreau [Tue, 9 Jun 2009 12:36:00 +0000 (14:36 +0200)] 
[BUG] ensure that we correctly re-start old process in case of error

When a new process fails to grab some ports, it sends a signal to
the old process in order to release them. Then it tries to bind
again. If it still fails (eg: one of the ports is bound to a
completely different process), it must send the continue signal
to the old process so that this one re-binds to the ports. This
is correctly done, but the newly bound ports are not released
first, which sometimes causes the old process to remain running
with no port bound. The fix simply consists in unbinding all
ports before sending the signal to the old process.
(cherry picked from commit f68da4603a092f35af627c459dbc714d9fa796e9)

16 years ago[MINOR] startup: don't imply -q with -D
Willy Tarreau [Mon, 18 May 2009 14:29:51 +0000 (16:29 +0200)] 
[MINOR] startup: don't imply -q with -D

It is recommended to have -D in init scripts, but -D also implies
quiet mode, which hides warning messages, and both options are now
completely unrelated. Remove the implication to get warnings with
-D.

16 years ago[RELEASE] Released version 1.3.18 v1.3.18
Willy Tarreau [Sun, 10 May 2009 18:27:47 +0000 (20:27 +0200)] 
[RELEASE] Released version 1.3.18

Released version 1.3.18 with the following main changes :
    - [MEDIUM] add support for "balance hdr(name)"
    - [CLEANUP] give a little bit more information in error message
    - [MINOR] add X-Original-To: header
    - [BUG] x-original-to: fix missing initialization to default value
    - [BUILD] spec file: fix broken pipe during rpmbuild and add man file
    - [MINOR] improve reporting of misplaced acl/reqxxx rules
    - [MEDIUM] http: add options to ignore invalid header names
    - [MEDIUM] http: capture invalid requests/responses even if accepted
    - [BUILD] add format(printf) to printf-like functions
    - [MINOR] fix several printf formats and missing arguments
    - [BUG] stats: total and lbtot are unsigned
    - [MINOR] fix a few remaining printf-like formats on 64-bit platforms
    - [CLEANUP] remove unused make option from haproxy.spec
    - [BUILD] make it possible to pass alternative arch at build time
    - [MINOR] switch all stat counters to 64-bit
    - [MEDIUM] ensure we don't recursively call pool_gc2()
    - [CRITICAL] uninitialized response field can sometimes cause crashes
    - [BUG] fix wrong pointer arithmetics in HTTP message captures
    - [MINOR] rhel init script : support the reload operation
    - [MINOR] add basic signal handling functions
    - [BUILD] add signal.o to all makefiles
    - [MEDIUM] call signal_process_queue from run_poll_loop
    - [MEDIUM] pollers: don't wait if a signal is pending
    - [MEDIUM] convert all signals to asynchronous signals
    - [BUG] O(1) pollers should check their FD before closing it
    - [MINOR] don't close stdio fds twice
    - [MINOR] add options dontlog-normal and log-separate-errors
    - [DOC] minor fixes and rearrangements
    - [BUG] fix parser crash on unconditional tcp content rules
    - [DOC] rearrange the configuration manual and add a summary
    - [MINOR] standard: provide a new 'my_strndup' function
    - [MINOR] implement per-logger log level limitation
    - [MINOR] compute the max of sessions/s on fe/be/srv
    - [MINOR] stats: report max sessions/s and limit in CSV export
    - [MINOR] stats: report max sessions/s and limit in HTML stats
    - [MINOR] stats/html: use the arial font before helvetica

16 years ago[MINOR] stats/html: use the arial font before helvetica
Willy Tarreau [Sun, 10 May 2009 18:08:10 +0000 (20:08 +0200)] 
[MINOR] stats/html: use the arial font before helvetica

The stats HTML output were barely readable on some browsers such as
firefox on Linux, due to the selected helvetica font which is too
small. Specifying "arial" first fixes the issue without changing the
table size. Also, the default size of 0.8em choosen to get 10px out
of 12px is wrong because it gets 9px when rounded down.

16 years ago[MINOR] stats: report max sessions/s and limit in HTML stats
Willy Tarreau [Sun, 10 May 2009 17:19:41 +0000 (19:19 +0200)] 
[MINOR] stats: report max sessions/s and limit in HTML stats

16 years ago[MINOR] stats: report max sessions/s and limit in CSV export
Willy Tarreau [Sun, 10 May 2009 17:01:49 +0000 (19:01 +0200)] 
[MINOR] stats: report max sessions/s and limit in CSV export

16 years ago[MINOR] compute the max of sessions/s on fe/be/srv
Willy Tarreau [Sun, 10 May 2009 16:52:49 +0000 (18:52 +0200)] 
[MINOR] compute the max of sessions/s on fe/be/srv

Some users want to keep the max sessions/s seen on servers, frontends
and backends for capacity planning. It's easy to grab it while the
session count is updated, so let's keep it.

16 years ago[MINOR] implement per-logger log level limitation
Willy Tarreau [Sun, 10 May 2009 15:20:05 +0000 (17:20 +0200)] 
[MINOR] implement per-logger log level limitation

Some people are using haproxy in a shared environment where the
system logger by default sends alert and emerg messages to all
consoles, which happens when all servers go down on a backend for
instance. These people can not always change the system configuration
and would like to limit the outgoing messages level in order not to
disturb the local users.

The addition of an optional 4th field on the "log" line permits
exactly this. The minimal log level ensures that all outgoing logs
will have at least this level. So the logs are not filtered out,
just set to this level.

16 years ago[MEDIUM] add support for "balance hdr(name)"
Benoit [Wed, 25 Mar 2009 12:02:10 +0000 (13:02 +0100)] 
[MEDIUM] add support for "balance hdr(name)"

There is a patch made by me that allow for balancing on any http header
field.

[WT:
  made minor changes:
  - turned 'balance header name' into 'balance hdr(name)' to match more
    closely the ACL syntax for easier future convergence
  - renamed the proxy structure fields header_* => hh_*
  - made it possible to use the domain name reduction to any header, not
    only "host" since it makes sense to do it with other ones.
  Otherwise patch looks good.
/WT]

16 years ago[MINOR] standard: provide a new 'my_strndup' function
Willy Tarreau [Sun, 10 May 2009 13:41:18 +0000 (15:41 +0200)] 
[MINOR] standard: provide a new 'my_strndup' function

This function is only offered by GNU extensions and is sometimes
useful during configuration parsing.

16 years ago[DOC] rearrange the configuration manual and add a summary
Willy Tarreau [Sun, 10 May 2009 11:12:33 +0000 (13:12 +0200)] 
[DOC] rearrange the configuration manual and add a summary

Several people have asked for a summary in order to ease finding
of sections in the configuration manual. It was the opportunity to
tidy it up a bit and rearrange some sections.

16 years ago[BUG] fix parser crash on unconditional tcp content rules
Willy Tarreau [Sun, 10 May 2009 10:05:46 +0000 (12:05 +0200)] 
[BUG] fix parser crash on unconditional tcp content rules

Since 1.3.17, a config containing one of the following lines would
crash the parser :

    tcp content reject
    tcp content accept

This is because a check is performed on the condition which is not
specified. The obvious fix consists in checkinf for a condition
first.

16 years ago[DOC] minor fixes and rearrangements
Willy Tarreau [Sun, 10 May 2009 10:02:55 +0000 (12:02 +0200)] 
[DOC] minor fixes and rearrangements

Rearranged a few misplaced keywords, fixed a few typos and truncated
some long lines.

16 years ago[MINOR] add options dontlog-normal and log-separate-errors
Willy Tarreau [Sun, 10 May 2009 09:57:02 +0000 (11:57 +0200)] 
[MINOR] add options dontlog-normal and log-separate-errors

Some big traffic sites have trouble dealing with logs and tend to
disable them. Here are two new options to help cope with massive
logs.

  - dontlog-normal only disables logging for 100% successful
    connections, other ones will still be logged

  - log-separate-errors will cause non-100% successful connections
    to be logged at level "err" instead of level "info" so that a
    properly configured syslog daemon can send them to a different
    file for longer conservation.

16 years ago[MINOR] don't close stdio fds twice
Willy Tarreau [Sun, 10 May 2009 08:33:29 +0000 (10:33 +0200)] 
[MINOR] don't close stdio fds twice

This minor harmless bug dates back to v1.1. When fclose() was added,
the close() calls were not removed, so the fds 0,1,2 are closed twice.

16 years ago[BUG] O(1) pollers should check their FD before closing it
Willy Tarreau [Sun, 10 May 2009 08:18:54 +0000 (10:18 +0200)] 
[BUG] O(1) pollers should check their FD before closing it

epoll, sepoll and kqueue pollers should check that their fd is not
closed before attempting to close it, otherwise we can end up with
multiple closes of fd #0 upon exit, which is harmless but dirty.

16 years ago[MEDIUM] convert all signals to asynchronous signals
Willy Tarreau [Sun, 10 May 2009 07:59:50 +0000 (09:59 +0200)] 
[MEDIUM] convert all signals to asynchronous signals

The small list of signals currently handled by haproxy were processed
as soon as they were received. This has caused trouble with calls to
pool_gc2() occuring in the middle of libc's memory management functions
seldom causing deadlocks preventing the old process from leaving.

Now these signals use the new async signal framework and are called
asynchronously, when there is no risk of recursion. This ensures more
reliable operation, especially for sensible processing such as memory
management.

16 years ago[MEDIUM] pollers: don't wait if a signal is pending
Willy Tarreau [Sun, 10 May 2009 07:57:21 +0000 (09:57 +0200)] 
[MEDIUM] pollers: don't wait if a signal is pending

If an asynchronous signal is received outside of the poller, we don't
want the poller to wait for a timeout to occur before processing it,
so we set its timeout to zero, just like we do with pending tasks in
the run queue.

16 years ago[MEDIUM] call signal_process_queue from run_poll_loop
Willy Tarreau [Sun, 10 May 2009 07:01:21 +0000 (09:01 +0200)] 
[MEDIUM] call signal_process_queue from run_poll_loop

Now we check for asynchronous pending signals. There's no user yet
so this cannot cause any trouble.

16 years ago[BUILD] add signal.o to all makefiles
Willy Tarreau [Sun, 10 May 2009 07:00:20 +0000 (09:00 +0200)] 
[BUILD] add signal.o to all makefiles

16 years ago[MINOR] add basic signal handling functions
Willy Tarreau [Sun, 10 May 2009 06:53:33 +0000 (08:53 +0200)] 
[MINOR] add basic signal handling functions

These functions will be used to deliver asynchronous signals in order
to make the signal handling functions more robust. The goal is to keep
the same interface to signal handlers.

16 years ago[BUG] x-original-to: fix missing initialization to default value
Maik Broemme [Fri, 8 May 2009 15:02:07 +0000 (17:02 +0200)] 
[BUG] x-original-to: fix missing initialization to default value

16 years ago[MINOR] add X-Original-To: header
Maik Broemme [Fri, 17 Apr 2009 16:53:21 +0000 (18:53 +0200)] 
[MINOR] add X-Original-To: header

I have attached a patch which will add on every http request a new
header 'X-Original-To'. If you have HAProxy running in transparent mode
with a big number of SQUID servers behind it, it is very nice to have
the original destination ip as a common header to make decisions based
on it.

The whole thing is configurable with a new option 'originalto'. I have
updated the sourcecode as well as the documentation. The 'haproxy-en.txt'
and 'haproxy-fr.txt' files are untouched, due to lack of my french
language knowledge. ;)

Also the patch adds this header for IPv4 only. I haven't any IPv6 test
environment running here and don't know if getsockopt() with SO_ORIGINAL_DST
will work on IPv6. If someone knows it and wants to test it I can modify
the diff. Feel free to ask me questions or things which should be changed. :)

--Maik

16 years ago[MINOR] rhel init script : support the reload operation
Willy Tarreau [Fri, 1 May 2009 13:49:56 +0000 (15:49 +0200)] 
[MINOR] rhel init script : support the reload operation

The reload operation in the Red Hat init script caused a restart
which is not always the best thing to do. Implement the reload.

16 years ago[BUG] fix wrong pointer arithmetics in HTTP message captures
Willy Tarreau [Fri, 1 May 2009 09:33:17 +0000 (11:33 +0200)] 
[BUG] fix wrong pointer arithmetics in HTTP message captures

The pointer arithmetics was wrong in http_capture_bad_message().
This has no impact right now because the error only msg->som was
affected and right now it's always 0. But this was a bug waiting
for keepalive support to strike.

16 years ago[CRITICAL] uninitialized response field can sometimes cause crashes
Willy Tarreau [Mon, 27 Apr 2009 06:11:33 +0000 (08:11 +0200)] 
[CRITICAL] uninitialized response field can sometimes cause crashes

The response message in the transaction structure was not properly
initialised at session initialisation. In theory it cannot cause any
trouble since the affected field os expected to always remain NULL.
However, in some circumstances, such as building on 64-bit platforms
with certain options, the struct session can be exactly 1024 bytes,
the same size of the requri field, so the pools are merged and the
uninitialised field may contain non-null data, causing crashes if
an invalid response is encountered and archived.

The fix simply consists in correctly initialising the missing fields.
This bug cannot affect architectures where the session pool is not
shared (32-bit architectures), but this is only by pure luck.

16 years ago[MEDIUM] ensure we don't recursively call pool_gc2()
Willy Tarreau [Tue, 21 Apr 2009 00:17:45 +0000 (02:17 +0200)] 
[MEDIUM] ensure we don't recursively call pool_gc2()

A race condition exists in the hot reconfiguration code. It is
theorically possible that the second signal is sent during a free()
in the first list, which can cause crashes or freezes (the later
have been observed). Just set up a counter to ensure we do not
recurse.

16 years ago[MINOR] switch all stat counters to 64-bit
Willy Tarreau [Sat, 11 Apr 2009 18:44:08 +0000 (20:44 +0200)] 
[MINOR] switch all stat counters to 64-bit

The byte counters have long been 64-bit to avoid overflows. But with
several sites nowadays, we see session counters wrap around every 10-days
or so. So it was the moment to switch counters to 64-bit, including
error and warning counters which can theorically rise as fast as session
counters even if in practice there is very low risk.

The performance impact should not be noticeable since those counters are
only updated once per session. The stats output have been carefully checked
for proper types on both 32- and 64-bit platforms.

16 years ago[BUILD] make it possible to pass alternative arch at build time
Willy Tarreau [Sat, 11 Apr 2009 17:45:50 +0000 (19:45 +0200)] 
[BUILD] make it possible to pass alternative arch at build time

When trying to build a 32-bit binary on a 64-bit platform, we generally
need to pass "-m32" to gcc, which is not convenient with current makefile.
Note that this option requires gcc >= 3.

In order to ease parameter passing, a new ARCH= makefile option has been
added. If it receives a target architecture, according "-m32"/"-m64" and
"-march=xxxx" will be passed to gcc. Only the generic makefile has been
changed to support this option right now as the need only appeared on Linux.

The spec file now makes use of this option so that rpmbuild can automatically
build with the proper architecture.

16 years ago[CLEANUP] remove unused make option from haproxy.spec
Willy Tarreau [Sat, 11 Apr 2009 17:44:17 +0000 (19:44 +0200)] 
[CLEANUP] remove unused make option from haproxy.spec

16 years ago[MINOR] fix a few remaining printf-like formats on 64-bit platforms
Willy Tarreau [Sat, 11 Apr 2009 17:42:49 +0000 (19:42 +0200)] 
[MINOR] fix a few remaining printf-like formats on 64-bit platforms

Mainly two sizeof() returning size_t which is not the size of an int
on 64-bit platforms.

16 years ago[BUG] stats: total and lbtot are unsigned
Willy Tarreau [Tue, 7 Apr 2009 11:27:40 +0000 (13:27 +0200)] 
[BUG] stats: total and lbtot are unsigned

Some big users are seeing negative numbers in the CSV stats. This patch
needs to be backported to 1.3.15 and extended to the HTML part.

16 years ago[BUILD] spec file: fix broken pipe during rpmbuild and add man file
Sébastien Barrier [Thu, 2 Apr 2009 13:09:35 +0000 (15:09 +0200)] 
[BUILD] spec file: fix broken pipe during rpmbuild and add man file

16 years ago[CLEANUP] give a little bit more information in error message
Jeffrey 'jf' Lim [Thu, 2 Apr 2009 13:53:56 +0000 (21:53 +0800)] 
[CLEANUP] give a little bit more information in error message

Indicate the error is about redirection.

16 years ago[MINOR] fix several printf formats and missing arguments
Willy Tarreau [Fri, 3 Apr 2009 12:49:12 +0000 (14:49 +0200)] 
[MINOR] fix several printf formats and missing arguments

Last patch revealed a number of mistakes in printf-like calls, mostly int/long
mismatches, and a few missing arguments.

16 years ago[BUILD] add format(printf) to printf-like functions
Willy Tarreau [Fri, 3 Apr 2009 10:01:47 +0000 (12:01 +0200)] 
[BUILD] add format(printf) to printf-like functions

Doing this helps catching warnings about wrong output formats.

16 years ago[MEDIUM] http: capture invalid requests/responses even if accepted
Willy Tarreau [Thu, 2 Apr 2009 13:18:36 +0000 (15:18 +0200)] 
[MEDIUM] http: capture invalid requests/responses even if accepted

It's useful to be able to accept an invalid header name in a request
or response but still be able to monitor further such errors. Now,
when an invalid request/response is received and accepted due to
an "accept-invalid-http-{request|response}" option, the invalid
request will be captured for later analysis with "show errors" on
the stats socket.

16 years ago[MEDIUM] http: add options to ignore invalid header names
Willy Tarreau [Thu, 2 Apr 2009 09:35:18 +0000 (11:35 +0200)] 
[MEDIUM] http: add options to ignore invalid header names

Sometimes it is required to let invalid requests pass because
applications sometimes take time to be fixed and other servers
do not care. Thus we provide two new options :

     option accept-invalid-http-request  (for the frontend)
     option accept-invalid-http-response (for the backend)

When those options are set, invalid requests or responses do
not cause a 403/502 error to be generated.

16 years ago[MINOR] improve reporting of misplaced acl/reqxxx rules
Willy Tarreau [Tue, 31 Mar 2009 08:49:21 +0000 (10:49 +0200)] 
[MINOR] improve reporting of misplaced acl/reqxxx rules

Now we can detect improper ordering of "block", "reqxxx", "reqadd",
"redirect" and "use_backend", and warn the user accordingly.

16 years ago[RELEASE] Released version 1.3.17 v1.3.17
Willy Tarreau [Sun, 29 Mar 2009 13:26:57 +0000 (15:26 +0200)] 
[RELEASE] Released version 1.3.17

Released version 1.3.17 with the following main changes :
    - Update specfile to build for v2.6 kernel.
    - [BUG] reset the stream_interface connect timeout upon connect or error
    - [BUG] reject unix accepts when connection limit is reached
    - [MINOR] show sess: report number of calls to each task
    - [BUG] don't call epoll_ctl() on closed sockets
    - [BUG] stream_sock: disable I/O on fds reporting an error
    - [MINOR] sepoll: don't count two events on the same FD.
    - [MINOR] show sess: report a lot more information about sessions
    - [BUG] stream_sock: check for shut{r,w} before refreshing some timeouts
    - [BUG] don't set an expiration date directly from now_ms
    - [MINOR] implement ulltoh() to write HTML-formatted numbers
    - [MINOR] stats/html: group digits by 3 to clarify numbers
    - [BUILD] remove haproxy-small.spec
    - [BUILD] makefile: remove unused references to linux24eold and EPOLL_CTL_WORKAROUND

16 years ago[BUILD] makefile: remove unused references to linux24eold and EPOLL_CTL_WORKAROUND
Willy Tarreau [Sun, 29 Mar 2009 13:08:25 +0000 (15:08 +0200)] 
[BUILD] makefile: remove unused references to linux24eold and EPOLL_CTL_WORKAROUND

This option is not implemented anymore but still appeared in the makefile. Get
rid of it.

16 years ago[BUILD] remove haproxy-small.spec
Willy Tarreau [Sun, 29 Mar 2009 13:05:24 +0000 (15:05 +0200)] 
[BUILD] remove haproxy-small.spec

This one is not used and causes trouble to people using rpmbuild.

16 years ago[PATCH] Update specfile to build for v2.6 kernel.
Jan-Frode Myklebust [Thu, 26 Mar 2009 14:45:53 +0000 (15:45 +0100)] 
[PATCH] Update specfile to build for v2.6 kernel.
  - Fix date in changelog.
  - Stop using deprecated "REGEX=pcre", and start using "USE_PCRE=1" instead.
  - Disable RPM-processing of perl dependencies, since haproxy
    shouldn't depend on perl, and it's only the examples/check script
    that's using perl.

16 years ago[MINOR] stats/html: group digits by 3 to clarify numbers
Willy Tarreau [Sun, 29 Mar 2009 12:46:01 +0000 (14:46 +0200)] 
[MINOR] stats/html: group digits by 3 to clarify numbers

Large stats numbers are more readable if there is a small space
between groups of 3 digits.

16 years ago[MINOR] implement ulltoh() to write HTML-formatted numbers
Willy Tarreau [Sun, 29 Mar 2009 11:41:58 +0000 (13:41 +0200)] 
[MINOR] implement ulltoh() to write HTML-formatted numbers

This function sets CSS letter spacing after each 3rd digit. The page must
create a class "rls" (right letter spacing) with style "letter-spacing: 0.3em"
in order to use it.

16 years ago[BUG] don't set an expiration date directly from now_ms
Willy Tarreau [Sun, 29 Mar 2009 08:24:15 +0000 (10:24 +0200)] 
[BUG] don't set an expiration date directly from now_ms

now_ms can be zero, don't set ->analyse_exp directly from it, we
must use tick_add() instead.

16 years ago[BUG] stream_sock: check for shut{r,w} before refreshing some timeouts
Willy Tarreau [Sun, 29 Mar 2009 08:18:41 +0000 (10:18 +0200)] 
[BUG] stream_sock: check for shut{r,w} before refreshing some timeouts

Under some circumstances, it appears possible to refresh a timeout
just after a side has been shut. For instance, if poll() plans to
call both read and write, and the read side calls chk_snd() which
in turn causes a shutw to occur, then stream_sock_write could update
its write timeout. The same problem happens the other way.

The timeout checks will then not catch these cases because they
ignore timeouts in case of shut{r,w}.

This is very likely to be the major cause of the 100% CPU usages
reported by Bart Bobrowski.

The fix consists in always ensuring that a side is not shut before
updating its timeout.

16 years ago[MINOR] show sess: report a lot more information about sessions
Willy Tarreau [Sat, 28 Mar 2009 23:18:14 +0000 (00:18 +0100)] 
[MINOR] show sess: report a lot more information about sessions

For complex troubleshooting, it's sometimes useful to be able to
completely dump all the states and flags related to a session.
Now "show sess" will report the stream interfaces and buffers
status for each session.

16 years ago[MINOR] sepoll: don't count two events on the same FD.
Willy Tarreau [Sat, 28 Mar 2009 20:10:48 +0000 (21:10 +0100)] 
[MINOR] sepoll: don't count two events on the same FD.

sepoll counts the number of speculative events it has processed in
order to remain fair with epoll_wait(). If a same FD is processed
both for read and for write, it is counted twice. Fix this.

16 years ago[BUG] stream_sock: disable I/O on fds reporting an error
Willy Tarreau [Sat, 28 Mar 2009 19:54:53 +0000 (20:54 +0100)] 
[BUG] stream_sock: disable I/O on fds reporting an error

Upon read or write error, we cannot immediately close the FD because
we want to first report the error to the upper layer which will do it
itself. However, we want to prevent any further I/O from being performed
on the FD. This is especially important in case of speculative I/O where
nothing else could stop the FD from still being polled until the upper
layer takes care of the condition.

16 years ago[BUG] don't call epoll_ctl() on closed sockets
Willy Tarreau [Sat, 28 Mar 2009 18:43:06 +0000 (19:43 +0100)] 
[BUG] don't call epoll_ctl() on closed sockets

Some I/O callbacks are able to close their socket themselves. We
want to check this before calling epoll_ctl(EPOLL_CTL_DEL), otherwise
we get a -1 EBADF. Right now is looks like this could not cause any
trouble but the case is racy enough to fix it.

16 years ago[MINOR] show sess: report number of calls to each task
Willy Tarreau [Sat, 28 Mar 2009 16:54:35 +0000 (17:54 +0100)] 
[MINOR] show sess: report number of calls to each task

For debugging purposes, it can be useful to know how many times each
task has been called.

16 years ago[BUG] reject unix accepts when connection limit is reached
Willy Tarreau [Sat, 28 Mar 2009 10:02:18 +0000 (11:02 +0100)] 
[BUG] reject unix accepts when connection limit is reached

unix sockets are not attached to a real frontend, so there is
no way to disable/enable the listener depending on the global
session count. For this reason, if the global maxconn is reached
and a unix socket comes in, it will just be ignored and remain
in the poll list, which will call again indefinitely.

So we need to accept then drop incoming unix connections when
the table is full.

This should not happen with clean configurations since the global
maxconn should provide enough room for unix sockets.

16 years ago[BUG] reset the stream_interface connect timeout upon connect or error
Willy Tarreau [Sat, 28 Mar 2009 09:47:26 +0000 (10:47 +0100)] 
[BUG] reset the stream_interface connect timeout upon connect or error

The stream_interface timeout was not reset upon a connect success or
error, leading to busy loops when requeuing tasks in the past.

Thanks to Bart Bobrowski for reporting the issue.

16 years ago[RELEASE] Released version 1.3.16 v1.3.16
Willy Tarreau [Sun, 22 Mar 2009 22:46:12 +0000 (23:46 +0100)] 
[RELEASE] Released version 1.3.16

Released version 1.3.16 with the following main changes :
    - [BUILD] Fixed Makefile for linking pcre
    - [CONTRIB] selinux policy for haproxy
    - [MINOR] show errors: encode backslash as well as non-ascii characters
    - [MINOR] cfgparse: some cleanups in the consistency checks
    - [MINOR] cfgparse: set backends to "balance roundrobin" by default
    - [MINOR] tcp-inspect: permit the use of no-delay inspection
    - [MEDIUM] reverse internal proxy declaration order to match configuration
    - [CLEANUP] config: catch and report some possibly wrong rule ordering
    - [BUG] connect timeout is in the stream interface, not the buffer
    - [BUG] session: errors were not reported in termination flags in TCP mode
    - [MINOR] tcp_request: let the caller take care of errors and timeouts
    - [CLEANUP] http: remove some commented out obsolete code in process_response
    - [MINOR] update ebtree to version 4.1
    - [MEDIUM] scheduler: get rid of the 4 trees thanks and use ebtree v4.1
    - [BUG] sched: don't leave 3 lasts tasks unprocessed when niced tasks are present
    - [BUG] scheduler: fix improper handling of duplicates __task_queue()
    - [MINOR] sched: permit a task to stay up between calls
    - [MINOR] task: keep a task count and clean up task creators
    - [MINOR] stats: report number of tasks (active and running)
    - [BUG] server check intervals must not be null
    - [OPTIM] stream_sock: don't retry to read after a large read
    - [OPTIM] buffer: new BF_READ_DONTWAIT flag reduces EAGAIN rates
    - [MEDIUM] session: don't resync FSMs on non-interesting changes
    - [BUG] check for global.maxconn before doing accept()
    - [OPTIM] sepoll: do not re-check whole list upon accepts

16 years ago[OPTIM] sepoll: do not re-check whole list upon accepts
Willy Tarreau [Sun, 22 Mar 2009 18:25:46 +0000 (19:25 +0100)] 
[OPTIM] sepoll: do not re-check whole list upon accepts

There is already an optimisation in the speculative poller which
causes newly created FDs to be checked immediately after being
created. Unfortunately, this optimisation causes the whole spec
list to be re-checked while we're only interested in the new FDs.

Doing this minor change causes performance gains of up to 6% on
medium-sized objects with a few hundreds concurrent connections.

16 years ago[BUG] check for global.maxconn before doing accept()
Willy Tarreau [Sat, 21 Mar 2009 21:43:12 +0000 (22:43 +0100)] 
[BUG] check for global.maxconn before doing accept()

If the accept() is done before checking for global.maxconn, we can
accept too many connections and encounter a lack of file descriptors
when trying to connect to the server. This is the cause of the
"cannot get a server socket" message  encountered in debug mode
during injections with low timeouts.

16 years ago[MEDIUM] session: don't resync FSMs on non-interesting changes
Willy Tarreau [Sat, 21 Mar 2009 21:09:29 +0000 (22:09 +0100)] 
[MEDIUM] session: don't resync FSMs on non-interesting changes

While processing the session, we used to resync the FSMs when buffer
flags changed. But since BF_KERN_SPLICING and BF_READ_DONTWAIT were
introduced, sometimes we could resync after they were set, which is
not what we want. This was because there were some old checks left
which did not mask changes with BF_MASK_STATIC before checking.

16 years ago[OPTIM] buffer: new BF_READ_DONTWAIT flag reduces EAGAIN rates
Willy Tarreau [Sat, 21 Mar 2009 20:10:04 +0000 (21:10 +0100)] 
[OPTIM] buffer: new BF_READ_DONTWAIT flag reduces EAGAIN rates

When the reader does not expect to read lots of data, it can
set BF_READ_DONTWAIT on the request buffer. When it is set,
the stream_sock_read callback will not try to perform multiple
reads, it will return after only one, and clear the flag.
That way, we can immediately return when waiting for an HTTP
request without trying to read again.

On pure request/responses schemes such as monitor-uri or
redirects, this has completely eliminated the EAGAIN occurrences
and the epoll_ctl() calls, resulting in a performance increase of
about 10%. Similar effects should be observed once we support
HTTP keep-alive since we'll immediately disable reads once we
get a full request.

16 years ago[OPTIM] stream_sock: don't retry to read after a large read
Willy Tarreau [Sat, 21 Mar 2009 19:43:57 +0000 (20:43 +0100)] 
[OPTIM] stream_sock: don't retry to read after a large read

If we get very large data at once, it's almost certain that it's
worthless trying to read again, because we got everything we could
get.

Doing this has made all -EAGAIN disappear from splice reads. The
threshold has been put in the global tunable structures so that if
we one day want to make it accessible from user config, it will be
easy to do so.

16 years ago[BUG] server check intervals must not be null
Willy Tarreau [Sat, 21 Mar 2009 17:58:32 +0000 (18:58 +0100)] 
[BUG] server check intervals must not be null

If server check interval is null, we might end up looping in
process_srv_chk().

Prevent those values from being zero and add some control in
process_srv_chk() against infinite loops.

16 years ago[MINOR] stats: report number of tasks (active and running)
Willy Tarreau [Sat, 21 Mar 2009 17:33:52 +0000 (18:33 +0100)] 
[MINOR] stats: report number of tasks (active and running)

It may be useful for statistics purposes to report the number of
tasks.

16 years ago[MINOR] task: keep a task count and clean up task creators
Willy Tarreau [Sat, 21 Mar 2009 17:13:21 +0000 (18:13 +0100)] 
[MINOR] task: keep a task count and clean up task creators

It's sometimes useful at least for statistics to keep a task count.
It's easy to do by forcing the rare task creators to always use the
same functions to create/destroy a task.

16 years ago[MINOR] sched: permit a task to stay up between calls
Willy Tarreau [Sat, 21 Mar 2009 12:26:05 +0000 (13:26 +0100)] 
[MINOR] sched: permit a task to stay up between calls

If a task wants to stay in the run queue, it is possible. It just
needs to wake itself up. We just want to ensure that a reniced
task will be processed at the right instant.

16 years ago[BUG] scheduler: fix improper handling of duplicates __task_queue()
Willy Tarreau [Sat, 21 Mar 2009 11:51:40 +0000 (12:51 +0100)] 
[BUG] scheduler: fix improper handling of duplicates __task_queue()

The top of a duplicate tree is not where bit == -1 but at the most
negative bit. This was causing tasks to be queued in reverse order
within duplicates. While this is not dramatic, it's incorrect and
might lead to longer than expected duplicate depths under some
circumstances.

16 years ago[BUG] sched: don't leave 3 lasts tasks unprocessed when niced tasks are present
Willy Tarreau [Sat, 21 Mar 2009 10:53:09 +0000 (11:53 +0100)] 
[BUG] sched: don't leave 3 lasts tasks unprocessed when niced tasks are present

When there are niced tasks, we would only process #tasks/4 per
turn, without taking care of running #tasks when #tasks was below
4, leaving those tasks waiting for a few other tasks to push them.

The fix simply consists in checking (#tasks+3)/4.

16 years ago[MEDIUM] scheduler: get rid of the 4 trees thanks and use ebtree v4.1
Willy Tarreau [Sat, 21 Mar 2009 09:01:42 +0000 (10:01 +0100)] 
[MEDIUM] scheduler: get rid of the 4 trees thanks and use ebtree v4.1

Since we're now able to search from a precise expiration date in
the timer tree using ebtree 4.1, we don't need to maintain 4 trees
anymore. Not only does this simplify the code a lot, but it also
ensures that we can always look 24 days back and ahead, which
doubles the ability of the previous scheduler. Indeed, while based
on absolute values, the timer tree is now relative to <now> as we
can always search from <now>-31 bits.

The run queue uses the exact same principle now, and is now simpler
and a bit faster to process. With these changes alone, an overall
0.5% performance gain was observed.

Tests were performed on the few wrapping cases and everything works
as expected.

16 years ago[MINOR] update ebtree to version 4.1
Willy Tarreau [Sat, 21 Mar 2009 06:40:32 +0000 (07:40 +0100)] 
[MINOR] update ebtree to version 4.1

Ebtree version 4.1 brings lookup by ranges. This will be useful for
the scheduler.

16 years ago[BUILD] Fixed Makefile for linking pcre
Christian Wiese [Thu, 20 Nov 2008 13:47:04 +0000 (14:47 +0100)] 
[BUILD] Fixed Makefile for linking pcre

If both make parameters USE_PCRE and USE_STATIC_PCRE are set to 1
while building haproxy, pcre gets linked in dynamically.

Therefore we check if USE_STATIC_PCRE was explicitely enabled to
ommit the CFLAGS and LDFLAGS normally set if USE_PCRE is enabled.

16 years ago[CONTRIB] selinux policy for haproxy
Jan-Frode Myklebust [Tue, 17 Mar 2009 20:26:43 +0000 (21:26 +0100)] 
[CONTRIB] selinux policy for haproxy

Here's an selinux policy for haproxy. The patch is built and lightly
tested with haproxy-1.3.15.7-1.fc10.i386 on Fedora9, and haproxy-1.2.18
on RHEL5.

16 years ago[CLEANUP] http: remove some commented out obsolete code in process_response
Willy Tarreau [Sun, 15 Mar 2009 22:11:49 +0000 (23:11 +0100)] 
[CLEANUP] http: remove some commented out obsolete code in process_response

16 years ago[MINOR] tcp_request: let the caller take care of errors and timeouts
Willy Tarreau [Sun, 15 Mar 2009 21:55:47 +0000 (22:55 +0100)] 
[MINOR] tcp_request: let the caller take care of errors and timeouts

tcp_request is not meant to decide how an error or a timeout has to
be handled. It must just apply it rules. Now that the error checks
have been added to the session, we don't need to check them anymore
in tcp_request_inspect(), which will only consider the shutdown which
may be the result of such an error.

That makes a lot more sense since tcp_request is not really waiting
for a request.

16 years ago[BUG] session: errors were not reported in termination flags in TCP mode
Willy Tarreau [Sun, 15 Mar 2009 21:34:05 +0000 (22:34 +0100)] 
[BUG] session: errors were not reported in termination flags in TCP mode

In order to get termination flags properly updated, the session was
relying a bit too much on http_return_srv_error() which is http-centric.

A generic srv_error function was implemented in the session in order to
catch all connection abort situations. It was then noticed that a request
abort during a connection attempt was not reported, which is now fixed.

Read and write errors/timeouts were not logged either. It was necessary
to add those tests at 4 new locations.

Now it looks like everything is correctly logged. Most likely some error
checking code could now be removed from some analysers.

16 years ago[BUG] connect timeout is in the stream interface, not the buffer
Willy Tarreau [Sun, 15 Mar 2009 20:49:00 +0000 (21:49 +0100)] 
[BUG] connect timeout is in the stream interface, not the buffer

The connect timeout was not properly detected due to the fact that
it was not correctly initialized. It must be set as the stream interface
timeout, not the buffer's write timeout.

16 years ago[CLEANUP] config: catch and report some possibly wrong rule ordering
Willy Tarreau [Sun, 15 Mar 2009 14:23:16 +0000 (15:23 +0100)] 
[CLEANUP] config: catch and report some possibly wrong rule ordering

There are some configurations in which redirect rules are declared
after use_backend rules. We can also find "block" rules after any
of these ones. The processing sequence is :
  - block
  - redirect
  - use_backend

So as of now we try to detect wrong ordering to warn the user about
a possibly undesired behaviour.

16 years ago[MEDIUM] reverse internal proxy declaration order to match configuration
Willy Tarreau [Sun, 15 Mar 2009 13:51:53 +0000 (14:51 +0100)] 
[MEDIUM] reverse internal proxy declaration order to match configuration

People are regularly complaining that proxies are linked in reverse
order when reading the stats. This is now definitely fixed because
the proxy order is now fixed to match configuration order.

16 years ago[MINOR] tcp-inspect: permit the use of no-delay inspection
Willy Tarreau [Sun, 15 Mar 2009 13:43:58 +0000 (14:43 +0100)] 
[MINOR] tcp-inspect: permit the use of no-delay inspection

Sometimes it may make sense to be able to immediately apply a verdict
without waiting at all. It was not possible because no inspect-delay
meant no inspection at all. This is now fixed.

16 years ago[MINOR] cfgparse: set backends to "balance roundrobin" by default
Willy Tarreau [Sun, 15 Mar 2009 13:06:41 +0000 (14:06 +0100)] 
[MINOR] cfgparse: set backends to "balance roundrobin" by default

When a backend has no LB algo specified and is not in dispatch, proxy
nor transparent mode, use "balance roundrobin" by default instead of
complaining. This will be particularly useful with stats and redirects.

16 years ago[MINOR] cfgparse: some cleanups in the consistency checks
Willy Tarreau [Sun, 15 Mar 2009 12:46:16 +0000 (13:46 +0100)] 
[MINOR] cfgparse: some cleanups in the consistency checks

Check for servers in health mode, for health mode in pure-backends.
Some code have been refactored for better organization.

16 years ago[MINOR] show errors: encode backslash as well as non-ascii characters
Willy Tarreau [Thu, 12 Mar 2009 07:18:33 +0000 (08:18 +0100)] 
[MINOR] show errors: encode backslash as well as non-ascii characters

These ones were not properly encoded, causing confusion on the output.