blob: abd1130035c95961f2086833a0050a065a5265ff [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
Willy Tarreau5ab04ec2011-03-20 10:32:26 +01002 * include/types/server.h
3 * This file defines everything related to servers.
4 *
Willy Tarreauf09c6602012-02-13 17:12:08 +01005 * Copyright (C) 2000-2012 Willy Tarreau - w@1wt.eu
Willy Tarreau5ab04ec2011-03-20 10:32:26 +01006 *
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation, version 2.1
10 * exclusively.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 */
Willy Tarreaubaaee002006-06-26 02:48:02 +020021
22#ifndef _TYPES_SERVER_H
23#define _TYPES_SERVER_H
24
25#include <netinet/in.h>
26#include <arpa/inet.h>
27
Emeric Brunc6545ac2012-05-18 15:46:21 +020028#ifdef USE_OPENSSL
29#include <openssl/ssl.h>
30#endif
31
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020032#include <common/config.h>
Willy Tarreau2dd0d472006-06-29 17:53:05 +020033#include <common/mini-clist.h>
Willy Tarreau45cb4fb2009-10-26 21:10:04 +010034#include <eb32tree.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020035
Willy Tarreauda92e2f2012-07-06 09:40:59 +020036#include <types/connection.h>
Krzysztof Piotr Oledzki052d4fd2009-10-04 14:52:57 +020037#include <types/counters.h>
Willy Tarreau7f062c42009-03-05 18:43:00 +010038#include <types/freq_ctr.h>
Willy Tarreau3fdb3662012-11-12 00:42:33 +010039#include <types/obj_type.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020040#include <types/proxy.h>
41#include <types/queue.h>
42#include <types/task.h>
Krzysztof Piotr Oledzki09605412009-09-23 22:09:24 +020043#include <types/checks.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020044
45
Godbachf2dd68d2014-12-10 10:21:30 +080046/* server states. Only SRV_ST_STOPPED indicates a down server. */
Willy Tarreauc93cd162014-05-13 15:54:22 +020047enum srv_state {
Willy Tarreau892337c2014-05-13 23:41:20 +020048 SRV_ST_STOPPED = 0, /* the server is down. Please keep set to zero. */
49 SRV_ST_STARTING, /* the server is warming up (up but throttled) */
50 SRV_ST_RUNNING, /* the server is fully up */
51 SRV_ST_STOPPING, /* the server is up but soft-stopping (eg: 404) */
Willy Tarreauc93cd162014-05-13 15:54:22 +020052};
53
Willy Tarreaubfc7b7a2014-05-22 16:14:34 +020054/* Administrative status : a server runs in one of these 3 stats :
55 * - READY : normal mode
56 * - DRAIN : takes no new visitor, equivalent to weight == 0
57 * - MAINT : maintenance mode, no more traffic nor health checks.
58 *
59 * Each server may be in maintenance by itself or may inherit this status from
60 * another server it tracks. It can also be in drain mode by itself or inherit
61 * it from another server. Let's store these origins here as flags. These flags
62 * are combined this way :
63 *
64 * FMAINT IMAINT FDRAIN IDRAIN Resulting state
65 * 0 0 0 0 READY
66 * 0 0 0 1 DRAIN
67 * 0 0 1 x DRAIN
68 * 0 1 x x MAINT
69 * 1 x x x MAINT
70 *
71 * This can be simplified this way :
72 *
73 * state_str = (state & MAINT) ? "MAINT" : (state & DRAIN) : "DRAIN" : "READY"
Willy Tarreau20125212014-05-13 19:44:56 +020074 */
75enum srv_admin {
Baptiste Assmann9f5ada32015-08-08 15:49:13 +020076 SRV_ADMF_FMAINT = 0x01, /* the server was explicitly forced into maintenance */
77 SRV_ADMF_IMAINT = 0x02, /* the server has inherited the maintenance status from a tracked server */
Baptiste Assmann54a47302015-09-18 10:30:03 +020078 SRV_ADMF_MAINT = 0x03, /* mask to check if any maintenance flag is present */
Baptiste Assmann9f5ada32015-08-08 15:49:13 +020079 SRV_ADMF_CMAINT = 0x04, /* the server is in maintenance because of the configuration */
Baptiste Assmann9f5ada32015-08-08 15:49:13 +020080 SRV_ADMF_FDRAIN = 0x08, /* the server was explicitly forced into drain state */
81 SRV_ADMF_IDRAIN = 0x10, /* the server has inherited the drain status from a tracked server */
82 SRV_ADMF_DRAIN = 0x18, /* mask to check if any drain flag is present */
Willy Tarreau20125212014-05-13 19:44:56 +020083};
84
Baptiste Assmann41472f42015-05-08 23:34:06 +020085/* server-state-file version */
86#define SRV_STATE_FILE_VERSION 1
87#define SRV_STATE_FILE_VERSION_MIN 1
88#define SRV_STATE_FILE_VERSION_MAX 1
89#define SRV_STATE_FILE_FIELD_NAMES "be_id be_name srv_id srv_name srv_addr srv_op_state srv_admin_state srv_uweight srv_iweight srv_time_since_last_change srv_check_status srv_check_result srv_check_health srv_check_state srv_agent_state bk_f_forced_id srv_f_forced_id"
90#define SRV_STATE_FILE_MAX_FIELDS 18
91#define SRV_STATE_FILE_NB_FIELDS_VERSION_1 18
92#define SRV_STATE_LINE_MAXLEN 512
93
94
Willy Tarreaubaaee002006-06-26 02:48:02 +020095/* server flags */
Willy Tarreauc93cd162014-05-13 15:54:22 +020096#define SRV_F_BACKUP 0x0001 /* this server is a backup server */
97#define SRV_F_MAPPORTS 0x0002 /* this server uses mapped ports */
98#define SRV_F_NON_STICK 0x0004 /* never add connections allocated to this server to a stick table */
KOVACS Krisztianb3e54fe2014-11-17 15:11:45 +010099#define SRV_F_USE_NS_FROM_PP 0x0008 /* use namespace associated with connection if present */
Baptiste Assmann7cc419a2015-07-07 22:02:20 +0200100#define SRV_F_FORCED_ID 0x0010 /* server's ID was forced in the configuration */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200101
David Safb76832014-05-08 23:42:08 -0400102/* configured server options for send-proxy (server->pp_opts) */
103#define SRV_PP_V1 0x0001 /* proxy protocol version 1 */
104#define SRV_PP_V2 0x0002 /* proxy protocol version 2 */
105#define SRV_PP_V2_SSL 0x0004 /* proxy protocol version 2 with SSL*/
106#define SRV_PP_V2_SSL_CN 0x0008 /* proxy protocol version 2 with SSL and CN*/
107
Willy Tarreaubaaee002006-06-26 02:48:02 +0200108/* function which act on servers need to return various errors */
109#define SRV_STATUS_OK 0 /* everything is OK. */
110#define SRV_STATUS_INTERNAL 1 /* other unrecoverable errors. */
111#define SRV_STATUS_NOSRV 2 /* no server is available */
112#define SRV_STATUS_FULL 3 /* the/all server(s) are saturated */
113#define SRV_STATUS_QUEUED 4 /* the/all server(s) are saturated but the connection was queued */
114
Willy Tarreaub698f0f2007-12-02 11:01:23 +0100115/* various constants */
116#define SRV_UWGHT_RANGE 256
Godbacha34bdc02013-07-22 07:44:53 +0800117#define SRV_UWGHT_MAX (SRV_UWGHT_RANGE)
Willy Tarreaub698f0f2007-12-02 11:01:23 +0100118#define SRV_EWGHT_RANGE (SRV_UWGHT_RANGE * BE_WEIGHT_SCALE)
119#define SRV_EWGHT_MAX (SRV_UWGHT_MAX * BE_WEIGHT_SCALE)
120
Emeric Brun89675492012-10-05 13:48:26 +0200121#ifdef USE_OPENSSL
122/* server ssl options */
123#define SRV_SSL_O_NONE 0x0000
Emeric Brun992adc92012-10-11 18:36:21 +0200124#define SRV_SSL_O_NO_VMASK 0x000F /* force version mask */
Emeric Brun89675492012-10-05 13:48:26 +0200125#define SRV_SSL_O_NO_SSLV3 0x0001 /* disable SSLv3 */
126#define SRV_SSL_O_NO_TLSV10 0x0002 /* disable TLSv1.0 */
127#define SRV_SSL_O_NO_TLSV11 0x0004 /* disable TLSv1.1 */
128#define SRV_SSL_O_NO_TLSV12 0x0008 /* disable TLSv1.2 */
129/* 0x000F reserved for 'no' protocol version options */
Emeric Brun992adc92012-10-11 18:36:21 +0200130#define SRV_SSL_O_USE_VMASK 0x00F0 /* force version mask */
131#define SRV_SSL_O_USE_SSLV3 0x0010 /* force SSLv3 */
132#define SRV_SSL_O_USE_TLSV10 0x0020 /* force TLSv1.0 */
133#define SRV_SSL_O_USE_TLSV11 0x0040 /* force TLSv1.1 */
134#define SRV_SSL_O_USE_TLSV12 0x0080 /* force TLSv1.2 */
Emeric Brun8694b9a2012-10-05 14:39:07 +0200135/* 0x00F0 reserved for 'force' protocol version options */
Emeric Brunf9c5c472012-10-11 15:28:34 +0200136#define SRV_SSL_O_NO_TLS_TICKETS 0x0100 /* disable session resumption tickets */
Willy Tarreau2a3fb1c2015-02-05 16:47:07 +0100137#define SRV_SSL_O_NO_REUSE 0x200 /* disable session reuse */
Emeric Brun89675492012-10-05 13:48:26 +0200138#endif
139
Simon Horman98637e52014-06-20 12:30:16 +0900140struct pid_list {
141 struct list list;
142 pid_t pid;
143 struct task *t;
144 int status;
145 int exited;
146};
147
Willy Tarreau6b2e11b2009-10-01 07:52:15 +0200148/* A tree occurrence is a descriptor of a place in a tree, with a pointer back
149 * to the server itself.
150 */
151struct server;
152struct tree_occ {
153 struct server *server;
154 struct eb32_node node;
155};
156
Willy Tarreaubaaee002006-06-26 02:48:02 +0200157struct server {
Willy Tarreau3fdb3662012-11-12 00:42:33 +0100158 enum obj_type obj_type; /* object type == OBJ_TYPE_SERVER */
Willy Tarreau892337c2014-05-13 23:41:20 +0200159 enum srv_state state, prev_state; /* server state among SRV_ST_* */
Willy Tarreau20125212014-05-13 19:44:56 +0200160 enum srv_admin admin, prev_admin; /* server maintenance status : SRV_ADMF_* */
Willy Tarreauc93cd162014-05-13 15:54:22 +0200161 unsigned char flags; /* server flags (SRV_F_*) */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200162 struct server *next;
Krzysztof Piotr Oledzki09605412009-09-23 22:09:24 +0200163 int cklen; /* the len of the cookie, to speed up checks */
Willy Tarreau21d2af32008-02-14 20:25:24 +0100164 int rdr_len; /* the length of the redirection prefix */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200165 char *cookie; /* the id set in the cookie */
Willy Tarreau21d2af32008-02-14 20:25:24 +0100166 char *rdr_pfx; /* the redirection prefix */
David Safb76832014-05-08 23:42:08 -0400167 int pp_opts; /* proxy protocol options (SRV_PP_*) */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200168
169 struct proxy *proxy; /* the proxy this server belongs to */
Willy Tarreau7c669d72008-06-20 15:04:11 +0200170 int served; /* # of active sessions currently being served (ie not pending) */
Willy Tarreauac68c5d2009-10-04 23:12:44 +0200171 int cur_sess; /* number of currently active sessions (including syn_sent) */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200172 unsigned maxconn, minconn; /* max # of active sessions (0 = unlimited), min# for dynamic limit. */
Willy Tarreauac68c5d2009-10-04 23:12:44 +0200173 int nbpend; /* number of pending connections */
Elijah Epifanovacafc5f2007-10-25 20:15:38 +0200174 int maxqueue; /* maximum number of pending connections allowed */
Willy Tarreau7b815632011-10-21 18:51:57 +0200175 struct freq_ctr sess_per_sec; /* sessions per second on this server */
Willy Tarreauac68c5d2009-10-04 23:12:44 +0200176 struct srvcounters counters; /* statistics counters */
177
Willy Tarreau91b6f322007-03-25 21:03:01 +0200178 struct list pendconns; /* pending connections */
Simon Hormanaf514952011-06-21 14:34:57 +0900179 struct list actconns; /* active connections */
Willy Tarreau600802a2015-08-04 17:19:06 +0200180 struct list priv_conns; /* private idle connections attached to stream interfaces */
Willy Tarreau173a1c62015-08-05 10:31:57 +0200181 struct list idle_conns; /* sharable idle connections attached or not to a stream interface */
Willy Tarreau7017cb02015-08-05 16:35:23 +0200182 struct list safe_conns; /* safe idle connections attached to stream interfaces, shared */
Willy Tarreau2e993902011-10-31 11:53:20 +0100183 struct task *warmup; /* the task dedicated to the warmup when slowstart is set */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200184
Willy Tarreauef9a3602012-12-08 22:29:20 +0100185 struct conn_src conn_src; /* connection source settings */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200186
Willy Tarreau1a53a3a2013-12-11 15:27:05 +0100187 struct server *track; /* the server we're currently tracking, if any */
188 struct server *trackers; /* the list of servers tracking us, if any */
189 struct server *tracknext; /* next server tracking <track> in <track>'s trackers list */
Krzysztof Piotr Oledzkic8b16fc2008-02-18 01:26:35 +0100190 char *trackit; /* temporary variable to make assignment deferrable */
Krzysztof Piotr Oledzki97f07b82009-12-15 22:31:24 +0100191 int consecutive_errors; /* current number of consecutive errors */
Krzysztof Piotr Oledzki97f07b82009-12-15 22:31:24 +0100192 int consecutive_errors_limit; /* number of consecutive errors that triggers an event */
193 short observe, onerror; /* observing mode: one of HANA_OBS_*; what to do on error: on of ANA_ONERR_* */
Justin Karnegeseb2c24a2012-05-24 15:28:52 -0700194 short onmarkeddown; /* what to do when marked down: one of HANA_ONMARKEDDOWN_* */
195 short onmarkedup; /* what to do when marked up: one of HANA_ONMARKEDUP_* */
Willy Tarreau9909fc12007-11-30 17:42:05 +0100196 int slowstart; /* slowstart time in seconds (ms in the conf) */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200197
198 char *id; /* just for identification */
Willy Tarreau975c50b2009-10-10 19:34:06 +0200199 unsigned iweight,uweight, eweight; /* initial weight, user-specified weight, and effective weight */
Willy Tarreau417fae02007-03-25 21:16:40 +0200200 unsigned wscore; /* weight score, used during srv map computation */
Willy Tarreaub625a082007-11-26 01:15:43 +0100201 unsigned prev_eweight; /* eweight before last change */
202 unsigned rweight; /* remainer of weight in the current LB tree */
203 unsigned npos, lpos; /* next and last positions in the LB tree */
204 struct eb32_node lb_node; /* node used for tree-based load balancing */
205 struct eb_root *lb_tree; /* we want to know in what tree the server is */
206 struct server *next_full; /* next server in the temporary full list */
Willy Tarreau6b2e11b2009-10-01 07:52:15 +0200207 unsigned lb_nodes_tot; /* number of allocated lb_nodes (C-HASH) */
208 unsigned lb_nodes_now; /* number of lb_nodes placed in the tree (C-HASH) */
209 struct tree_occ *lb_nodes; /* lb_nodes_tot * struct tree_occ */
Willy Tarreau91b6f322007-03-25 21:03:01 +0200210
KOVACS Krisztianb3e54fe2014-11-17 15:11:45 +0100211 const struct netns_entry *netns; /* contains network namespace name or NULL. Network namespace comes from configuration */
Willy Tarreau7b815632011-10-21 18:51:57 +0200212 /* warning, these structs are huge, keep them at the bottom */
213 struct sockaddr_storage addr; /* the address to connect to */
Willy Tarreauf7bc57c2012-10-03 00:19:48 +0200214 struct xprt_ops *xprt; /* transport-layer operations */
Krzysztof Oledzki85130942007-10-22 16:21:10 +0200215 unsigned down_time; /* total time the server was down */
216 time_t last_change; /* last time, when the state was changed */
217
Willy Tarreauf09c6602012-02-13 17:12:08 +0100218 int puid; /* proxy-unique server ID, used for SNMP, and "first" LB algo */
Krzysztof Piotr Oledzki052d4fd2009-10-04 14:52:57 +0200219
Simon Horman66183002013-02-23 10:16:43 +0900220 struct check check; /* health-check specific configuration */
Simon Hormand60d6912013-11-25 10:46:36 +0900221 struct check agent; /* agent specific configuration */
Nick Chalk57b1bf72010-03-16 15:50:46 +0000222
Baptiste Assmanna68ca962015-04-14 01:15:08 +0200223 char *resolvers_id; /* resolvers section used by this server */
224 char *hostname; /* server hostname */
225 struct dns_resolution *resolution; /* server name resolution */
226 int resolver_family_priority; /* which IP family should the resolver use when both are returned */
227
Emeric Brunc6545ac2012-05-18 15:46:21 +0200228#ifdef USE_OPENSSL
Emeric Brun01f8e2f2012-05-18 16:02:00 +0200229 int use_ssl; /* ssl enabled */
Emeric Brunc6545ac2012-05-18 15:46:21 +0200230 struct {
231 SSL_CTX *ctx;
232 SSL_SESSION *reused_sess;
Willy Tarreaud7aacbf2012-09-03 23:34:19 +0200233 char *ciphers; /* cipher suite to use if non-null */
Emeric Brun89675492012-10-05 13:48:26 +0200234 int options; /* ssl options */
Emeric Brunef42d922012-10-11 16:11:36 +0200235 int verify; /* verify method (set of SSL_VERIFY_* flags) */
Evan Broderbe554312013-06-27 00:05:25 -0700236 char *verify_host; /* hostname of certificate must match this host */
Emeric Brunef42d922012-10-11 16:11:36 +0200237 char *ca_file; /* CAfile to use on verify */
238 char *crl_file; /* CRLfile to use on verify */
Emeric Bruna7aa3092012-10-26 12:58:00 +0200239 char *client_crt; /* client certificate to send */
Willy Tarreau732eac42015-07-09 11:40:25 +0200240 struct sample_expr *sni; /* sample expression for SNI */
Emeric Brunc6545ac2012-05-18 15:46:21 +0200241 } ssl_ctx;
242#endif
Willy Tarreau90a570f2009-10-04 20:54:54 +0200243 struct {
244 const char *file; /* file where the section appears */
245 int line; /* line where the section appears */
Willy Tarreau53fb4ae2009-10-04 23:04:08 +0200246 struct eb32_node id; /* place in the tree of used IDs */
Willy Tarreau90a570f2009-10-04 20:54:54 +0200247 } conf; /* config information */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200248};
249
Willy Tarreau21faa912012-10-10 08:27:36 +0200250/* Descriptor for a "server" keyword. The ->parse() function returns 0 in case of
251 * success, or a combination of ERR_* flags if an error is encountered. The
252 * function pointer can be NULL if not implemented. The function also has an
253 * access to the current "server" config line. The ->skip value tells the parser
254 * how many words have to be skipped after the keyword. If the function needs to
255 * parse more keywords, it needs to update cur_arg.
256 */
257struct srv_kw {
258 const char *kw;
259 int (*parse)(char **args, int *cur_arg, struct proxy *px, struct server *srv, char **err);
260 int skip; /* nb min of args to skip, for use when kw is not handled */
261 int default_ok; /* non-zero if kw is supported in default-server section */
262};
263
264/*
265 * A keyword list. It is a NULL-terminated array of keywords. It embeds a
266 * struct list in order to be linked to other lists, allowing it to easily
267 * be declared where it is needed, and linked without duplicating data nor
268 * allocating memory. It is also possible to indicate a scope for the keywords.
269 */
270struct srv_kw_list {
271 const char *scope;
272 struct list list;
273 struct srv_kw kw[VAR_ARRAY];
274};
Willy Tarreaubaaee002006-06-26 02:48:02 +0200275
276#endif /* _TYPES_SERVER_H */
277
278/*
279 * Local variables:
280 * c-indent-level: 8
281 * c-basic-offset: 8
282 * End:
283 */