blob: 39a7f3d28b4177fe1f7a4872d83c301c92b005be [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
Willy Tarreau62c3be22012-01-20 13:12:32 +01002 * include/proto/backend.h
3 * Functions prototypes for the backend.
4 *
5 * Copyright (C) 2000-2012 Willy Tarreau - w@1wt.eu
6 *
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 _PROTO_BACKEND_H
23#define _PROTO_BACKEND_H
24
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020025#include <common/config.h>
Bhaskar Maddalaa20cb852014-02-03 16:26:46 -050026#include <common/time.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020027
28#include <types/backend.h>
Willy Tarreauf89c1872009-10-01 11:19:37 +020029#include <types/proxy.h>
30#include <types/server.h>
Willy Tarreau87b09662015-04-03 00:22:06 +020031#include <types/stream.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020032
Willy Tarreau87b09662015-04-03 00:22:06 +020033int assign_server(struct stream *s);
34int assign_server_address(struct stream *s);
35int assign_server_and_queue(struct stream *s);
36int connect_server(struct stream *s);
37int srv_redispatch_connect(struct stream *t);
Krzysztof Piotr Oledzki15514c22010-01-04 16:03:09 +010038const char *backend_lb_algo_str(int algo);
Willy Tarreaua93c74b2012-05-08 18:14:39 +020039int backend_parse_balance(const char **args, char **err, struct proxy *curproxy);
Willy Tarreau87b09662015-04-03 00:22:06 +020040int tcp_persist_rdp_cookie(struct stream *s, struct channel *req, int an_bit);
Willy Tarreaubaaee002006-06-26 02:48:02 +020041
Krzysztof Oledzki85130942007-10-22 16:21:10 +020042int be_downtime(struct proxy *px);
Willy Tarreauc5d9c802009-10-01 09:17:05 +020043void recount_servers(struct proxy *px);
44void update_backend_weight(struct proxy *px);
Willy Tarreauca7d4b92009-10-01 09:21:55 +020045struct server *get_server_sh(struct proxy *px, const char *addr, int len);
46struct server *get_server_uh(struct proxy *px, char *uri, int uri_len);
Bhaskar Maddalaa20cb852014-02-03 16:26:46 -050047int be_lastsession(const struct proxy *be);
48
Nenad Merdanovicb7e7c472017-03-12 21:56:55 +010049/* Returns number of usable servers in backend */
50static inline int be_usable_srv(struct proxy *be)
51{
52 if (be->state == PR_STSTOPPED)
53 return 0;
54 else if (be->srv_act)
55 return be->srv_act;
56 else if (be->lbprm.fbck)
57 return 1;
58 else
59 return be->srv_bck;
60}
61
Bhaskar Maddalaa20cb852014-02-03 16:26:46 -050062/* set the time of last session on the backend */
63static void inline be_set_sess_last(struct proxy *be)
64{
65 be->be_counters.last_sess = now.tv_sec;
66}
Willy Tarreauc5d9c802009-10-01 09:17:05 +020067
Willy Tarreau87eb1d62014-05-13 18:51:40 +020068/* This function returns non-zero if the designated server is usable for LB
69 * according to its current weight and current state. Otherwise it returns 0.
Willy Tarreauc5d9c802009-10-01 09:17:05 +020070 */
Willy Tarreau87eb1d62014-05-13 18:51:40 +020071static inline int srv_is_usable(const struct server *srv)
72{
Willy Tarreauc93cd162014-05-13 15:54:22 +020073 enum srv_state state = srv->state;
Willy Tarreau87eb1d62014-05-13 18:51:40 +020074
75 if (!srv->eweight)
76 return 0;
Willy Tarreau20125212014-05-13 19:44:56 +020077 if (srv->admin & SRV_ADMF_MAINT)
78 return 0;
Willy Tarreaubfc7b7a2014-05-22 16:14:34 +020079 if (srv->admin & SRV_ADMF_DRAIN)
80 return 0;
Willy Tarreau892337c2014-05-13 23:41:20 +020081 switch (state) {
82 case SRV_ST_STARTING:
83 case SRV_ST_RUNNING:
84 return 1;
85 case SRV_ST_STOPPING:
86 case SRV_ST_STOPPED:
Willy Tarreau87eb1d62014-05-13 18:51:40 +020087 return 0;
Willy Tarreau892337c2014-05-13 23:41:20 +020088 }
89 return 0;
Willy Tarreau87eb1d62014-05-13 18:51:40 +020090}
91
92/* This function returns non-zero if the designated server was usable for LB
93 * according to its current weight and previous state. Otherwise it returns 0.
94 */
95static inline int srv_was_usable(const struct server *srv)
Willy Tarreauc5d9c802009-10-01 09:17:05 +020096{
Willy Tarreauc93cd162014-05-13 15:54:22 +020097 enum srv_state state = srv->prev_state;
Willy Tarreau87eb1d62014-05-13 18:51:40 +020098
99 if (!srv->prev_eweight)
Willy Tarreauc5d9c802009-10-01 09:17:05 +0200100 return 0;
Willy Tarreau20125212014-05-13 19:44:56 +0200101 if (srv->prev_admin & SRV_ADMF_MAINT)
102 return 0;
Willy Tarreaubfc7b7a2014-05-22 16:14:34 +0200103 if (srv->prev_admin & SRV_ADMF_DRAIN)
104 return 0;
Willy Tarreau892337c2014-05-13 23:41:20 +0200105 switch (state) {
106 case SRV_ST_STARTING:
107 case SRV_ST_RUNNING:
108 return 1;
109 case SRV_ST_STOPPING:
110 case SRV_ST_STOPPED:
Willy Tarreauc5d9c802009-10-01 09:17:05 +0200111 return 0;
Willy Tarreau892337c2014-05-13 23:41:20 +0200112 }
113 return 0;
Willy Tarreauc5d9c802009-10-01 09:17:05 +0200114}
Willy Tarreaubaaee002006-06-26 02:48:02 +0200115
Willy Tarreauc5150da2014-05-13 19:27:31 +0200116/* This function commits the current server state and weight onto the previous
117 * ones in order to detect future changes.
118 */
119static inline void srv_lb_commit_status(struct server *srv)
120{
121 srv->prev_state = srv->state;
Willy Tarreau20125212014-05-13 19:44:56 +0200122 srv->prev_admin = srv->admin;
Willy Tarreauc5150da2014-05-13 19:27:31 +0200123 srv->prev_eweight = srv->eweight;
124}
125
126/* This function returns true when a server has experienced a change since last
127 * commit on its state or weight, otherwise zero.
128 */
129static inline int srv_lb_status_changed(const struct server *srv)
130{
131 return (srv->state != srv->prev_state ||
Willy Tarreau20125212014-05-13 19:44:56 +0200132 srv->admin != srv->prev_admin ||
Willy Tarreauc5150da2014-05-13 19:27:31 +0200133 srv->eweight != srv->prev_eweight);
134}
135
Willy Tarreau4aac7db2014-05-16 11:48:10 +0200136/* sends a log message when a backend goes down, and also sets last
137 * change date.
138 */
139void set_backend_down(struct proxy *be);
140
Willy Tarreaubaaee002006-06-26 02:48:02 +0200141#endif /* _PROTO_BACKEND_H */
142
143/*
144 * Local variables:
145 * c-indent-level: 8
146 * c-basic-offset: 8
147 * End:
148 */