blob: 93f4f81a66cb5788b298903f11fbd7c1e93a862d [file] [log] [blame]
Willy TARREAU3dc06442006-06-15 21:48:13 +02001/*
Willy Tarreauac68c5d2009-10-04 23:12:44 +02002 * include/proto/server.h
3 * This file defines everything related to servers.
4 *
5 * Copyright (C) 2000-2009 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 TARREAU3dc06442006-06-15 21:48:13 +020021
Willy Tarreaubaaee002006-06-26 02:48:02 +020022#ifndef _PROTO_SERVER_H
23#define _PROTO_SERVER_H
24
25#include <unistd.h>
26
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020027#include <common/config.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020028#include <types/proxy.h>
29#include <types/queue.h>
30#include <types/server.h>
Willy TARREAU3dc06442006-06-15 21:48:13 +020031
Willy Tarreaubaaee002006-06-26 02:48:02 +020032#include <proto/queue.h>
Willy Tarreau7f062c42009-03-05 18:43:00 +010033#include <proto/freq_ctr.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020034
Simon Hormana3608442013-11-01 16:46:15 +090035int srv_downtime(const struct server *s);
Simon Horman4a741432013-02-23 15:35:38 +090036int srv_getinter(const struct check *check);
Willy Tarreaubaaee002006-06-26 02:48:02 +020037
Willy Tarreau7f062c42009-03-05 18:43:00 +010038/* increase the number of cumulated connections on the designated server */
39static void inline srv_inc_sess_ctr(struct server *s)
40{
Krzysztof Piotr Oledzki052d4fd2009-10-04 14:52:57 +020041 s->counters.cum_sess++;
Willy Tarreau7f062c42009-03-05 18:43:00 +010042 update_freq_ctr(&s->sess_per_sec, 1);
Willy Tarreauac68c5d2009-10-04 23:12:44 +020043 if (s->sess_per_sec.curr_ctr > s->counters.sps_max)
44 s->counters.sps_max = s->sess_per_sec.curr_ctr;
Willy Tarreau7f062c42009-03-05 18:43:00 +010045}
46
Willy Tarreaubaaee002006-06-26 02:48:02 +020047#endif /* _PROTO_SERVER_H */
Willy TARREAU3dc06442006-06-15 21:48:13 +020048
Willy Tarreaubaaee002006-06-26 02:48:02 +020049/*
Willy Tarreau21faa912012-10-10 08:27:36 +020050 * Registers the server keyword list <kwl> as a list of valid keywords for next
51 * parsing sessions.
52 */
53void srv_register_keywords(struct srv_kw_list *kwl);
54
55/* Return a pointer to the server keyword <kw>, or NULL if not found. */
56struct srv_kw *srv_find_kw(const char *kw);
57
58/* Dumps all registered "server" keywords to the <out> string pointer. */
59void srv_dump_kws(char **out);
60
Willy Tarreau004e0452013-11-21 11:22:01 +010061/* Recomputes the server's eweight based on its state, uweight, the current time,
62 * and the proxy's algorihtm. To be used after updating sv->uweight. The warmup
63 * state is automatically disabled if the time is elapsed.
64 */
65void server_recalc_eweight(struct server *sv);
66
Willy Tarreaud32c3992013-11-21 15:30:45 +010067/* returns the current server throttle rate between 0 and 100% */
68static inline unsigned int server_throttle_rate(struct server *sv)
69{
70 struct proxy *px = sv->proxy;
71
72 /* when uweight is 0, we're in soft-stop so that cannot be a slowstart,
73 * thus the throttle is 100%.
74 */
75 if (!sv->uweight)
76 return 100;
77
Willy Tarreaue38feed2013-12-16 18:04:57 +010078 return (100U * px->lbprm.wmult * sv->eweight + px->lbprm.wdiv - 1) / (px->lbprm.wdiv * sv->uweight);
Willy Tarreaud32c3992013-11-21 15:30:45 +010079}
80
Willy Tarreau21faa912012-10-10 08:27:36 +020081/*
Simon Horman7d09b9a2013-02-12 10:45:51 +090082 * Parses weight_str and configures sv accordingly.
83 * Returns NULL on success, error message string otherwise.
84 */
85const char *server_parse_weight_change_request(struct server *sv,
86 const char *weight_str);
87
88/*
Simon Horman8c3d0be2013-11-25 10:46:40 +090089 * Update the server's drain state to reflect its user-weight. This is not
90 * done immediately to allow a discrepancy between the server's user-weight
91 * and drains state to control logging of changes in the drain state.
92 */
93static inline void set_server_drain_state(struct server *s)
94{
95 if (!s->uweight)
96 s->state |= SRV_DRAIN;
97 else
98 s->state &= ~SRV_DRAIN;
99}
100/*
Willy Tarreaubaaee002006-06-26 02:48:02 +0200101 * Local variables:
102 * c-indent-level: 8
103 * c-basic-offset: 8
104 * End:
105 */