]> git.ipfire.org Git - thirdparty/haproxy.git/log
thirdparty/haproxy.git
8 years agoMINOR: lua: add function which return true if the channel is full.
Thierry FOURNIER / OZON.IO [Mon, 7 Nov 2016 14:28:40 +0000 (15:28 +0100)] 
MINOR: lua: add function which return true if the channel is full.

Add function which return true if the channel is full. It is
useful for triggering some process when the buffer is full.

8 years agoCONTRIB: debug/flags: add check for SF_ERR_CHK_PORT
Willy Tarreau [Fri, 11 Nov 2016 07:05:34 +0000 (08:05 +0100)] 
CONTRIB: debug/flags: add check for SF_ERR_CHK_PORT

This flag was added by commit 95db2bc ("MAJOR: check: find out which
port to use for health check at run time"), let's check for it.

8 years agoBUILD: debug/flags: remove test for SF_COMP_READY
Willy Tarreau [Fri, 11 Nov 2016 07:04:44 +0000 (08:04 +0100)] 
BUILD: debug/flags: remove test for SF_COMP_READY

It doesn't exist anymore.

8 years agoBUILD: http: include types/sample.h in proto_http.h
Willy Tarreau [Fri, 11 Nov 2016 06:56:48 +0000 (07:56 +0100)] 
BUILD: http: include types/sample.h in proto_http.h

Commit d7c9196 ("MAJOR: filters: Add filters support") removed sample.h
from proto_http.h, but it has become necessary as of commit fd7edd3
("MINOR: Move http method enum from proto_http to sample") in order
to have HTTP_METH_*. Due to this, the "debug/flags" utility doesn't
build anymore.

8 years agoSCRIPTS: make publish-release also copy the new SPOE doc
Willy Tarreau [Wed, 9 Nov 2016 22:21:47 +0000 (23:21 +0100)] 
SCRIPTS: make publish-release also copy the new SPOE doc

It may be useful for developers who want to experiment with the protocol.

8 years ago[RELEASE] Released version 1.7-dev6 v1.7-dev6
Willy Tarreau [Wed, 9 Nov 2016 22:18:17 +0000 (23:18 +0100)] 
[RELEASE] Released version 1.7-dev6

Released version 1.7-dev6 with the following main changes :
    - DOC: fix the entry for hash-balance-factor config option
    - DOC: Fix typo in description of `-st` parameter in man page
    - CLEANUP: cfgparse: Very minor spelling correction
    - MINOR: examples: Update haproxy.spec URLs to haproxy.org
    - BUG/MEDIUM: peers: on shutdown, wake up the appctx, not the stream
    - BUG/MEDIUM: peers: fix use after free in peer_session_create()
    - MINOR: peers: make peer_session_forceshutdown() use the appctx and not the stream
    - MINOR: peers: remove the pointer to the stream
    - BUG/MEDIUM: systemd-wrapper: return correct exit codes
    - DOC: stats: provide state details for show servers state
    - MEDIUM: tools: make str2ip2() preserve existing ports
    - CLEANUP: tools: make ipcpy() preserve the original port
    - OPTIM: http: move all http character classs tables into a single one
    - OPTIM: http: improve parsing performance of long header lines
    - OPTIM: http: improve parsing performance of long URIs
    - OPTIM: http: optimize lookup of comma and quote in header values
    - BUG/MEDIUM: srv-state: properly restore the DRAIN state
    - BUG/MINOR: srv-state: allow to have both CMAINT and FDRAIN flags
    - MINOR: server: do not emit warnings/logs/alerts on server state changes at boot
    - BUG/MEDIUM: servers: properly propagate the maintenance states during startup
    - MEDIUM: wurfl: add Scientiamobile WURFL device detection module
    - DOC: move the device detection modules documentation to their own files
    - CLEANUP: wurfl: reduce exposure in the rest of the code
    - MEDIUM: ssl: Add support for OpenSSL 1.1.0
    - MINOR: stream: make option contstats usable again
    - MEDIUM: tools: make str2sa_range() return the FQDN even when not resolving
    - MINOR: init: move apply_server_state in haproxy.c before MODE_CHECK
    - MAJOR: server: postpone address resolution
    - MINOR: new srv_admin flag: SRV_ADMF_RMAINT
    - MINOR: server: indicate in the logs when RMAINT is cleared
    - MINOR: stats: indicate it when a server is down due to resolution
    - MINOR: server: make srv_set_admin_state() capable of telling why this happens
    - MINOR: dns: implement extra 'hold' timers.
    - MAJOR: dns: runtime resolution can change server admin state
    - MEDIUM: cli: leave the RMAINT state when setting an IP address on the CLI
    - MEDIUM: server: add a new init-addr server line setting
    - MEDIUM: server: make use of init-addr
    - MINOR: server: implement init-addr none
    - MEDIUM: server: make libc resolution failure non-fatal
    - MINOR: server: add support for explicit numeric address in init-addr
    - DOC: add some documentation for the "init-addr" server keyword
    - MINOR: init: add -dr to ignore server address resolution failures
    - MEDIUM: server: do not restrict anymore usage of IP address from the state file
    - BUG: vars: Fix 'set-var' converter because of a typo
    - CLEANUP: remove last references to 'ruleset' section
    - MEDIUM: filters: Add attch/detach and stream_set_backend callbacks
    - MINOR: filters: Update filters documentation accordingly to recent changes
    - MINOR: filters: Call stream_set_backend callbacks before updating backend stats
    - MINOR: filters: Remove backend filters attached to a stream only for HTTP streams
    - MINOR: flt_trace: Add hexdump option to dump forwarded data
    - MINOR: cfgparse: Add functions to backup and restore registered sections
    - MINOR: cfgparse: Parse scope lines and save the last one parsed
    - REORG: sample: move code to release a sample expression in sample.c
    - MINOR: vars: Allow '.' in variable names
    - MINOR: vars: Add vars_set_by_name_ifexist function
    - MEDIUM: vars: Add a per-process scope for variables
    - MINOR: vars: Add 'unset-var' action/converter
    - MAJOR: spoe: Add an experimental Stream Processing Offload Engine
    - MINOR: spoe: add random ip-reputation service as SPOA example
    - MINOR: spoe/checks: Add support for SPOP health checks
    - DOC: update ROADMAP file

8 years agoDOC: update ROADMAP file
Willy Tarreau [Wed, 9 Nov 2016 22:17:05 +0000 (23:17 +0100)] 
DOC: update ROADMAP file

tcp-request session is OK now.

8 years agoMINOR: spoe/checks: Add support for SPOP health checks
Christopher Faulet [Mon, 7 Nov 2016 20:07:38 +0000 (21:07 +0100)] 
MINOR: spoe/checks: Add support for SPOP health checks

A new "option spop-check" statement has been added to enable server health
checks based on SPOP HELLO handshake. SPOP is the protocol used by SPOE filters
to talk to servers.

8 years agoMINOR: spoe: add random ip-reputation service as SPOA example
Christopher Faulet [Thu, 3 Nov 2016 21:49:37 +0000 (22:49 +0100)] 
MINOR: spoe: add random ip-reputation service as SPOA example

This is a very simple service that implement a "random" ip reputation
service. It will return random scores for all checked IP addresses. It only
shows you how to implement a ip reputation service or such kind of services
using the SPOE.

8 years agoMAJOR: spoe: Add an experimental Stream Processing Offload Engine
Christopher Faulet [Thu, 27 Oct 2016 20:29:49 +0000 (22:29 +0200)] 
MAJOR: spoe: Add an experimental Stream Processing Offload Engine

SPOE makes possible the communication with external components to retrieve some
info using an in-house binary protocol, the Stream Processing Offload Protocol
(SPOP). In the long term, its aim is to allow any kind of offloading on the
streams. This first version, besides being experimental, won't do lot of
things. The most important today is to validate the protocol design and lay the
foundations of what will, one day, be a full offload engine for the stream
processing.

So, for now, the SPOE can offload the stream processing before "tcp-request
content", "tcp-response content", "http-request" and "http-response" rules. And
it only supports variables creation/suppression. But, in spite of these limited
features, we can easily imagine to implement a SSO solution, an ip reputation
service or an ip geolocation service.

Internally, the SPOE is implemented as a filter. So, to use it, you must use
following line in a proxy proxy section:

  frontend my-front
      ...
      filter spoe [engine <name>] config <file>
      ...

It uses its own configuration file to keep the HAProxy configuration clean. It
is also a easy way to disable it by commenting out the filter line.

See "doc/SPOE.txt" for all details about the SPOE configuration.

8 years agoMINOR: vars: Add 'unset-var' action/converter
Christopher Faulet [Wed, 9 Nov 2016 15:54:56 +0000 (16:54 +0100)] 
MINOR: vars: Add 'unset-var' action/converter

It does the opposite of 'set-var' action/converter. It is really useful for
per-process variables. But, it can be used for any scope.

The lua function 'unset_var' has also been added.

8 years agoMEDIUM: vars: Add a per-process scope for variables
Christopher Faulet [Wed, 9 Nov 2016 10:36:17 +0000 (11:36 +0100)] 
MEDIUM: vars: Add a per-process scope for variables

Now it is possible to use variables attached to a process. The scope name is
'proc'. These variables are released only when HAProxy is stopped.

'tune.vars.proc-max-size' directive has been added to confiure the maximum
amount of memory used by "proc" variables. And because memory accounting is
hierachical for variables, memory for "proc" vars includes memory for "sess"
vars.

8 years agoMINOR: vars: Add vars_set_by_name_ifexist function
Christopher Faulet [Mon, 31 Oct 2016 10:05:37 +0000 (11:05 +0100)] 
MINOR: vars: Add vars_set_by_name_ifexist function

This function, unsurprisingly, sets a variable value only if it already
exists. In other words, this function will succeed only if the variable was
found somewhere in the configuration during HAProxy startup.

It will be used by SPOE filter. So an agent will be able to set a value only for
existing variables. This prevents an agent to create a very large number of
unused variables to flood HAProxy and exhaust the memory reserved to variables..

8 years agoMINOR: vars: Allow '.' in variable names
Christopher Faulet [Mon, 31 Oct 2016 09:49:03 +0000 (10:49 +0100)] 
MINOR: vars: Allow '.' in variable names

This is required to have implicit prefix or scope. SPOE filter will use it to
keep variables set by an agent in its own namespace.

8 years agoREORG: sample: move code to release a sample expression in sample.c
Christopher Faulet [Wed, 26 Oct 2016 09:34:47 +0000 (11:34 +0200)] 
REORG: sample: move code to release a sample expression in sample.c

This code has been moved from haproxy.c to sample.c and the function
release_sample_expr can now be called from anywhere to release a sample
expression. This function will be used by the stream processing offload engine
(SPOE).

8 years agoMINOR: cfgparse: Parse scope lines and save the last one parsed
Christopher Faulet [Fri, 4 Nov 2016 21:36:15 +0000 (22:36 +0100)] 
MINOR: cfgparse: Parse scope lines and save the last one parsed

A scope is a section name between square bracket, alone on its line, ie:

  [scope-name]
  ...

The spaces at the beginning and at the end of the line are skipped. Comments at
the end of the line are also skipped.

When a scope is parsed, its name is saved in the global variable
cfg_scope. Initially, cfg_scope is NULL and it remains NULL until a valid scope
line is parsed.

This feature remains unused in the HAProxy configuration file and
undocumented. However, it will be used during SPOE configuration parsing.

8 years agoMINOR: cfgparse: Add functions to backup and restore registered sections
Christopher Faulet [Wed, 26 Oct 2016 09:09:44 +0000 (11:09 +0200)] 
MINOR: cfgparse: Add functions to backup and restore registered sections

This feature will be used by the stream processing offload engine (SPOE) to
parse dedicated configuration files without mixing HAProxy sections with SPOE
sections.

So, here we can back up all sections known by HAProxy, unregister all of them
and add new ones, dedicted to the SPOE. Once the SPOE configuration file parsed,
we can roll back all changes by restoring HAProxy sections.

8 years agoMINOR: flt_trace: Add hexdump option to dump forwarded data
Christopher Faulet [Mon, 31 Oct 2016 10:27:21 +0000 (11:27 +0100)] 
MINOR: flt_trace: Add hexdump option to dump forwarded data

This is pretty verbose, but it can be handy to have it in HAProxy.

8 years agoMINOR: filters: Remove backend filters attached to a stream only for HTTP streams
Christopher Faulet [Mon, 31 Oct 2016 10:22:37 +0000 (11:22 +0100)] 
MINOR: filters: Remove backend filters attached to a stream only for HTTP streams

Now, for TCP streams, backend filters are released when the stream is
destroyed. But, for HTTP streams, these filters are released when the
transaction analyze ends, in flt_end_analyze callback.

8 years agoMINOR: filters: Call stream_set_backend callbacks before updating backend stats
Christopher Faulet [Tue, 21 Jun 2016 09:54:52 +0000 (11:54 +0200)] 
MINOR: filters: Call stream_set_backend callbacks before updating backend stats

So if an internal error is returned, the number of cumulated connections on the
backend is not incremented.

8 years agoMINOR: filters: Update filters documentation accordingly to recent changes
Christopher Faulet [Tue, 21 Jun 2016 09:50:49 +0000 (11:50 +0200)] 
MINOR: filters: Update filters documentation accordingly to recent changes

8 years agoMEDIUM: filters: Add attch/detach and stream_set_backend callbacks
Christopher Faulet [Tue, 21 Jun 2016 09:42:37 +0000 (11:42 +0200)] 
MEDIUM: filters: Add attch/detach and stream_set_backend callbacks

New callbacks have been added to handle creation and destruction of filter
instances:

* 'attach' callback is called after a filter instance creation, when it is
  attached to a stream. This happens when the stream is started for filters
  defined on the stream's frontend and when the backend is set for filters
  declared on the stream's backend. It is possible to ignore the filter, if
  needed, by returning 0. This could be useful to have conditional filtering.

* 'detach' callback is called when a filter instance is detached from a stream,
  before its destruction. This happens when the stream is stopped for filters
  defined on the stream's frontend and when the analyze ends for filters defined
  on the stream's backend.

In addition, the callback 'stream_set_backend' has been added to know when a
backend is set for a stream. It is only called when the frontend and the backend
are not the same. And it is called for all filters attached to a stream
(frontend and backend).

Finally, the TRACE filter has been updated.

8 years agoCLEANUP: remove last references to 'ruleset' section
Christopher Faulet [Wed, 26 Oct 2016 09:06:28 +0000 (11:06 +0200)] 
CLEANUP: remove last references to 'ruleset' section

8 years agoBUG: vars: Fix 'set-var' converter because of a typo
Christopher Faulet [Wed, 9 Nov 2016 15:15:32 +0000 (16:15 +0100)] 
BUG: vars: Fix 'set-var' converter because of a typo

The 'set-var' converter uses function smp_conv_store (vars.c). In this function,
we should use the first argument (index 0) to retrieve the variable name and its
scope. But because of a typo, we get the scope of the second argument (index
1). In this case, there is no second argument. So the scope used was always 0
(SCOPE_SESS), always setting the variable in the session scope.

So, due to this bug, this rules

  tcp-request content accept if { src,set-var(txn.foo) -m found }

always set the variable 'sess.foo' instead of 'txn.foo'.

8 years agoMEDIUM: server: do not restrict anymore usage of IP address from the state file
Willy Tarreau [Wed, 9 Nov 2016 13:54:53 +0000 (14:54 +0100)] 
MEDIUM: server: do not restrict anymore usage of IP address from the state file

Now that it is possible to decide whether we prefer to use libc or the
state file to resolve the server's IP address and it is possible to change
a server's IP address at run time on the CLI, let's not restrict the reuse
of the address from the state file anymore to the DNS only.

The impact is that by default the state file will be considered first
(which matches its purpose) and only then the libc. This way any address
change performed at run time over the CLI will be preserved regardless
of DNS usage or not.

8 years agoMINOR: init: add -dr to ignore server address resolution failures
Willy Tarreau [Mon, 7 Nov 2016 20:03:16 +0000 (21:03 +0100)] 
MINOR: init: add -dr to ignore server address resolution failures

It is very common when validating a configuration out of production not to
have access to the same resolvers and to fail on server address resolution,
making it difficult to test a configuration. This option simply appends the
"none" method to the list of address resolution methods for all servers,
ensuring that even if the libc fails to resolve an address, the startup
sequence is not interrupted.

8 years agoDOC: add some documentation for the "init-addr" server keyword
Willy Tarreau [Mon, 7 Nov 2016 18:42:35 +0000 (19:42 +0100)] 
DOC: add some documentation for the "init-addr" server keyword

All 4 new values were documented at once.

8 years agoMINOR: server: add support for explicit numeric address in init-addr
Willy Tarreau [Wed, 2 Nov 2016 14:05:56 +0000 (15:05 +0100)] 
MINOR: server: add support for explicit numeric address in init-addr

This will allow a server to automatically fall back to an explicit numeric
IP address when all other methods fail. The address is simply specified in
the address list.

8 years agoMEDIUM: server: make libc resolution failure non-fatal
Willy Tarreau [Mon, 7 Nov 2016 18:19:22 +0000 (19:19 +0100)] 
MEDIUM: server: make libc resolution failure non-fatal

Now that we have "init-addr none", it becomes possible to recover on
libc resolver's failures. Thus it's preferable not to alert nor fail
at the moment the libc is called, and instead process the failure at
the end of the list. This allows "none" to be set after libc to
provide a smooth fallback in case of resolver issues.

8 years agoMINOR: server: implement init-addr none
Willy Tarreau [Fri, 4 Nov 2016 14:17:58 +0000 (15:17 +0100)] 
MINOR: server: implement init-addr none

The server is put into the "no address" maintenance state in this case.

8 years agoMEDIUM: server: make use of init-addr
Willy Tarreau [Fri, 4 Nov 2016 14:10:17 +0000 (15:10 +0100)] 
MEDIUM: server: make use of init-addr

It is now supported. If not set, we default to the legacy methods list
which is "last,libc".

8 years agoMEDIUM: server: add a new init-addr server line setting
Baptiste Assmann [Wed, 21 Sep 2016 18:26:16 +0000 (20:26 +0200)] 
MEDIUM: server: add a new init-addr server line setting

This new setting supports a comma-delimited list of methods used to
resolve the server's FQDN to an IP address. Currently supported methods
are "libc" (use the regular libc's resolver) and "last" (use the last
known valid address found in the state file).

The list is implemented in a 32-bit integer, because each init-addr
method only requires 3 bits. The last one must always be SRV_IADDR_END
(0), allowing to store up to 10 methods in a single 32 bit integer.

Note: the doc is provided at the end of this series.

8 years agoMEDIUM: cli: leave the RMAINT state when setting an IP address on the CLI
Willy Tarreau [Fri, 4 Nov 2016 17:21:32 +0000 (18:21 +0100)] 
MEDIUM: cli: leave the RMAINT state when setting an IP address on the CLI

The RMAINT state happens when a server doesn't get a valid DNS response
past the hold time. If the address is forced on the CLI, we must use it
and leave the RMAINT state.

8 years agoMAJOR: dns: runtime resolution can change server admin state
Baptiste Assmann [Wed, 2 Nov 2016 21:58:18 +0000 (22:58 +0100)] 
MAJOR: dns: runtime resolution can change server admin state

WARNING: this is a MAJOR (and disruptive) change with previous HAProxy's
behavior: before, HAProxy never ever used to change a server administrative
status when the DNS resolution failed at run time.

This patch gives HAProxy the ability to change the administrative status
of a server to MAINT (RMAINT actually) when an error is encountered for
a period longer than its own allowed by the corresponding 'hold'
parameter.

IE if the configuration sets "hold nx 10s" and a server's hostname
points to a NX for more than 10s, then the server will be set to RMAINT,
hence in MAINTENANCE mode.

8 years agoMINOR: dns: implement extra 'hold' timers.
Baptiste Assmann [Wed, 2 Nov 2016 21:23:31 +0000 (22:23 +0100)] 
MINOR: dns: implement extra 'hold' timers.

This adds new "hold" timers : nx, refused, timeout, other. This timers
will be used to tell HAProxy to keep an erroneous response as valid for
the corresponding period. For now they're only configured, not enforced.

8 years agoMINOR: server: make srv_set_admin_state() capable of telling why this happens
Willy Tarreau [Mon, 7 Nov 2016 14:53:43 +0000 (15:53 +0100)] 
MINOR: server: make srv_set_admin_state() capable of telling why this happens

It will be important to help debugging some DNS resolution issues to
know why a server was marked down, so let's make  the function support
a 3rd argument with an indication of the reason. Passing NULL will keep
the message as-is.

8 years agoMINOR: stats: indicate it when a server is down due to resolution
Willy Tarreau [Wed, 9 Nov 2016 13:45:51 +0000 (14:45 +0100)] 
MINOR: stats: indicate it when a server is down due to resolution

The server's state is now "MAINT (resolution)" just like we also have
"MAINT (via x/y)" when servers are tracked. The HTML stats page reports
"resolution" in the checks field similarly to what is done for the "via"
entry.

8 years agoMINOR: server: indicate in the logs when RMAINT is cleared
Willy Tarreau [Mon, 7 Nov 2016 14:42:33 +0000 (15:42 +0100)] 
MINOR: server: indicate in the logs when RMAINT is cleared

It's important to report in the server state change logs that RMAINT was
cleared, as it's not the regular maintenance mode, it's specific to name
resolution, and it's important to report the new state (which can be DRAIN
or READY).

8 years agoMINOR: new srv_admin flag: SRV_ADMF_RMAINT
Baptiste Assmann [Wed, 2 Nov 2016 20:31:27 +0000 (21:31 +0100)] 
MINOR: new srv_admin flag: SRV_ADMF_RMAINT

This flag has to be set when an IP address resolution fails (either
using libc at start up or using HAProxy's runtime resolver). This will
automatically trigger the administrative status "MAINT", through the
global mask SRV_ADMF_MAINT.

8 years agoMAJOR: server: postpone address resolution
Baptiste Assmann [Wed, 2 Nov 2016 14:34:05 +0000 (15:34 +0100)] 
MAJOR: server: postpone address resolution

Server addresses are not resolved anymore upon the first pass so that we
don't fail if an address cannot be resolved by the libc. Instead they are
processed all at once after the configuration is fully loaded, by the new
function srv_init_addr(). This function only acts on the server's address
if this address uses an FQDN, which appears in server->hostname.

For now the function does two things, to followup with HAProxy's historical
default behavior:

  1. apply server IP address found in server-state file if runtime DNS
     resolution is enabled for this server

  2. use the DNS resolver provided by the libc

If none of the 2 options above can find an IP address, then an error is
returned.

All of this will be needed to support the new server parameter "init-addr".
For now, the biggest user-visible change is that all server resolution errors
are dumped at once instead of causing a startup failure one by one.

8 years agoMINOR: init: move apply_server_state in haproxy.c before MODE_CHECK
Baptiste Assmann [Wed, 2 Nov 2016 14:33:15 +0000 (15:33 +0100)] 
MINOR: init: move apply_server_state in haproxy.c before MODE_CHECK

Currently, the function which applies server states provided by the
"old" process is applied after configuration sanity check. This results
in the impossibility to check the validity of the state file during a
regular config check, implying a full start is required, which can be
a problem sometimes.

This patch moves the loading of server_state file before MODE_CHECK.

8 years agoMEDIUM: tools: make str2sa_range() return the FQDN even when not resolving
Willy Tarreau [Wed, 2 Nov 2016 21:27:10 +0000 (22:27 +0100)] 
MEDIUM: tools: make str2sa_range() return the FQDN even when not resolving

This will be needed to later postpone server address resolution. We need the
FQDN even when it doesn't resolve. The caller then needs to check if fqdn was
set when resolve is null to detect that the address couldn't be parsed and
needs later resolution.

8 years agoMINOR: stream: make option contstats usable again
Willy Tarreau [Tue, 8 Nov 2016 21:03:00 +0000 (22:03 +0100)] 
MINOR: stream: make option contstats usable again

Quite a lot of people have been complaining about option contstats not
working correctly anymore since about 1.4. The reason was that one reason
for the significant performance boost between 1.3 and 1.4 was the ability
to forward data between a server and a client without waking up the stream
manager. And we couldn't afford to force sessions to constantly wake it
up given that most of the people interested in contstats are also those
interested in high performance transmission.

An idea was experimented with in the past, consisting in limiting the
amount of transmissible data before waking it up, but it was not usable
on slow connections (eg: FTP over modem lines, RDP, SSH) as stats would
be updated too rarely if at all, so that idea was dropped.

During a discussion today another idea came up : ensure that stats are
updated once in a while, since it's the only thing that matters. It
happens that we have the request channel's analyse_exp timeout that is
used to wake the stream up after a configured delay, and that by
definition this timeout is not used when there's no more analyser
(otherwise the stream would wake up and the stats would be updated).

Thus here the idea is to reuse this timeout when there's no analyser
and set it to now+5 seconds so that a stream wakes up at least once
every 5 seconds to update its stats. It should be short enough to
provide smooth traffic graphs and to allow to debug outputs of "show
sess" more easily without inflicting too much load even for very large
number of concurrent connections.

This patch is simple enough and safe enough to be backportable to 1.6
if there is some demand.

8 years agoMEDIUM: ssl: Add support for OpenSSL 1.1.0
Dirkjan Bussink [Mon, 29 Aug 2016 11:26:37 +0000 (13:26 +0200)] 
MEDIUM: ssl: Add support for OpenSSL 1.1.0

In the last release a lot of the structures have become opaque for an
end user. This means the code using these needs to be changed to use the
proper functions to interact with these structures instead of trying to
manipulate them directly.

This does not fix any deprecations yet that are part of 1.1.0, it only
ensures that it can be compiled against that version and is still
compatible with older ones.

[wt: openssl-0.9.8 doesn't build with it, there are conflicts on certain
     function prototypes which we declare as inline here and which are
     defined differently there. But openssl-0.9.8 is not supported anymore
     so probably it's OK to go without it for now and we'll see later if
     some users still need it. Emeric has reviewed this change and didn't
     spot anything obvious which requires special care. Let's try it for
     real now]

8 years agoCLEANUP: wurfl: reduce exposure in the rest of the code
Willy Tarreau [Tue, 8 Nov 2016 17:47:25 +0000 (18:47 +0100)] 
CLEANUP: wurfl: reduce exposure in the rest of the code

The only reason wurfl/wurfl.h was needed outside of wurfl.c was to expose
wurfl_handle which is a pointer to a structure, referenced by global.h.
By just storing a void* there instead, we can confine all wurfl code to
wurfl.c, which is really nice.

8 years agoDOC: move the device detection modules documentation to their own files
Willy Tarreau [Tue, 8 Nov 2016 13:57:29 +0000 (14:57 +0100)] 
DOC: move the device detection modules documentation to their own files

Both DeviceAtlas and 51Degrees used to put their building instructions
in the README, representing more than 1/3 of it. It's better to let the
README focus on generic stuff and building procedure and move the DD
docs to their own files.

8 years agoMEDIUM: wurfl: add Scientiamobile WURFL device detection module
scientiamobile [Fri, 4 Nov 2016 09:55:08 +0000 (10:55 +0100)] 
MEDIUM: wurfl: add Scientiamobile WURFL device detection module

WURFL is a high-performance and low-memory footprint mobile device
detection software component that can quickly and accurately detect
over 500 capabilities of visiting devices. It can differentiate between
portable mobile devices, desktop devices, SmartTVs and any other types
of devices on which a web browser can be installed.

In order to add WURFL device detection support, you would need to
download Scientiamobile InFuze C API and install it on your system.
Refer to www.scientiamobile.com to obtain a valid InFuze license.

Any useful information on how to configure HAProxy working with WURFL
may be found in:

  doc/WURFL-device-detection.txt
  doc/configuration.txt
  examples/wurfl-example.cfg

Please find more information about WURFL device detection API detection
at https://docs.scientiamobile.com/documentation/infuze/infuze-c-api-user-guide

8 years agoBUG/MEDIUM: servers: properly propagate the maintenance states during startup
Willy Tarreau [Thu, 3 Nov 2016 18:22:19 +0000 (19:22 +0100)] 
BUG/MEDIUM: servers: properly propagate the maintenance states during startup

Right now there is an issue with the way the maintenance flags are
propagated upon startup. They are not propagate, just copied from the
tracked server. This implies that depending on the server's order, some
tracking servers may not be marked down. For example this configuration
does not work as expected :

        server s1 1.1.1.1:8000 track s2
        server s2 1.1.1.1:8000 track s3
        server s3 1.1.1.1:8000 track s4
        server s4 wtap:8000 check inter 1s disabled

It results in s1/s2 being up, and s3/s4 being down, while all of them
should be down.

The only clean way to process this is to run through all "root" servers
(those not tracking any other server), and to propagate their state down
to all their trackers. This is the same algorithm used to propagate the
state changes. It has to be done both to compute the IDRAIN flag and the
IMAINT flag. However, doing so requires that tracking servers are not
marked as inherited maintenance anymore while parsing the configuration
(and given that it is wrong, better drop it).

This fix also addresses another side effect of the bug above which is
that the IDRAIN/IMAINT flags are stored in the state files, and if
restored while the tracked server doesn't have the equivalent flag,
the servers may end up in a situation where it's impossible to remove
these flags. For example in the configuration above, after removing
"disabled" on server s4, the other servers would have remained down,
and not anymore with this fix. Similarly, the combination of IMAINT
or IDRAIN with their respective forced modes was not accepted on
reload, which is wrong as well.

This bug has been present at least since 1.5, maybe even 1.4 (it came
with tracking support). The fix needs to be backported there, though
the srv-state parts are irrelevant.

This commit relies on previous patch to silence warnings on startup.

8 years agoMINOR: server: do not emit warnings/logs/alerts on server state changes at boot
Willy Tarreau [Thu, 3 Nov 2016 18:42:36 +0000 (19:42 +0100)] 
MINOR: server: do not emit warnings/logs/alerts on server state changes at boot

We'll have to use srv_set_admin_flag() to propagate some server flags
during the startup, and we don't want the resulting actions to cause
warnings, logs nor e-mail alerts to be generated since we're just applying
the config or a state file. So let's condition these notifications to the
fact that we're starting.

8 years agoBUG/MINOR: srv-state: allow to have both CMAINT and FDRAIN flags
Willy Tarreau [Thu, 3 Nov 2016 17:33:25 +0000 (18:33 +0100)] 
BUG/MINOR: srv-state: allow to have both CMAINT and FDRAIN flags

CMAINT indicates that the server was *initially* disabled in the
configuration via the "disabled" keyword. FDRAIN indicates that the
server was switched to the DRAIN state from the CLI or the agent.
This it's perfectly valid to have both of them in the state file,
so the parser must not reject this combination.

This fix must be backported to 1.6.

8 years agoBUG/MEDIUM: srv-state: properly restore the DRAIN state
Willy Tarreau [Thu, 3 Nov 2016 17:19:49 +0000 (18:19 +0100)] 
BUG/MEDIUM: srv-state: properly restore the DRAIN state

There were seveal reports about the DRAIN state not being properly
restored upon reload.

It happens that the condition in the code does exactly the opposite
of what the comment says, and the comment is right so the code is
wrong.

It's worth noting that the conditions are complex here due to the 2
available methods to set the drain state (CLI/agent, and config's
weight). To paraphrase the updated comment in the code, there are
two possible reasons for FDRAIN to have been present :
  - previous config weight was zero
  - "set server b/s drain" was sent to the CLI

In the first case, we simply want to drop this drain state if the new
weight is not zero anymore, meaning the administrator has intentionally
turned the weight back to a positive value to enable the server again
after an operation. In the second case, the drain state was forced on
the CLI regardless of the config's weight so we don't want a change to
the config weight to lose this status. What this means is :
  - if previous weight was 0 and new one is >0, drop the DRAIN state.
  - if the previous weight was >0, keep it.

This fix must be backported to 1.6.

8 years agoOPTIM: http: optimize lookup of comma and quote in header values
Willy Tarreau [Sat, 5 Nov 2016 17:23:38 +0000 (18:23 +0100)] 
OPTIM: http: optimize lookup of comma and quote in header values

http_find_header2() relies on find_hdr_value_end() to find the comma
delimiting a header field value, which also properly handles double
quotes and backslashes within quotes. In fact double quotes are very
rare, and commas happen once every multiple characters, especially
with cookies where a full block can be found at once. So it makes
sense to optimize this function to speed up the lookup of the first
block before the quote.

This change increases the performance from 212k to 217k req/s when
requests contain a 1kB cookie (+2.5%). We don't care about going
back into the fast parser after the first quote, as it may
needlessly make the parser more complex for very marginal gains.

8 years agoOPTIM: http: improve parsing performance of long URIs
Willy Tarreau [Sat, 5 Nov 2016 16:52:06 +0000 (17:52 +0100)] 
OPTIM: http: improve parsing performance of long URIs

Searching the trailing space in long URIs takes some time. This can
happen especially on static files and some blogs. By skipping valid
character ranges by 32-bit blocks, it's possible to increase the
HTTP performance from 212k to 216k req/s on requests features a
100-character URI, which is an increase of 2%. This is done for
architectures supporting unaligned accesses (x86_64, x86, armv7a).
There's only a 32-bit version because URIs are rarely long and very
often short, so it's more efficient to limit the systematic overhead
than to try to optimize for the rarest requests.

8 years agoOPTIM: http: improve parsing performance of long header lines
Willy Tarreau [Sat, 5 Nov 2016 16:35:40 +0000 (17:35 +0100)] 
OPTIM: http: improve parsing performance of long header lines

A performance test with 1kB cookies was capping at 194k req/s. After
implementing multi-byte skipping, the performance increased to 212k req/s,
or 9.2% faster. This patch implements this for architectures supporting
unaligned accesses (x86_64, x86, armv7a). Maybe other architectures can
benefit from this but they were not tested yet.

8 years agoOPTIM: http: move all http character classs tables into a single one
Willy Tarreau [Sat, 5 Nov 2016 14:50:20 +0000 (15:50 +0100)] 
OPTIM: http: move all http character classs tables into a single one

We used to have 7 different character classes, each was 256 bytes long,
resulting in almost 2kB being used in the L1 cache. It's as cheap to
test a bit than to check the byte is not null, so let's store a 7-bit
composite value and check for the respective bits there instead.

The executable is now 4 kB smaller and the performance on small
objects increased by about 1% to 222k requests/second with a config
involving 4 http-request rules including 1 header lookup, one header
replacement, and 2 variable assignments.

8 years agoCLEANUP: tools: make ipcpy() preserve the original port
Willy Tarreau [Fri, 4 Nov 2016 17:47:01 +0000 (18:47 +0100)] 
CLEANUP: tools: make ipcpy() preserve the original port

ipcpy() is used to replace an IP address with another one, but it
doesn't preserve the original port so all callers have to do it
manually while it's trivial to do there. Better do it inside the
function.

8 years agoMEDIUM: tools: make str2ip2() preserve existing ports
Willy Tarreau [Wed, 2 Nov 2016 21:37:03 +0000 (22:37 +0100)] 
MEDIUM: tools: make str2ip2() preserve existing ports

Often we need to call str2ip2() on an address which already contains a
port without replacing it, so let's ensure we preserve it even if the
family changes.

8 years agoDOC: stats: provide state details for show servers state
Cyril Bonté [Tue, 1 Nov 2016 23:19:58 +0000 (00:19 +0100)] 
DOC: stats: provide state details for show servers state

Add the state values to the documentation instead of adding a reference to the
source code.

8 years agoBUG/MEDIUM: systemd-wrapper: return correct exit codes
Willy Tarreau [Thu, 3 Nov 2016 19:31:40 +0000 (20:31 +0100)] 
BUG/MEDIUM: systemd-wrapper: return correct exit codes

Gabriele Cerami reported the the exit codes of the systemd-wrapper are
wrong. In short, it directly returns the output of the wait syscall's
status, which is a composite value made of error code an signal numbers.
In general it contains the signal number on the lower bits and the error
code on the higher bits, but exit() truncates it to the lowest 8 bits,
causing config validations to incorrectly report a success. Example :

  $ ./haproxy-systemd-wrapper -c -f /dev/null
  <7>haproxy-systemd-wrapper: executing /tmp/haproxy -c -f /dev/null -Ds
  Configuration file has no error but will not start (no listener) => exit(2).
  <5>haproxy-systemd-wrapper: exit, haproxy RC=512
  $ echo $?
  0

If the process is killed however, the signal number is directly reported
in the exit code.

Let's fix all this to ensure that the exit code matches what the shell does,
which means that codes 0..127 are for exit codes, codes 128..254 for signals,
and code 255 for unknown exit code. Now the return code is correct :

  $ ./haproxy-systemd-wrapper -c -f /dev/null
  <7>haproxy-systemd-wrapper: executing /tmp/haproxy -c -f /dev/null -Ds
  Configuration file has no error but will not start (no listener) => exit(2).
  <5>haproxy-systemd-wrapper: exit, haproxy RC=2
  $ echo $?
  2

  $ ./haproxy-systemd-wrapper -f /tmp/cfg.conf
  <7>haproxy-systemd-wrapper: executing /tmp/haproxy -f /dev/null -Ds
  ^C
  <5>haproxy-systemd-wrapper: exit, haproxy RC=130
  $ echo $?
  130

This fix must be backported to 1.6 and 1.5.

8 years agoMINOR: peers: remove the pointer to the stream
Willy Tarreau [Mon, 31 Oct 2016 17:42:52 +0000 (18:42 +0100)] 
MINOR: peers: remove the pointer to the stream

There's no reason to use the stream anymore, only the appctx should be
used by a peer. This was a leftover from the migration to appctx and it
caused some confusion, so let's totally drop it now. Note that half of
the patch are just comment updates.

8 years agoMINOR: peers: make peer_session_forceshutdown() use the appctx and not the stream
Willy Tarreau [Mon, 31 Oct 2016 16:37:39 +0000 (17:37 +0100)] 
MINOR: peers: make peer_session_forceshutdown() use the appctx and not the stream

It was inherited from initial code but we must only manipulate the appctx
and never the stream, otherwise we always risk shooting ourselves in the
foot.

8 years agoBUG/MEDIUM: peers: fix use after free in peer_session_create()
Willy Tarreau [Mon, 31 Oct 2016 16:46:57 +0000 (17:46 +0100)] 
BUG/MEDIUM: peers: fix use after free in peer_session_create()

In case of resource allocation error, peer_session_create() frees
everything allocated and returns a pointer to the stream/session that
was put back into the free pool. This stream/session is then assigned
to ps->{stream,session} with no error control. This means that it is
perfectly possible to have a new stream or session being both used for
a regular communication and for a peer at the same time.

In fact it is the only way (for now) to explain a CLOSE_WAIT on peers
connections that was caught in this dump with the stream interface in
SI_ST_CON state while the error field proves the state ought to have
been SI_ST_DIS, very likely indicating two concurrent accesses on the
same area :

  0x7dbd50: [31/Oct/2016:17:53:41.267510] id=0 proto=tcpv4
    flags=0x23006, conn_retries=0, srv_conn=(nil), pend_pos=(nil)
    frontend=myhost2 (id=4294967295 mode=tcp), listener=? (id=0)
    backend=<NONE> (id=-1 mode=-) addr=127.0.0.1:41432
    server=<NONE> (id=-1) addr=127.0.0.1:8521
    task=0x7dbcd8 (state=0x08 nice=0 calls=2 exp=<NEVER> age=1m5s)
    si[0]=0x7dbf48 (state=CLO flags=0x4040 endp0=APPCTX:0x7d99c8 exp=<NEVER>, et=0x000)
    si[1]=0x7dbf68 (state=CON flags=0x50 endp1=CONN:0x7dc0b8 exp=<NEVER>, et=0x020)
    app0=0x7d99c8 st0=11 st1=0 st2=0 applet=<PEER>
    co1=0x7dc0b8 ctrl=tcpv4 xprt=RAW data=STRM target=PROXY:0x7fe62028a010
        flags=0x0020b310 fd=7 fd.state=22 fd.cache=0 updt=0
    req=0x7dbd60 (f=0x80a020 an=0x0 pipe=0 tofwd=0 total=0)
        an_exp=<NEVER> rex=<NEVER> wex=<NEVER>
        buf=0x78a3c0 data=0x78a3d4 o=0 p=0 req.next=0 i=0 size=0
    res=0x7dbda0 (f=0x80402020 an=0x0 pipe=0 tofwd=0 total=0)
        an_exp=<NEVER> rex=<NEVER> wex=<NEVER>
        buf=0x78a3c0 data=0x78a3d4 o=0 p=0 rsp.next=0 i=0 size=0

Special thanks to Arnaud Gavara who provided lots of valuable input and
ran some validation testing on this patch.

This fix must be backported to 1.6 and 1.5. Note that in 1.5 the
session is not assigned from within the function so some extra checks
may be needed in the callers.

8 years agoBUG/MEDIUM: peers: on shutdown, wake up the appctx, not the stream
Willy Tarreau [Mon, 31 Oct 2016 16:32:20 +0000 (17:32 +0100)] 
BUG/MEDIUM: peers: on shutdown, wake up the appctx, not the stream

This part was missed when peers were ported to the new applet
infrastructure in 1.6, the main stream is woken up instead of the
appctx. This creates a race condition by which it is possible to
wake the stream at the wrong moment and miss an event. This bug
might be at least partially responsible for some of the CLOSE_WAIT
that were reported on peers session upon reload in version 1.6.

This fix must be backported to 1.6.

8 years agoMINOR: examples: Update haproxy.spec URLs to haproxy.org
Grant [Sat, 4 Jul 2015 08:23:52 +0000 (09:23 +0100)] 
MINOR: examples: Update haproxy.spec URLs to haproxy.org

also update version.
[wt: should be backported to 1.6]

8 years agoCLEANUP: cfgparse: Very minor spelling correction
Ian Miell [Tue, 18 Aug 2015 18:32:08 +0000 (19:32 +0100)] 
CLEANUP: cfgparse: Very minor spelling correction

'optionnally' changed to 'optionally'

8 years agoDOC: Fix typo in description of `-st` parameter in man page
Jorrit Schippers [Sat, 9 Apr 2016 18:30:38 +0000 (20:30 +0200)] 
DOC: Fix typo in description of `-st` parameter in man page

extra "wait".

9 years agoDOC: fix the entry for hash-balance-factor config option
Andrew Rodland [Tue, 25 Oct 2016 21:04:12 +0000 (17:04 -0400)] 
DOC: fix the entry for hash-balance-factor config option

It was accidentally added as "balance-factor". Fix it and
re-alphabetize.

Signed-off-by: Andrew Rodland <andrewr@vimeo.com>
9 years ago[RELEASE] Released version 1.7-dev5 v1.7-dev5
Willy Tarreau [Tue, 25 Oct 2016 20:22:00 +0000 (22:22 +0200)] 
[RELEASE] Released version 1.7-dev5

Released version 1.7-dev5 with the following main changes :
    - MINOR: cfgparse: few memory leaks fixes.
    - MEDIUM: log: Decompose %Tq in %Th %Ti %TR
    - CLEANUP: logs: remove unused log format field definitions
    - BUILD/MAJOR:updated 51d Trie implementation to incorperate latest update to 51Degrees.c
    - BUG/MAJOR: stream: properly mark the server address as unset on connect retry
    - CLEANUP: proto_http: Removing useless variable assignation
    - CLEANUP: dumpstats: Removing useless variables allocation
    - CLEANUP: dns: Removing usless variable & assignation
    - BUG/MINOR: payload: fix SSLv2 version parser
    - MINOR: cli: allow the semi-colon to be escaped on the CLI
    - MINOR: cli: change a server health check port through the stats socket
    - BUG/MINOR: Fix OSX compilation errors
    - MAJOR: check: find out which port to use for health check at run time
    - MINOR: server: introduction of 3 new server flags
    - MINOR: new update_server_addr_port() function to change both server's ADDR and service PORT
    - MINOR: cli: ability to change a server's port
    - CLEANUP/MINOR dns: comment do not follow up code update
    - MINOR: chunk: new strncat function
    - MINOR: dns: wrong DNS_MAX_UDP_MESSAGE value
    - MINOR: dns: new MAX values
    - MINOR: dns: new macro to compute DNS header size
    - MINOR: dns: new DNS structures to store received packets
    - MEDIUM: dns: new DNS response parser
    - MINOR: dns: query type change when last record is a CNAME
    - MINOR: dns: proper domain name validation when receiving DNS response
    - MINOR: dns: comments in types/dns.h about structures endianness
    - BUG/MINOR: displayed PCRE version is running release
    - MINOR: show Built with PCRE version
    - MINOR: show Running on zlib version
    - MEDIUM: make SO_REUSEPORT configurable
    - MINOR: enable IP_BIND_ADDRESS_NO_PORT on backend connections
    - BUG/MEDIUM: http/compression: Fix how chunked data are copied during the HTTP body parsing
    - BUG/MINOR: stats: report the correct conn_time in backend's html output
    - BUG/MEDIUM: dns: don't randomly crash on out-of-memory
    - MINOR: Add fe_req_rate sample fetch
    - MEDIUM: peers: Fix a peer stick-tables synchronization issue.
    - MEDIUM: cli: register CLI keywords with cli_register_kw()
    - BUILD: Make use of accept4() on OpenBSD.
    - MINOR: tcp: make set-src/set-src-port and set-dst/set-dst-port commutative
    - DOC: fix missed entry for "set-{src,dst}{,-port}"
    - BUG/MINOR: vars: use sess and not s->sess in action_store()
    - BUG/MINOR: vars: make smp_fetch_var() more robust against misuses
    - BUG/MINOR: vars: smp_fetch_var() doesn't depend on HTTP but on the session
    - MINOR: stats: output dcon
    - CLEANUP: tcp rules: mention everywhere that tcp-conn rules are L4
    - MINOR: counters: add new fields for denied_sess
    - MEDIUM: tcp: add registration and processing of TCP L5 rules
    - MINOR: stats: emit dses
    - DOC: document tcp-request session
    - MINOR: ssl: add debug traces
    - BUILD/CLEANUP: ssl: Check BIO_reset() return code
    - BUG/MINOR: ssl: Check malloc return code
    - BUG/MINOR: ssl: prevent multiple entries for the same certificate
    - BUG/MINOR: systemd: make the wrapper return a non-null status code on error
    - BUG/MINOR: systemd: always restore signals before execve()
    - BUG/MINOR: systemd: check return value of calloc()
    - MINOR: systemd: report it when execve() fails
    - BUG/MEDIUM: systemd: let the wrapper know that haproxy has completed or failed
    - MINOR: proxy: add 'served' field to proxy, equal to total of all servers'
    - MINOR: backend: add hash-balance-factor option for hash-type consistent
    - MINOR: server: compute a "cumulative weight" to allow chash balancing to hit its target
    - MEDIUM: server: Implement bounded-load hash algorithm
    - SCRIPTS: make git-show-backports also dump a "git show" command
    - MINOR: build: Allow linking to device-atlas library file
    - MINOR: stats: Escape equals sign on socket dump

9 years agoMINOR: stats: Escape equals sign on socket dump
Chad Lavoie [Tue, 4 Oct 2016 20:10:40 +0000 (16:10 -0400)] 
MINOR: stats: Escape equals sign on socket dump

Greetings,

Was recently working with a stick table storing URL's and one had an
equals sign in it (e.g. 127.0.0.1/f=ab) which made it difficult to
easily split the key and value without a regex.

This patch will change it so that the key looks like
"key=127.0.0.1/f\=ab" instead of "key=127.0.0.1/f=ab".

Not very important given that there are ways to work around it.

Thanks,

- Chad

9 years agoMINOR: build: Allow linking to device-atlas library file
Bertrand Jacquin [Wed, 5 Oct 2016 23:32:39 +0000 (00:32 +0100)] 
MINOR: build: Allow linking to device-atlas library file

DeviceAtlas might be installed in a location where a user might not have
enough permissions to write json.o and dac.o

9 years agoSCRIPTS: make git-show-backports also dump a "git show" command
Willy Tarreau [Tue, 25 Oct 2016 20:12:54 +0000 (22:12 +0200)] 
SCRIPTS: make git-show-backports also dump a "git show" command

This is very convenient for backport reviews as in a single
command you get all the patches one at a time with their
changelog and backport instructions.

9 years agoMEDIUM: server: Implement bounded-load hash algorithm
Andrew Rodland [Tue, 25 Oct 2016 16:50:37 +0000 (12:50 -0400)] 
MEDIUM: server: Implement bounded-load hash algorithm

The consistent hash lookup is done as normal, then if balancing is
enabled, we progress through the hash ring until we find a server that
doesn't have "too much" load. In the case of equal weights for all
servers, the allowed number of requests for a server is either the
floor or the ceil of (num_requests * hash-balance-factor / num_servers);
with unequal weights things are somewhat more complicated, but the
spirit is the same -- a server should not be able to go too far above
(its relative weight times) the average load. Using the hash ring to
make the second/third/etc. choice maintains as much locality as
possible given the load limit.

Signed-off-by: Andrew Rodland <andrewr@vimeo.com>
9 years agoMINOR: server: compute a "cumulative weight" to allow chash balancing to hit its...
Andrew Rodland [Tue, 25 Oct 2016 16:49:45 +0000 (12:49 -0400)] 
MINOR: server: compute a "cumulative weight" to allow chash balancing to hit its target

For active servers, this is the sum of the eweights of all active
servers before this one in the backend, and
[srv->cumulative_weight .. srv_cumulative_weight + srv_eweight) is a
space occupied by this server in the range [0 .. lbprm.tot_wact), and
likewise for backup servers with tot_wbck. This allows choosing a
server or a range of servers proportional to their weight, by simple
integer comparison.

Signed-off-by: Andrew Rodland <andrewr@vimeo.com>
9 years agoMINOR: backend: add hash-balance-factor option for hash-type consistent
Andrew Rodland [Tue, 25 Oct 2016 16:49:05 +0000 (12:49 -0400)] 
MINOR: backend: add hash-balance-factor option for hash-type consistent

0 will mean no balancing occurs; otherwise it represents the ratio
between the highest-loaded server and the average load, times 100 (i.e.
a value of 150 means a 1.5x ratio), assuming equal weights.

Signed-off-by: Andrew Rodland <andrewr@vimeo.com>
9 years agoMINOR: proxy: add 'served' field to proxy, equal to total of all servers'
Andrew Rodland [Tue, 25 Oct 2016 16:48:17 +0000 (12:48 -0400)] 
MINOR: proxy: add 'served' field to proxy, equal to total of all servers'

This will allow lb_chash to determine the total active sessions for a
proxy without any computation.

Signed-off-by: Andrew Rodland <andrewr@vimeo.com>
9 years agoBUG/MEDIUM: systemd: let the wrapper know that haproxy has completed or failed
Willy Tarreau [Tue, 25 Oct 2016 15:20:24 +0000 (17:20 +0200)] 
BUG/MEDIUM: systemd: let the wrapper know that haproxy has completed or failed

Pierre Cheynier found that there's a persistent issue with the systemd
wrapper. Too fast reloads can lead to certain old processes not being
signaled at all and continuing to run. The problem was tracked down as
a race between the startup and the signal processing : nothing prevents
the wrapper from starting new processes while others are still starting,
and the resulting pid file will only contain the latest pids in this
case. This can happen with large configs and/or when a lot of SSL
certificates are involved.

In order to solve this we want the wrapper to wait for the new processes
to complete their startup. But we also want to ensure it doesn't wait for
nothing in case of error.

The solution found here is to create a pipe between the wrapper and the
sub-processes. The wrapper waits on the pipe and the sub-processes are
expected to close this pipe once they completed their startup. That way
we don't queue up new processes until the previous ones have registered
their pids to the pid file. And if anything goes wrong, the wrapper is
immediately released. The only thing is that we need the sub-processes
to know the pipe's file descriptor. We pass it in an environment variable
called HAPROXY_WRAPPER_FD.

It was confirmed both by Pierre and myself that this completely solves
the "zombie" process issue so that only the new processes continue to
listen on the sockets.

It seems that in the future this stuff could be moved to the haproxy
master process, also getting rid of an environment variable.

This fix needs to be backported to 1.6 and 1.5.

9 years agoMINOR: systemd: report it when execve() fails
Willy Tarreau [Tue, 25 Oct 2016 14:51:40 +0000 (16:51 +0200)] 
MINOR: systemd: report it when execve() fails

It's important to know that a signal sent to the wrapper had no effect
because something failed during execve(). Ideally more info (strerror)
should be reported. It would be nice to backport this to 1.6 and 1.5.

9 years agoBUG/MINOR: systemd: check return value of calloc()
Willy Tarreau [Tue, 25 Oct 2016 15:05:56 +0000 (17:05 +0200)] 
BUG/MINOR: systemd: check return value of calloc()

The wrapper is not the best reliable thing in the universe, so start
by adding at least the minimum expected controls :-/

To be backported to 1.5 and 1.6.

9 years agoBUG/MINOR: systemd: always restore signals before execve()
Willy Tarreau [Tue, 25 Oct 2016 14:49:31 +0000 (16:49 +0200)] 
BUG/MINOR: systemd: always restore signals before execve()

Since signals are inherited, we must restore them before calling execve()
and intercept them again after a failed execve(). In order to cleanly deal
with the SIGUSR2/SIGHUP loops where we re-exec the wrapper, we ignore these
two signals during a re-exec, and restore them to defaults when spawning
haproxy.

This should be backported to 1.6 and 1.5.

9 years agoBUG/MINOR: systemd: make the wrapper return a non-null status code on error
Willy Tarreau [Tue, 25 Oct 2016 13:50:47 +0000 (15:50 +0200)] 
BUG/MINOR: systemd: make the wrapper return a non-null status code on error

When execv() fails to execute the haproxy executable, it's important to
return an error instead of pretending everything is cool. This fix should
be backported to 1.6 and 1.5 in order to improve the overall reliability
under systemd.

9 years agoBUG/MINOR: ssl: prevent multiple entries for the same certificate
Thierry FOURNIER / OZON.IO [Thu, 6 Oct 2016 08:56:48 +0000 (10:56 +0200)] 
BUG/MINOR: ssl: prevent multiple entries for the same certificate

Today, the certificate are indexed int he SNI tree using their CN and the
list of thier AltNames. So, Some certificates have the same names in the
CN and one of the AltNames entries.

Typically Let's Encrypt duplicate the the DNS name in the CN and the
AltName.

This patch prevents the creation of identical entries in the trees. It
checks the same DNS name and the same SSL context.

If the same certificate is registered two time it will be duplicated.

This patch should be backported in the 1.6 and 1.5 version.

9 years agoBUG/MINOR: ssl: Check malloc return code
Thierry FOURNIER / OZON.IO [Thu, 6 Oct 2016 08:35:29 +0000 (10:35 +0200)] 
BUG/MINOR: ssl: Check malloc return code

If malloc() can't allocate memory and return NULL, a segfaut will raises.

This patch should be backported in the 1.6 and 1.5 version.

9 years agoBUILD/CLEANUP: ssl: Check BIO_reset() return code
Thierry FOURNIER / OZON.IO [Thu, 13 Oct 2016 22:49:21 +0000 (00:49 +0200)] 
BUILD/CLEANUP: ssl: Check BIO_reset() return code

The BIO_reset function can fails, and the error is not processed.
This patch just take in account the return code of the BIO_reset()
function.

9 years agoMINOR: ssl: add debug traces
Thierry FOURNIER / OZON.IO [Mon, 10 Oct 2016 09:59:50 +0000 (11:59 +0200)] 
MINOR: ssl: add debug traces

Add some debug trace when haproxy is configured in debug & verbose mode.
This is useful for openssl tests. Typically, the error "SSL handshake
failure" can be caused by a lot of protocol error. This patch details
the encountered error. For exemple:

   OpenSSL error 0x1408a0c1: ssl3_get_client_hello: no shared cipher

Note that my compilator (gcc-4.7) refuse to considers the function
ssl_sock_dump_errors() as inline. The condition "if" ensure that the
content of the function is not executed in normal case. It should be
a pity to call a function just for testing its execution condition, so
I use the macro "forceinline".

9 years agoDOC: document tcp-request session
Willy Tarreau [Fri, 21 Oct 2016 15:49:36 +0000 (17:49 +0200)] 
DOC: document tcp-request session

This is mostly a copy-paste-edit of the section about "tcp-request connection".
Maybe all these sections should be merged.

9 years agoMINOR: stats: emit dses
Willy Tarreau [Fri, 21 Oct 2016 16:16:27 +0000 (18:16 +0200)] 
MINOR: stats: emit dses

This is the number of denied sessions, blocked by "tcp-request session reject".

9 years agoMEDIUM: tcp: add registration and processing of TCP L5 rules
Willy Tarreau [Fri, 21 Oct 2016 14:37:51 +0000 (16:37 +0200)] 
MEDIUM: tcp: add registration and processing of TCP L5 rules

This commit introduces "tcp-request session" rules. These are very
much like "tcp-request connection" rules except that they're processed
after the handshake, so it is possible to consider SSL information and
addresses rewritten by the proxy protocol header in actions. This is
particularly useful to track proxied sources as this was not possible
before, given that tcp-request content rules are processed after each
HTTP request. Similarly it is possible to assign the proxied source
address or the client's cert to a variable.

9 years agoMINOR: counters: add new fields for denied_sess
Willy Tarreau [Fri, 21 Oct 2016 14:31:13 +0000 (16:31 +0200)] 
MINOR: counters: add new fields for denied_sess

This will be used with denied sessions. This counter is not exposed yet.

9 years agoCLEANUP: tcp rules: mention everywhere that tcp-conn rules are L4
Willy Tarreau [Fri, 21 Oct 2016 14:34:21 +0000 (16:34 +0200)] 
CLEANUP: tcp rules: mention everywhere that tcp-conn rules are L4

This is in order to make integration of tcp-request-session cleaner :
- tcp_exec_req_rules() was renamed tcp_exec_l4_rules()
- LI_O_TCP_RULES was renamed LI_O_TCP_L4_RULES
  (LI_O_*'s horrible indent was also fixed and a provision was left
   for L5 rules).

9 years agoMINOR: stats: output dcon
Willy Tarreau [Fri, 21 Oct 2016 16:15:32 +0000 (18:15 +0200)] 
MINOR: stats: output dcon

These are denied conns. Strangely this wasn't emitted while it used to be
available for a while. It corresponds to the number of connections blocked
by "tcp-request connection reject".

9 years agoBUG/MINOR: vars: smp_fetch_var() doesn't depend on HTTP but on the session
Willy Tarreau [Fri, 21 Oct 2016 15:17:18 +0000 (17:17 +0200)] 
BUG/MINOR: vars: smp_fetch_var() doesn't depend on HTTP but on the session

Thus the SMP_USE_HTTP_ANY dependency is incorrect, we have to depend on
SMP_USE_L5_CLI (the session). It's particularly important for session-wide
variables which are kept across HTTP requests. For now there is no impact
but it will make a difference with tcp-request session rules.

9 years agoBUG/MINOR: vars: make smp_fetch_var() more robust against misuses
Willy Tarreau [Fri, 21 Oct 2016 15:14:35 +0000 (17:14 +0200)] 
BUG/MINOR: vars: make smp_fetch_var() more robust against misuses

smp_fetch_var() may be called from everywhere since it just reads a
variable. It must ensure that the stream exists before trying to return
a stream-dependant variable. For now there is no impact but it will
cause trouble with tcp-request session rules.

9 years agoBUG/MINOR: vars: use sess and not s->sess in action_store()
Willy Tarreau [Fri, 21 Oct 2016 15:13:24 +0000 (17:13 +0200)] 
BUG/MINOR: vars: use sess and not s->sess in action_store()

This causes the stream to be dereferenced when not needed. It will
cause trouble when variables are used outside of a stream.

9 years agoDOC: fix missed entry for "set-{src,dst}{,-port}"
Willy Tarreau [Fri, 21 Oct 2016 15:52:58 +0000 (17:52 +0200)] 
DOC: fix missed entry for "set-{src,dst}{,-port}"

There was the same explanation for tcp-request connection that I missed
in previous patch.

9 years agoMINOR: tcp: make set-src/set-src-port and set-dst/set-dst-port commutative
Willy Tarreau [Fri, 21 Oct 2016 13:07:45 +0000 (15:07 +0200)] 
MINOR: tcp: make set-src/set-src-port and set-dst/set-dst-port commutative

When the tcp/http actions above were introduced in 1.7-dev4, we used to
proceed like this :

  - set-src/set-dst would force the port to zero
  - set-src-port/set-dst-port would not do anything if the address family is
    neither AF_INET nor AF_INET6.

It was a stupid idea of mine to request this behaviour because it ensures
that these functions cannot be used in a wide number of situations. Because
of the first rule, it is necessary to save the source port one way or
another if only the address has to be changed (so you have to use an
variable). Due to the second rule, there's no way to set the source port
on a unix socket without first overwriting the address. And sometimes it's
really not convenient, especially when there's no way to guarantee that all
fields will properly be set.

In order to fix all this, this small change does the following :
  - set-src/set-dst always preserve the original port even if the address
    family changes. If the previous address family didn't have a port (eg:
    AF_UNIX), then the port is set to zero ;

  - set-src-port/set-dst-port always preserve the original address. If the
    address doesn't have a port, then the family is forced to IPv4 and the
    address to "0.0.0.0".

Thanks to this it now becomes possible to perform one action, the other or
both in any order.

9 years agoBUILD: Make use of accept4() on OpenBSD.
Daniel Jakots [Tue, 27 Sep 2016 17:22:21 +0000 (19:22 +0200)] 
BUILD: Make use of accept4() on OpenBSD.

OpenBSD >= 5.7 supports accept4(). Older versions are not supported
anymore anyway.

Patch originally from Brad Smith.

9 years agoMEDIUM: cli: register CLI keywords with cli_register_kw()
William Lallemand [Thu, 13 Oct 2016 15:57:55 +0000 (17:57 +0200)] 
MEDIUM: cli: register CLI keywords with cli_register_kw()

To register a new cli keyword, you need to declare a cli_kw_list
structure in your source file:

static struct cli_kw_list cli_kws = {{ },{
{ { "test", "list", NULL }, "test list : do some tests on the cli", test_parsing, NULL },
{ { NULL }, NULL, NULL, NULL, NULL }
}};

And then register it:

cli_register_kw(&cli_kws);

The first field is an array of 5 elements, where you declare the
keywords combination which will match, it must be ended by a NULL
element.

The second field is used as a usage message, it will appear in the help
of the cli, you can set it to NULL if you don't want to show it, it's a
good idea if you want to overwrite some existing keywords.

The two last fields are callbacks.

The first one is used at parsing time, you can use it to parse the
arguments of your keywords and print small messages. The function must
return 1 in case of a failure, otherwise 0:

#include <proto/dumpstats.h>

static int test_parsing(char **args, struct appctx *appctx)
{
struct chunk out;

if (!*args[2]) {
appctx->ctx.cli.msg = "Error: the 3rd argument is mandatory !";
appctx->st0 = STAT_CLI_PRINT;
return 1;
}
chunk_reset(&trash);
chunk_printf(&trash, "arg[3]: %s\n", args[2]);
chunk_init(&out, NULL, 0);
chunk_dup(&out, &trash);
appctx->ctx.cli.err = out.str;
appctx->st0 = STAT_CLI_PRINT_FREE; /* print and free in the default cli_io_handler */
return 0;
}

The last field is the IO handler callback, it can be set to NULL if you
want to use the default cli_io_handler() otherwise you can write your
own. You can use the private pointer in the appctx if you need to store
a context or some data. stats_dump_sess_to_buffer() is a good example of
IO handler, IO handlers often use the appctx->st2 variable for the state
machine. The handler must return 0 in case it have to be recall later
otherwise 1.

9 years agoMEDIUM: peers: Fix a peer stick-tables synchronization issue.
Frédéric Lécaille [Wed, 12 Oct 2016 15:30:30 +0000 (17:30 +0200)] 
MEDIUM: peers: Fix a peer stick-tables synchronization issue.

During the stick-table teaching process which occurs at reloading/restart time,
expiration dates of stick-tables entries were not synchronized between peers.

This patch adds two new stick-table messages to provide such a synchronization feature.

As these new messages are not supported by older haproxy peers protocol versions,
this patch increments peers protol version, from 2.0 to 2.1, to help in detecting/supporting
such older peers protocol implementations so that new versions might still be able
to transparently communicate with a newer one.

[wt: technically speaking it would be nice to have this backported into 1.6
 as some people who reload often are affected by this design limitation, but
 it's not a totally transparent change that may make certain users feel
 reluctant to upgrade older versions. Let's let it cook in 1.7 first and
 decide later]

9 years agoMINOR: Add fe_req_rate sample fetch
Nenad Merdanovic [Mon, 3 Oct 2016 02:57:37 +0000 (04:57 +0200)] 
MINOR: Add fe_req_rate sample fetch

The fe_req_rate is similar to fe_sess_rate, but fetches the number
of HTTP requests per second instead of connections/sessions per second.

Signed-off-by: Nenad Merdanovic <nmerdan@anine.io>
9 years agoBUG/MEDIUM: dns: don't randomly crash on out-of-memory
Willy Tarreau [Sat, 1 Oct 2016 07:20:32 +0000 (09:20 +0200)] 
BUG/MEDIUM: dns: don't randomly crash on out-of-memory

dns_init_resolvers() tries to emit the current resolver's name in the
error message in case of out-of-memory condition. But it must not do
it when initializing the trash before even having such a resolver
otherwise the user is certain to get a dirty crash instead of the
error message. No backport is needed.