]> git.ipfire.org Git - thirdparty/haproxy.git/log
thirdparty/haproxy.git
12 years agoMEDIUM: HTTP compression (zlib library support)
William Lallemand [Tue, 23 Oct 2012 08:25:10 +0000 (10:25 +0200)] 
MEDIUM: HTTP compression (zlib library support)

This commit introduces HTTP compression using the zlib library.

http_response_forward_body has been modified to call the compression
functions.

This feature includes 3 algorithms: identity, gzip and deflate:

  * identity: this is mostly for debugging, and it was useful for
  developping the compression feature. With Content-Length in input, it
  is making each chunk with the data available in the current buffer.
  With chunks in input, it is rechunking, the output chunks will be
  bigger or smaller depending of the size of the input chunk and the
  size of the buffer. Identity does not apply any change on data.

  * gzip: same as identity, but applying a gzip compression. The data
  are deflated using the Z_NO_FLUSH flag in zlib. When there is no more
  data in the input buffer, it flushes the data in the output buffer
  (Z_SYNC_FLUSH). At the end of data, when it receives the last chunk in
  input, or when there is no more data to read, it writes the end of
  data with Z_FINISH and the ending chunk.

  * deflate: same as gzip, but with deflate algorithm and zlib format.
  Note that this algorithm has ambiguous support on many browsers and
  no support at all from recent ones. It is strongly recommended not
  to use it for anything else than experimentation.

You can't choose the compression ratio at the moment, it will be set to
Z_BEST_SPEED (1), as tests have shown very little benefit in terms of
compression ration when going above for HTML contents, at the cost of
a massive CPU impact.

Compression will be activated depending of the Accept-Encoding request
header. With identity, it does not take care of that header.

To build HAProxy with zlib support, use USE_ZLIB=1 in the make
parameters.

This work was initially started by David Du Colombier at Exceliance.

12 years agoCLEANUP: http: rename HTTP_MSG_DATA_CRLF state
Willy Tarreau [Thu, 25 Oct 2012 17:04:45 +0000 (19:04 +0200)] 
CLEANUP: http: rename HTTP_MSG_DATA_CRLF state

This state's name is confusing as it is only used with chunked encoding
and makes newcomers think it's also related to the content-length. Let's
call it CHUNK_CRLF to clear any doubt on this.

12 years agoOPTIM: tools: inline hex2i()
Willy Tarreau [Thu, 25 Oct 2012 22:58:22 +0000 (00:58 +0200)] 
OPTIM: tools: inline hex2i()

This tiny function was not inlined because initially not much used.
However it's been used un the chunk parser for a while and it became
one of the most CPU-cycle eater there. By inlining it, the chunk parser
speed was increased by 74 %. We're almost 3 times faster than original
with just the last 4 commits.

12 years agoOPTIM: http: inline http_parse_chunk_size() and http_skip_chunk_crlf()
Willy Tarreau [Thu, 25 Oct 2012 22:49:52 +0000 (00:49 +0200)] 
OPTIM: http: inline http_parse_chunk_size() and http_skip_chunk_crlf()

These functions are not that long and the compiler inlines them well. Doing
so has sped up the chunked encoding parser by 41% !

Note that http_forward_trailers was also declared static because it's not
exported.

12 years agoOPTIM: channel: inline channel_forward's fast path
Willy Tarreau [Thu, 25 Oct 2012 22:21:52 +0000 (00:21 +0200)] 
OPTIM: channel: inline channel_forward's fast path

Most calls to channel_forward() are performed with short byte counts and
are already optimized in channel_forward() taking just a few instructions.
Thus it's a waste of CPU cycles to call a function for this, let's just
inline the short byte count case and fall back to the common one for
remaining situations.

Doing so has increased the chunked encoding parser's performance by 12% !

12 years agoMEDIUM: http: accept IPv6 values with (s)hdr_ip acl
Cyril Bonté [Wed, 24 Oct 2012 22:01:06 +0000 (00:01 +0200)] 
MEDIUM: http: accept IPv6 values with (s)hdr_ip acl

Commit ceb4ac9c states that IPv6 values are accepted by "hdr_ip" acl,
but the code didn't allow it. This patch provides the ability to accept IPv6
values.

12 years agoBUG/MAJOR: fix a segfault on option http_proxy and url_ip acl
Cyril Bonté [Wed, 24 Oct 2012 21:47:47 +0000 (23:47 +0200)] 
BUG/MAJOR: fix a segfault on option http_proxy and url_ip acl

url2sa() mistakenly uses "addr" as a reference. This causes a segfault when
option http_proxy or url_ip are used.

This bug was introduced in haproxy 1.5 and doesn't need to be backported.

12 years agoBUG/MEDIUM: acls using IPv6 subnets patterns incorrectly match IPs
Cyril Bonté [Tue, 23 Oct 2012 19:28:31 +0000 (21:28 +0200)] 
BUG/MEDIUM: acls using IPv6 subnets patterns incorrectly match IPs

Some tests revealed that IPs not in the range of IPv6 subnets incorrectly
matched (for example "acl BUG src 2804::/16" applied to a src IP "127.0.0.1").

This is caused by the acl_match_ip() function applies a mask in host byte
order, whereas it should be in network byte order.

12 years agoMEDIUM: cli: allow the stats socket to be bound to a specific set of processes
Willy Tarreau [Mon, 22 Oct 2012 21:17:18 +0000 (23:17 +0200)] 
MEDIUM: cli: allow the stats socket to be bound to a specific set of processes

Using "stats bind-process", it becomes possible to indicate to haproxy which
process will get the incoming connections to the stats socket. It will also
shut down the warning when nbproc > 1.

12 years agoBUG/MAJOR: connection: risk of crash on certain tricky close scenario
Willy Tarreau [Mon, 22 Oct 2012 20:47:55 +0000 (22:47 +0200)] 
BUG/MAJOR: connection: risk of crash on certain tricky close scenario

In some circumstances, if the connection to the server is aborted while
some data were planned to be sent and the poller reported an ability to
send, then conn_fd_handler() would still call conn->data->send(), causing
the data layer to dereference the now NULL conn->xprt and crash.

So we have to check for conn->xprt validity before calling the data
layer.

This issue was introduced after 1.5-dev12 so it does not need any backport
and does not affect any released version.

Special thanks go to Cristian Ditoiu who once again provided amazing help
to troubleshoot this bug !

12 years agoMEDIUM: listener: provide a fallback for accept4() when not supported
Willy Tarreau [Mon, 22 Oct 2012 17:32:55 +0000 (19:32 +0200)] 
MEDIUM: listener: provide a fallback for accept4() when not supported

It happens that on some systems, the libc is recent enough to permit
building with accept4() but the kernel does not support it. The result
is then a disaster since no connection is accepted. We now detect this
and automatically fall back to accept() and fcntl() when this happens.

12 years agoMINOR: sample: export 'sample_get_trash_chunk(void)'
Emeric Brun [Wed, 17 Oct 2012 13:34:03 +0000 (15:34 +0200)] 
MINOR: sample: export 'sample_get_trash_chunk(void)'

This will be used on external fetch modules.

12 years agoMINOR: acl: add parse and match primitives to use binary type on ACLs
Emeric Brun [Wed, 17 Oct 2012 11:38:19 +0000 (13:38 +0200)] 
MINOR: acl: add parse and match primitives to use binary type on ACLs

Binary ACL match patterns can now be entered as hex digit strings.

12 years agoMINOR: sample: manage binary to string type convertion in stick-table and samples.
Emeric Brun [Wed, 17 Oct 2012 11:36:06 +0000 (13:36 +0200)] 
MINOR: sample: manage binary to string type convertion in stick-table and samples.

Binary type is converted to a null terminated hexa string.

12 years agoDOC: make it clear what the HTTP request size is
Dmitry Sivachenko [Sun, 21 Oct 2012 14:10:25 +0000 (18:10 +0400)] 
DOC: make it clear what the HTTP request size is

Please consider the following patch for configuration.txt to clarify meaning
of bufsize, maxrewrite and the size of HTTP request which can be processed.

12 years agoBUG/MEDIUM: http: set DONTWAIT on data when switching to tunnel mode
Willy Tarreau [Sat, 20 Oct 2012 08:38:09 +0000 (10:38 +0200)] 
BUG/MEDIUM: http: set DONTWAIT on data when switching to tunnel mode

Jaroslaw Bojar diagnosed an issue when haproxy switches to tunnel mode
after a transfer. The response data are sent with the MSG_MORE flag,
causing them to be needlessly queued in the kernel. In order to fix this,
we set the CF_NEVER_WAIT flag on the channels when switching to tunnel
mode.

One issue remained with client-side keep-alive : if the response is sent
before the end of the request, it suffers the same issue for the same
reason. This is easily addressed by setting the CF_SEND_DONTWAIT flag
on the channel when the response has been parsed and we're waiting for
the other side.

The same issue is present in 1.4 so the fix must be backported.

12 years agoMINOR: ssl: improve socket behaviour upon handshake abort.
Willy Tarreau [Fri, 19 Oct 2012 18:52:18 +0000 (20:52 +0200)] 
MINOR: ssl: improve socket behaviour upon handshake abort.

While checking haproxy's SSL stack with www.ssllabs.com, it appeared that
immediately closing upon a failed handshake caused a TCP reset to be emitted.
This is because OpenSSL does not consume pending data in the socket buffers.
One side effect is that if the reset packet is lost, the client might not get
it. So now when a handshake fails, we try to clean the socket buffers before
closing, resulting in a clean FIN instead of an RST.

12 years agoMEDIUM: sample: pass an empty list instead of a null for fetch args
Willy Tarreau [Fri, 19 Oct 2012 17:49:09 +0000 (19:49 +0200)] 
MEDIUM: sample: pass an empty list instead of a null for fetch args

ACL and sample fetches use args list and it is really not convenient to
check for null args everywhere. Now for empty args we pass a constant
list of end of lists. It will allow us to remove many useless checks.

12 years agoMINOR: sample: accept fetch keywords without parenthesis
Willy Tarreau [Fri, 19 Oct 2012 14:47:23 +0000 (16:47 +0200)] 
MINOR: sample: accept fetch keywords without parenthesis

fetch keywords which support arguments do not support being called
without parenthesis even if all arguments are optional. Let's fix
this to allow fetch keywords without parenthesis as is already done
in ACLs.

12 years agoMINOR: chunk: provide string compare functions
Willy Tarreau [Fri, 19 Oct 2012 13:18:06 +0000 (15:18 +0200)] 
MINOR: chunk: provide string compare functions

It's sometimes needed to be able to compare a zero-terminated string with a
chunk, so we now have two functions to do that, one strcmp() equivalent and
one strcasecmp() equivalent.

12 years agoBUG: ssl: fix ssl_sni ACLs to correctly process regular expressions
Willy Tarreau [Fri, 19 Oct 2012 12:34:30 +0000 (14:34 +0200)] 
BUG: ssl: fix ssl_sni ACLs to correctly process regular expressions

ssl_sni_reg was using acl_parse_str which is wrong since we're parsing
a regex. Additionally, neither _end nor _reg may be looked up.

12 years agoMEDIUM: ssl: add support for the "npn" bind keyword
Willy Tarreau [Thu, 18 Oct 2012 16:57:14 +0000 (18:57 +0200)] 
MEDIUM: ssl: add support for the "npn" bind keyword

The ssl_npn match could not work by itself because clients do not use
the NPN extension unless the server advertises the protocols it supports.
Thanks to Simone Bordet for the explanations on how to get it right.

12 years agoBUILD: ssl: fix shctx build on older compilers
Willy Tarreau [Thu, 18 Oct 2012 13:11:52 +0000 (15:11 +0200)] 
BUILD: ssl: fix shctx build on older compilers

gcc < 3 breaks on shctx because of the missing arg in the lock macros.
We don't need the arg at all, it's not used.

12 years agoDOC: fix minor typo on http-send-name-header
Cyril Bonté [Mon, 15 Oct 2012 17:44:24 +0000 (19:44 +0200)] 
DOC: fix minor typo on http-send-name-header

The "server" keyword documentation had a reference on "http-send-server-name"
instead of "http-send-name-header".

12 years agoMINOR: ssl: add 'ssl_npn' sample/acl to extract TLS/NPN information
Willy Tarreau [Mon, 15 Oct 2012 11:19:06 +0000 (13:19 +0200)] 
MINOR: ssl: add 'ssl_npn' sample/acl to extract TLS/NPN information

This may be used to distinguish between SPDY versions for example.

12 years agoDOC: document relations between internal entities
Willy Tarreau [Sun, 14 Oct 2012 12:05:16 +0000 (14:05 +0200)] 
DOC: document relations between internal entities

Links between internal structures have been represented in
entities.fig. The pdf and svg versions were added too.

12 years agoOPTIM: connection: pack the struct target
Willy Tarreau [Sat, 13 Oct 2012 12:33:58 +0000 (14:33 +0200)] 
OPTIM: connection: pack the struct target

The struct target contains one int and one pointer, causing it to be
64-bit aligned on 64-bit platforms. By marking it "packed", we can
save 8 bytes in struct connection and as many in struct session on
such platforms.

12 years agoOPTIM: session: reorder struct session fields
Willy Tarreau [Sat, 13 Oct 2012 09:22:24 +0000 (11:22 +0200)] 
OPTIM: session: reorder struct session fields

A reorering of the struct session fields has increased overall performance
by almost 1% due to better cache usage.

12 years agoCLEANUP: session: remove term_trace which is not used anymore
Willy Tarreau [Sat, 13 Oct 2012 09:09:14 +0000 (11:09 +0200)] 
CLEANUP: session: remove term_trace which is not used anymore

This field was used to trace precisely where a session was terminated
but it did not survive code rearchitecture and was not used at all
anymore. Let's get rid of it.

12 years agoOPTIM: channel: reorganize struct members to improve cache efficiency
Willy Tarreau [Sat, 13 Oct 2012 08:05:56 +0000 (10:05 +0200)] 
OPTIM: channel: reorganize struct members to improve cache efficiency

Now that the buffer is moved out of the channel, it is possible to move
the pointer earlier in the struct and reorder some fields. This new
ordering improves overall performance by 2%, mainly saved in the HTTP
parsers and data transfers.

12 years agoMAJOR: channel: replace the struct buffer with a pointer to a buffer
Willy Tarreau [Fri, 12 Oct 2012 21:49:43 +0000 (23:49 +0200)] 
MAJOR: channel: replace the struct buffer with a pointer to a buffer

With this commit, we now separate the channel from the buffer. This will
allow us to replace buffers on the fly without touching the channel. Since
nobody is supposed to keep a reference to a buffer anymore, doing so is not
a problem and will also permit some copy-less data manipulation.

Interestingly, these changes have shown a 2% performance increase on some
workloads, probably due to a better cache placement of data.

12 years agoCLEANUP: acl: use 'chn' instead of 'b' to name channel pointers
Willy Tarreau [Fri, 12 Oct 2012 21:58:13 +0000 (23:58 +0200)] 
CLEANUP: acl: use 'chn' instead of 'b' to name channel pointers

As with previous patches, this naming is confusing.

12 years agoCLEANUP: stream_interface: use 'chn' instead of 'b' to name channel pointers
Willy Tarreau [Fri, 12 Oct 2012 21:56:57 +0000 (23:56 +0200)] 
CLEANUP: stream_interface: use 'chn' instead of 'b' to name channel pointers

As with previous patches, this naming is confusing.

12 years agoCLEANUP: tcp: use 'chn' instead of 'buf' or 'b' for channel pointer names
Willy Tarreau [Fri, 12 Oct 2012 21:53:39 +0000 (23:53 +0200)] 
CLEANUP: tcp: use 'chn' instead of 'buf' or 'b' for channel pointer names

Same as previous patches, avoid confusion in local variable names.

12 years agoCLEANUP: channel: use 'chn' instead of 'buf' as local variable names
Willy Tarreau [Fri, 12 Oct 2012 21:11:02 +0000 (23:11 +0200)] 
CLEANUP: channel: use 'chn' instead of 'buf' as local variable names

It's too confusing to see buf->buf everywhere where the first buf is
a channel. Let's fix this now.

12 years agoCLEANUP: http: use 'chn' to name channel variables, not 'buf'
Willy Tarreau [Fri, 12 Oct 2012 20:51:15 +0000 (22:51 +0200)] 
CLEANUP: http: use 'chn' to name channel variables, not 'buf'

These "buf" were confusing as they were really refering to channels. At
most places, a buffer was really all what was needed, so a struct buffer
was used instead. It is possible that the performance has slightly increased
by the removal of pointer offset in many pointer operations by directly
using the buffer pointer instead of the channel pointer.

12 years agoREORG: http: rename msg->buf to msg->chn since it's a channel
Willy Tarreau [Fri, 12 Oct 2012 20:40:39 +0000 (22:40 +0200)] 
REORG: http: rename msg->buf to msg->chn since it's a channel

It's extremely confusing to have all those msg->buf->buf everywhere after
the extraction of the buffer from the channel. Let's clean this up.

12 years agoMEDIUM: log: report SSL ciphers and version in logs using logformat %sslc/%sslv
Willy Tarreau [Fri, 12 Oct 2012 18:17:54 +0000 (20:17 +0200)] 
MEDIUM: log: report SSL ciphers and version in logs using logformat %sslc/%sslv

These two new log-format tags report the SSL protocol version (%sslv) and the
SSL ciphers (%sslc) used for the connection with the client. For instance, to
append these information just after the client's IP/port address information
on an HTTP log line, use the following configuration :

    log-format %Ci:%Cp\ %sslv:%sslc\ [%t]\ %ft\ %b/%s\ %Tq/%Tw/%Tc/%Tr/%Tt\ %st\ %B\ %cc\ \ %cs\ %tsc\ %ac/%fc/%bc/%sc/%rc\ %sq/%bq\ %hr\ %hs\ %{+Q}r

It will report a line such as the following one :

    Oct 12 20:47:30 haproxy[9643]: 127.0.0.1:43602 TLSv1:AES-SHA [12/Oct/2012:20:47:30.303] stick2~ stick2/s1 7/0/12/0/19 200 145 - - ---- 0/0/0/0/0 0/0 "GET /?t=0 HTTP/1.0"

12 years agoMINOR: log: make lf_text use a const char *
Willy Tarreau [Fri, 12 Oct 2012 17:48:16 +0000 (19:48 +0200)] 
MINOR: log: make lf_text use a const char *

lf_text() should use a const char * otherwise it makes it more complex
to use data coming from const strings.

12 years agoMEDIUM: log: add a new LW_XPRT flag to pin the transport layer
Willy Tarreau [Fri, 12 Oct 2012 16:01:49 +0000 (18:01 +0200)] 
MEDIUM: log: add a new LW_XPRT flag to pin the transport layer

This flag will have to be set on log tags which require transport layer
information. They will prevent the conn_xprt_close() call from releasing
the transport layer too early.

12 years agoMEDIUM: connection: add a flag to hold the transport layer
Willy Tarreau [Fri, 12 Oct 2012 15:50:05 +0000 (17:50 +0200)] 
MEDIUM: connection: add a flag to hold the transport layer

When we start logging SSL information, we need the SSL struct to be
present even past the conn_xprt_close() call. In order to achieve this,
we should use refcounting on the connection and the transport layer. At
the moment it's not worth using plain refcounting as only the logs require
this, so instead of real refcounting we just use a flag which will be set
by the log subsystem when SSL data need to be logged.

What happens then is that the xprt->close() call is ignored and the
transport layer is closed again during session_free(), after the log
line is emitted.

12 years agoBUG/MEDIUM: session: enable the conn_session_update() callback
Willy Tarreau [Fri, 12 Oct 2012 15:42:13 +0000 (17:42 +0200)] 
BUG/MEDIUM: session: enable the conn_session_update() callback

This callback was introduced by commit 9683e9a0 but never enabled because
the CO_FL_WAKE_DATA flag was not set. The result is that this function is
never called when an SSL handshake fails, so the connection is only closed
on timeout.

12 years agoBUG/MINOR: session: fix some leftover from debug code
Willy Tarreau [Fri, 12 Oct 2012 15:36:40 +0000 (17:36 +0200)] 
BUG/MINOR: session: fix some leftover from debug code

Commit 82569f91 moved the health and monitor-net checks to session.c
but a debug test introduced 0& to disable MSG_DONTWAIT in the recv()
call and this debug code remained there. Since the socket is marked
non-blocking, there should be no effect but it's dangerous to keep
such a thing here.

12 years agoMEDIUM: connection: always unset the transport layer upon close
Willy Tarreau [Fri, 12 Oct 2012 15:00:05 +0000 (17:00 +0200)] 
MEDIUM: connection: always unset the transport layer upon close

When calling conn_xprt_close(), we always clear the transport pointer
so that all transport layers leave the connection in the same state after
a close. This will also make it safer and cheaper to call conn_xprt_close()
multiple times if needed.

12 years agoMEDIUM: log: suffix the frontend's name with '~' when using SSL
Willy Tarreau [Fri, 12 Oct 2012 12:56:11 +0000 (14:56 +0200)] 
MEDIUM: log: suffix the frontend's name with '~' when using SSL

Until now it was not possible to know from the logs whether the incoming
connection was made over SSL or not. In order to address this in the existing
log formats, a new log format %ft was introduced, to log the frontend's name
suffixed with its transport layer. The only transport layer in use right now
is '~' for SSL, so that existing log formats for non-SSL traffic are not
affected at all, and SSL log formats have the frontend's name suffixed with
'~'.

The TCP, HTTP and CLF log format now use %ft instead of %f. This does not
affect existing log formats which still make use of %f however.

12 years agoDOC: Fix rename of options cafile and crlfile to ca-file and crl-file.
Emeric Brun [Thu, 11 Oct 2012 14:28:27 +0000 (16:28 +0200)] 
DOC: Fix rename of options cafile and crlfile to ca-file and crl-file.

12 years agoMINOR: ssl: add statements 'verify', 'ca-file' and 'crl-file' on servers.
Emeric Brun [Thu, 11 Oct 2012 14:11:36 +0000 (16:11 +0200)] 
MINOR: ssl: add statements 'verify', 'ca-file' and 'crl-file' on servers.

It now becomes possible to verify the server's certificate using the "verify"
directive. This one only supports "none" and "required", as it does not make
much sense to also support "optional" here.

12 years agoMINOR: ssl: add statement 'no-tls-tickets' on server side.
Emeric Brun [Thu, 11 Oct 2012 13:28:34 +0000 (15:28 +0200)] 
MINOR: ssl: add statement 'no-tls-tickets' on server side.

12 years agoMEDIUM: ssl: reject ssl server keywords in default-server statement
Emeric Brun [Thu, 11 Oct 2012 13:05:10 +0000 (15:05 +0200)] 
MEDIUM: ssl: reject ssl server keywords in default-server statement

At the moment they are ignored, but they were not rejected so they could
cause confusion in some configurations.

12 years agoMINOR: ssl: move ssl context init for servers from cfgparse.c to ssl_sock.c
Emeric Brun [Thu, 11 Oct 2012 12:00:19 +0000 (14:00 +0200)] 
MINOR: ssl: move ssl context init for servers from cfgparse.c to ssl_sock.c

12 years agoBUG/MINOR: ssl: Fix issue on server statements 'no-tls*' and 'no-sslv3'
Emeric Brun [Thu, 11 Oct 2012 16:36:21 +0000 (18:36 +0200)] 
BUG/MINOR: ssl: Fix issue on server statements 'no-tls*' and 'no-sslv3'

bit field collision with 'force-tlsv*'.

12 years agoMEDIUM: ssl: move "server" keyword SSL options parsing to ssl_sock.c
Willy Tarreau [Wed, 10 Oct 2012 21:04:25 +0000 (23:04 +0200)] 
MEDIUM: ssl: move "server" keyword SSL options parsing to ssl_sock.c

All SSL-specific "server" keywords are now processed in ssl_sock.c. At
the moment, there is no more "not implemented" hint when SSL is disabled,
but keywords could be added in server.c if needed.

12 years agoBUG/MEDIUM: config: check-send-proxy was ignored if SSL was not builtin
Willy Tarreau [Wed, 10 Oct 2012 21:01:14 +0000 (23:01 +0200)] 
BUG/MEDIUM: config: check-send-proxy was ignored if SSL was not builtin

Improper insertion within #if/#endif SSL causes the check-send-proxy state
not to be automatically enabled if SSL is disabled at build time.

12 years agoMEDIUM: server: move parsing of keyword "id" to server.c
Willy Tarreau [Wed, 10 Oct 2012 15:51:05 +0000 (17:51 +0200)] 
MEDIUM: server: move parsing of keyword "id" to server.c

This is the first keyword to be moved to server.c.

12 years agoMEDIUM: server: check for registered keywords when parsing unknown keywords
Willy Tarreau [Wed, 10 Oct 2012 06:57:40 +0000 (08:57 +0200)] 
MEDIUM: server: check for registered keywords when parsing unknown keywords

At this point, no server keyword is registered yet. The help line does
not report supported keywords anymore since it lists the registered ones
only.

12 years agoMINOR: standard: make indent_msg() support empty messages
Willy Tarreau [Wed, 10 Oct 2012 06:56:47 +0000 (08:56 +0200)] 
MINOR: standard: make indent_msg() support empty messages

indent_msg() is called with dynamically generated messages, so these
may be empty (NULL) when an empty list is being dumped. Support this
and return a NULL too.

12 years agoMINOR: server: add minimal infrastructure to parse keywords
Willy Tarreau [Wed, 10 Oct 2012 06:27:36 +0000 (08:27 +0200)] 
MINOR: server: add minimal infrastructure to parse keywords

Just like with the "bind" lines, we'll switch the "server" line
parsing to keyword registration. The code is essentially the same
as for bind keywords, with minor changes such as support for the
default-server keywords and support for variable argument count.

12 years agoBUILD: accept4: move the socketcall declaration outside of accept4()
Willy Tarreau [Wed, 10 Oct 2012 06:26:12 +0000 (08:26 +0200)] 
BUILD: accept4: move the socketcall declaration outside of accept4()

Gcc 4.2.4 breaks on the syscall declared inside the function, move it
outside and declare it static inline.

12 years agoMINOR: halog: add a parameter to limit output line count
Willy Tarreau [Wed, 10 Oct 2012 14:49:28 +0000 (16:49 +0200)] 
MINOR: halog: add a parameter to limit output line count

Sometimes it's useful to limit the output to a number of lines, for
example when output is already sorted (eg: 10 slowest URLs, ...). Now
we can use -m for this.

12 years agoBUG/MINOR: halog: fix help message for -ut/-uto
Willy Tarreau [Wed, 10 Oct 2012 12:57:35 +0000 (14:57 +0200)] 
BUG/MINOR: halog: fix help message for -ut/-uto

Erroneous copy-paste suggesting wrong option.

12 years agoBUG/MINOR: halog: -ad/-ac report the correct number of output lines
Willy Tarreau [Wed, 10 Oct 2012 11:41:52 +0000 (13:41 +0200)] 
BUG/MINOR: halog: -ad/-ac report the correct number of output lines

There was a lines_out++ left from earlier code, causing each input
line to be counted as an output line.

This fix also affects 1.4 and should be backported.

12 years agoMINOR: halog: sort output by cookie code
Willy Tarreau [Wed, 10 Oct 2012 08:26:22 +0000 (10:26 +0200)] 
MINOR: halog: sort output by cookie code

It's sometimes useful to have the output sorted by cookie code to see
the ratios of NI vs VN for example. This is now possible with -cc.

12 years agoDOC: ssl: surround keywords with quotes
Cyril Bonté [Tue, 9 Oct 2012 20:45:34 +0000 (22:45 +0200)] 
DOC: ssl: surround keywords with quotes

In order to make external tools easily detect keywords in the documentation,
let's surround them by quotes as it is done for other keywords.

12 years agoDOC: ssl: remove prefer-server-ciphers documentation
Cyril Bonté [Tue, 9 Oct 2012 20:45:33 +0000 (22:45 +0200)] 
DOC: ssl: remove prefer-server-ciphers documentation

Commit 3c4bc6e1 removed the prefer-server-ciphers statement.
Therefore, the statement should also be removed from the documentation.

12 years agoMEDIUM: listener: add support for linux's accept4() syscall
Willy Tarreau [Mon, 8 Oct 2012 18:11:03 +0000 (20:11 +0200)] 
MEDIUM: listener: add support for linux's accept4() syscall

On Linux, accept4() does the same as accept() except that it allows
the caller to specify some flags to set on the resulting socket. We
use this to set the O_NONBLOCK flag and thus to save one fcntl()
call in each connection. The effect is a small performance gain of
around 1%.

The option is automatically enabled when target linux2628 is set, or
when the USE_ACCEPT4 Makefile variable is set. If the libc is too old
to provide the equivalent function, this is automatically detected and
our own function is used instead. In any case it is possible to force
the use of our implementation with USE_MY_ACCEPT4.

12 years agoBUG/MAJOR: ensure that hdr_idx is always reserved when L7 fetches are used
Willy Tarreau [Fri, 5 Oct 2012 20:41:26 +0000 (22:41 +0200)] 
BUG/MAJOR: ensure that hdr_idx is always reserved when L7 fetches are used

Baptiste Assmann reported a bug causing a crash on recent versions when
sticking rules were set on layer 7 in a TCP proxy. The bug is easier to
reproduce with the "defer-accept" option on the "bind" line in order to
have some contents to parse when the connection is accepted. The issue
is that the acl_prefetch_http() function called from HTTP fetches relies
on hdr_idx to be preinitialized, which is not the case if there is no L7
ACL.

The solution consists in adding a new SMP_CAP_L7 flag to fetches to indicate
that they are expected to work on L7 data, so that the proxy knows that the
hdr_idx has to be initialized. This is already how ACL and HTTP mode are
handled.

The bug was present since 1.5-dev9.

12 years agoCLEANUP: cttproxy: remove a warning on undeclared close()
Willy Tarreau [Fri, 5 Oct 2012 20:18:07 +0000 (22:18 +0200)] 
CLEANUP: cttproxy: remove a warning on undeclared close()

This one is harmless and only happens on old systems anyway.

12 years agoMINOR: ssl: add defines LISTEN_DEFAULT_CIPHERS and CONNECT_DEFAULT_CIPHERS.
Emeric Brun [Fri, 5 Oct 2012 13:47:31 +0000 (15:47 +0200)] 
MINOR: ssl: add defines LISTEN_DEFAULT_CIPHERS and CONNECT_DEFAULT_CIPHERS.

These ones are used to set the default ciphers suite on "bind" lines and
"server" lines respectively, instead of using OpenSSL's defaults. These
are probably mainly useful for distro packagers.

12 years agoMINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on server
Emeric Brun [Fri, 5 Oct 2012 12:39:07 +0000 (14:39 +0200)] 
MINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on server

These options force the SSL lib to use the specified protocol when
connecting to a server. They are complentary to no-tlsv*/no-sslv3.

12 years agoMINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on bind.
Emeric Brun [Fri, 5 Oct 2012 12:14:21 +0000 (14:14 +0200)] 
MINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on bind.

These options force the SSL lib to use the specified protocol. They
are complentary to no-tlsv*/no-sslv3.

12 years agoMINOR: ssl: use bit fields to store ssl options instead of one int each
Emeric Brun [Fri, 5 Oct 2012 11:48:26 +0000 (13:48 +0200)] 
MINOR: ssl: use bit fields to  store ssl options instead of one int each

Too many SSL options already and some still to come, use a bit field
and get rid of all the integers. No functional change here.

12 years agoMEDIUM: conf: rename 'cafile' and 'crlfile' statements 'ca-file' and 'crl-file'
Emeric Brun [Fri, 5 Oct 2012 10:00:26 +0000 (12:00 +0200)] 
MEDIUM: conf: rename 'cafile' and 'crlfile' statements 'ca-file' and 'crl-file'

These names were not really handy.

12 years agoMEDIUM: conf: rename 'nosslv3' and 'notlsvXX' statements 'no-sslv3' and 'no-tlsvXX'.
Emeric Brun [Fri, 5 Oct 2012 09:55:06 +0000 (11:55 +0200)] 
MEDIUM: conf: rename 'nosslv3' and 'notlsvXX' statements 'no-sslv3' and 'no-tlsvXX'.

These ones were really not easy to read nor write, and become confusing
with the next ones to be added.

12 years agoMINOR: ssl: add 'crt-base' and 'ca-base' global statements.
Emeric Brun [Tue, 2 Oct 2012 16:42:10 +0000 (18:42 +0200)] 
MINOR: ssl: add 'crt-base' and 'ca-base' global statements.

'crt-base' sets root directory used for relative certificates paths.
'ca-base' sets root directory used for relative CAs and CRLs paths.

12 years agoBUG/MEDIUM: ssl: subsequent handshakes fail after server configuration changes
Emeric Brun [Thu, 4 Oct 2012 15:09:56 +0000 (17:09 +0200)] 
BUG/MEDIUM: ssl: subsequent handshakes fail after server configuration changes

On server's configuration change, if the previously used
cipher is disabled, all subsequent connect attempts fail.

Fix consists in freeing cached session on handshake failure.

12 years agoBUG: connection: fix regression from commit 9e272bf9
Willy Tarreau [Fri, 5 Oct 2012 19:29:37 +0000 (21:29 +0200)] 
BUG: connection: fix regression from commit 9e272bf9

Commit 9e272bf9 broke connection setup in TCP mode, the comment was
misleading and obviously wrong, as after a connection is established,
we *do* have none of the CONNECT* flags. However we can never have
them all at the same time, so let's use this to trigger a detection.

12 years agoMINOR: ssl: remove prefer-server-ciphers statement and set it as the default on ssl...
Emeric Brun [Thu, 4 Oct 2012 16:44:19 +0000 (18:44 +0200)] 
MINOR: ssl: remove prefer-server-ciphers statement and set it as the default on ssl listeners.

12 years agoBUG/MINOR: build: Fix failure with USE_OPENSSL=1 and USE_FUTEX=1 on archs i486 and...
Emeric Brun [Thu, 4 Oct 2012 15:28:25 +0000 (17:28 +0200)] 
BUG/MINOR: build: Fix failure with USE_OPENSSL=1 and USE_FUTEX=1 on archs i486 and i686.

12 years agoBUG/MINOR: conf: Fix 'maxsslconn' statement error if built without OPENSSL.
Emeric Brun [Tue, 2 Oct 2012 16:45:42 +0000 (18:45 +0200)] 
BUG/MINOR: conf: Fix 'maxsslconn' statement error if built without OPENSSL.

12 years agoMEDIUM: tcp: enable TCP Fast Open on systems which support it
Willy Tarreau [Fri, 5 Oct 2012 14:21:00 +0000 (16:21 +0200)] 
MEDIUM: tcp: enable TCP Fast Open on systems which support it

If TCP_FASTOPEN is defined, then the "tfo" option is supported on
"bind" lines to enable TCP Fast Open (linux >= 3.6).

12 years agoMINOR: samples: update the url_param fetch to match parameters in the path
bedis [Fri, 5 Oct 2012 06:38:24 +0000 (08:38 +0200)] 
MINOR: samples: update the url_param fetch to match parameters in the path

It now supports an optional delimiter to allow to look for the parameter before
the query string.

12 years agoCLEANUP: checks: remove minor warnings for assigned but not used variables
Willy Tarreau [Fri, 5 Oct 2012 12:54:30 +0000 (14:54 +0200)] 
CLEANUP: checks: remove minor warnings for assigned but not used variables

We don't use the return value from snd_buf/rcv_buf anymore since we only
rely on the connection flags.

12 years agoBUILD: fix build issue without USE_OPENSSL
Baptiste Assmann [Fri, 5 Oct 2012 09:48:04 +0000 (11:48 +0200)] 
BUILD: fix build issue without USE_OPENSSL

The SSL check referenced use_ssl which only exists when USE_OPENSSL is set.

12 years agoMEDIUM: checks: enable the PROXY protocol with health checks
Willy Tarreau [Thu, 4 Oct 2012 22:04:16 +0000 (00:04 +0200)] 
MEDIUM: checks: enable the PROXY protocol with health checks

When health checks are configured on a server which has the send-proxy
directive and no "port" nor "addr" settings, the health check connections
will automatically use the PROXY protocol. If "port" or "addr" are set,
the "check-send-proxy" directive may be used to force the protocol.

12 years agoMEDIUM: checks: add the "check-ssl" server option
Willy Tarreau [Thu, 4 Oct 2012 21:15:39 +0000 (23:15 +0200)] 
MEDIUM: checks: add the "check-ssl" server option

This option forces health checks to be sent over SSL even if the
address or port are not the standard ones.

12 years agoMAJOR: checks: completely use the connection transport layer
Willy Tarreau [Fri, 28 Sep 2012 17:39:36 +0000 (19:39 +0200)] 
MAJOR: checks: completely use the connection transport layer

With this change, we now use the connection's transport layer to receive
and send data during health checks. It even becomes possible to send data
in multiple times, which was not possible before.

The transport layer used is the same as the one used for the traffic, unless
a specific address and/or port is specified for the checks using "port" or
"addr", in which case the transport layer defaults to raw_sock. An option
will be provided to force SSL checks on different IP/ports later.

Connection errors and timeouts are still reported.

Some situations where strerror() was able to report a precise error after
a failed connect() in the past might not be reported with as much precision
anymore, but the error message was already meaningless. During the tests,
no situation was found where a message became less precise.

12 years agoMEDIUM: check: add the ctrl and transport layers in the server check structure
Willy Tarreau [Fri, 28 Sep 2012 16:13:10 +0000 (18:13 +0200)] 
MEDIUM: check: add the ctrl and transport layers in the server check structure

Since it's possible for the checks to use a different protocol or transport layer
than the prod traffic, we need to have them referenced in the server. The
SSL checks are not enabled yet, but the transport layers are completely used.

12 years agoMEDIUM: checks: use real buffers to store requests and responses
Willy Tarreau [Fri, 28 Sep 2012 13:28:30 +0000 (15:28 +0200)] 
MEDIUM: checks: use real buffers to store requests and responses

Till now the request was made in the trash and sent to the network at
once, and the response was read into a preallocated char[]. Now we
allocate a full buffer for both the request and the response, and make
use of it.

Some of the operations will probably be replaced later with buffer macros
but the point was to ensure we could migrate to use the data layers soon.

One nice improvement caused by this change is that requests are now formed
at the beginning of the check and may safely be sent in multiple chunks if
needed.

12 years agoREORG: server: move the check-specific parts into a check subsection
Willy Tarreau [Fri, 28 Sep 2012 13:01:02 +0000 (15:01 +0200)] 
REORG: server: move the check-specific parts into a check subsection

The health checks in the servers are becoming a real mess, move them
into their own subsection. We'll soon need to have a struct buffer to
replace the char * as well as check-specific protocol and transport
layers.

12 years agoMAJOR: checks: make use of the connection layer to send checks
Willy Tarreau [Fri, 28 Sep 2012 12:40:02 +0000 (14:40 +0200)] 
MAJOR: checks: make use of the connection layer to send checks

This is a first step, we now use the connection layer without the data
layers (send/recv are still used by hand). The connection is established
using tcp_connect_server() and raw_sock is assumed and forced for now.

fdtab is not manipulated anymore and polling is managed via the connection
layer.

It becomes quite clear that the server needs a second ->ctrl and ->xprt
dedicated to the checks.

12 years agoMEDIUM: connection: add a new local send-proxy transport callback
Willy Tarreau [Thu, 4 Oct 2012 21:55:57 +0000 (23:55 +0200)] 
MEDIUM: connection: add a new local send-proxy transport callback

This callback sends a PROXY protocol line on the outgoing connection,
with the local and remote endpoint information. This is used for local
connections (eg: health checks) where the other end needs to have a
valid address and no connection is relayed.

12 years agoREORG: connection: move the PROXY protocol management to connection.c
Willy Tarreau [Thu, 4 Oct 2012 22:10:55 +0000 (00:10 +0200)] 
REORG: connection: move the PROXY protocol management to connection.c

It was previously in frontend.c but there is no reason for this anymore
considering that all the information involved is in the connection itself
only. Theorically this should be in the socket layer but we don't have
this yet.

12 years agoMEDIUM: connection: automatically disable polling on error
Willy Tarreau [Thu, 4 Oct 2012 20:21:15 +0000 (22:21 +0200)] 
MEDIUM: connection: automatically disable polling on error

We absolutely want to disable FD polling after an error is detected,
otherwise the data layer has to do it and it's far from being obvious
at these layers.

The way we did it was a bit tricky in conn_update_*_polling and
conn_*_polling_changes. However it has almost no impact on performance
and code size both for the fast and slow path.

We'll now be able to remove some flag updates in the stream interface.

12 years agoMEDIUM: connection: it's not the data layer's role to validate the connection
Willy Tarreau [Thu, 4 Oct 2012 18:20:46 +0000 (20:20 +0200)] 
MEDIUM: connection: it's not the data layer's role to validate the connection

Till now we used to perform the L4_CONN check in the data layer
(eg: stream interface) but that does not make sense, because some transport
layers will imply that the connection is opened (eg: SSL), and also because
the complexity to check for this is higher in the data layer than in the
transport layer. This is so much true that some read0 cases did not validate
the connection.

So as of now, the transport layer is responsible for clearing L4_CONN when
it detects an activity, and the data layer may safely rely on this flag. This
only impacts a minor change in raw_sock and stream_interface for now.

12 years agoMEDIUM: connection: don't call the data->init callback upon error
Willy Tarreau [Wed, 3 Oct 2012 19:20:21 +0000 (21:20 +0200)] 
MEDIUM: connection: don't call the data->init callback upon error

We don't call ->init() anymore upon error since we already call ->wake().

12 years agoMEDIUM: session: register a data->wake callback to process errors
Willy Tarreau [Wed, 3 Oct 2012 19:17:23 +0000 (21:17 +0200)] 
MEDIUM: session: register a data->wake callback to process errors

The connection layer will soon call ->wake() only when errors happen, and
not ->init(). So make the session layer use this callback to detect errors
and abort connections.

12 years agoMEDIUM: connection: make it possible for data->wake to return an error
Willy Tarreau [Wed, 3 Oct 2012 19:12:16 +0000 (21:12 +0200)] 
MEDIUM: connection: make it possible for data->wake to return an error

Just like ->init(), ->wake() may now be used to return an error and
abort the connection. Currently this is not used but will be with
embryonic sessions.

12 years agoMEDIUM: connection: only call the data->wake callback on activity
Willy Tarreau [Wed, 3 Oct 2012 19:04:48 +0000 (21:04 +0200)] 
MEDIUM: connection: only call the data->wake callback on activity

We now check the connection flags for changes in order not to call the
data->wake callback when there is no activity. Activity means a change
on any of the CO_FL_*_SH, CO_FL_ERROR, CO_FL_CONNECTED, CO_FL_WAIT_CONN*
flags, as well as a call to data->recv or data->send.

12 years agoMEDIUM: connection: reorganize connection flags
Willy Tarreau [Wed, 3 Oct 2012 18:00:18 +0000 (20:00 +0200)] 
MEDIUM: connection: reorganize connection flags

The connection flags have progressively been added one after the other
and were not very well organized. Some of them are often used together
and a number of operations are performed on the DATA/SOCK ENA/POL flags.
Thus, they have been reorganized so that flags that work together are
close to each other (allows immediate operands on ARM) and that polling
changes can be detected with fewer operations using a simple shift and
xor. The handshakes are now the last ones so that it will be easier to
add new ones after without risking a collision. All activity-related
flags are also grouped together.

12 years agoMEDIUM: connection: use a generic data-layer init() callback
Willy Tarreau [Tue, 2 Oct 2012 23:39:48 +0000 (01:39 +0200)] 
MEDIUM: connection: use a generic data-layer init() callback

The generic data-layer init callback is now used after the transport
layer is complete and before calling the data layer recv/send callbacks.

This allows the session to switch from the embryonic session data layer
to the complete stream interface data layer, by making conn_session_complete()
the data layer's init callback.

It sill looks awkwards that the init() callback must be used opon error,
but except by adding yet another one, it does not seem to be mergeable
into another function (eg: it should probably not be merged with ->wake
to avoid unneeded calls during the handshake, though semantically that
would make sense).