blob: effc51c2c6e7ec35ffae89f20c644401a4f67619 [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
Willy Tarreau8096de92010-02-26 11:12:27 +01002 * include/types/global.h
3 * Global variables.
4 *
Willy Tarreaue9f49e72012-11-11 17:42:00 +01005 * Copyright (C) 2000-2012 Willy Tarreau - w@1wt.eu
Willy Tarreau8096de92010-02-26 11:12:27 +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_GLOBAL_H
23#define _TYPES_GLOBAL_H
24
25#include <netinet/in.h>
26
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020027#include <common/config.h>
Willy Tarreau65d805f2014-07-15 18:05:58 +020028#include <common/standard.h>
Christopher Faulet6adad112017-04-21 16:47:03 +020029#include <common/hathreads.h>
30
Willy Tarreauc7e42382012-08-24 19:22:53 +020031#include <types/freq_ctr.h>
Willy Tarreaud1d54542012-09-12 22:58:11 +020032#include <types/listener.h>
Willy Tarreau89a63132009-08-16 17:41:45 +020033#include <types/proxy.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020034#include <types/task.h>
Christopher Fauletff2613e2016-11-09 11:36:17 +010035#include <types/vars.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020036
Emeric Brunc8e8d122012-10-02 18:42:10 +020037#ifndef UNIX_MAX_PATH
38#define UNIX_MAX_PATH 108
39#endif
40
Willy Tarreaubaaee002006-06-26 02:48:02 +020041/* modes of operation (global.mode) */
Willy Tarreaufbee7132007-10-18 13:53:22 +020042#define MODE_DEBUG 0x01
43#define MODE_DAEMON 0x02
44#define MODE_QUIET 0x04
45#define MODE_CHECK 0x08
46#define MODE_VERBOSE 0x10
47#define MODE_STARTING 0x20
48#define MODE_FOREGROUND 0x40
William Lallemand095ba4c2017-06-01 17:38:50 +020049#define MODE_MWORKER 0x80 /* Master Worker */
Willy Tarreaubaaee002006-06-26 02:48:02 +020050
Willy Tarreau77074d52006-11-12 23:57:19 +010051/* list of last checks to perform, depending on config options */
52#define LSTCHK_CAP_BIND 0x00000001 /* check that we can bind to any port */
Willy Tarreau29fbe512015-08-20 19:35:14 +020053#define LSTCHK_NETADM 0x00000002 /* check that we have CAP_NET_ADMIN */
Willy Tarreaubaaee002006-06-26 02:48:02 +020054
Willy Tarreau43b78992009-01-25 15:42:27 +010055/* Global tuning options */
56/* available polling mechanisms */
57#define GTUNE_USE_SELECT (1<<0)
58#define GTUNE_USE_POLL (1<<1)
59#define GTUNE_USE_EPOLL (1<<2)
60#define GTUNE_USE_KQUEUE (1<<3)
Willy Tarreau3ab68cf2009-01-25 16:03:28 +010061/* platform-specific options */
Willy Tarreaue9f49e72012-11-11 17:42:00 +010062#define GTUNE_USE_SPLICE (1<<4)
Nenad Merdanovic88afe032014-04-14 15:56:58 +020063#define GTUNE_USE_GAI (1<<5)
Lukas Tribusa0bcbdc2016-09-12 21:42:20 +000064#define GTUNE_USE_REUSEPORT (1<<6)
Willy Tarreau3eed10e2016-11-07 21:03:16 +010065#define GTUNE_RESOLVE_DONTFAIL (1<<7)
Willy Tarreau43b78992009-01-25 15:42:27 +010066
Olivier Houchard1fc05162017-04-06 01:05:05 +020067#define GTUNE_SOCKET_TRANSFER (1<<8)
William Lallemand4cfede82017-11-24 22:02:34 +010068#define GTUNE_NOEXIT_ONFAILURE (1<<9)
Tim Duesterhusd6942c82017-11-20 15:58:35 +010069#define GTUNE_USE_SYSTEMD (1<<10)
Olivier Houchard1fc05162017-04-06 01:05:05 +020070
Willy Tarreau6162db22009-10-10 17:13:00 +020071/* Access level for a stats socket */
72#define ACCESS_LVL_NONE 0
73#define ACCESS_LVL_USER 1
74#define ACCESS_LVL_OPER 2
75#define ACCESS_LVL_ADMIN 3
William Lallemand07a62f72017-05-24 00:57:40 +020076#define ACCESS_LVL_MASK 0x3
77
William Lallemandf6975e92017-05-26 17:42:10 +020078#define ACCESS_FD_LISTENERS 0x4 /* expose listeners FDs on stats socket */
William Lallemand14721be2018-10-26 14:47:37 +020079#define ACCESS_MASTER 0x8 /* works with the master (and every other processes) */
80#define ACCESS_MASTER_ONLY 0x10 /* only works with the worker */
Willy Tarreau43b78992009-01-25 15:42:27 +010081
Emeric Brun850efd52014-01-29 12:24:34 +010082/* SSL server verify mode */
83enum {
84 SSL_SERVER_VERIFY_NONE = 0,
85 SSL_SERVER_VERIFY_REQUIRED = 1,
86};
87
Willy Tarreaubaaee002006-06-26 02:48:02 +020088/* FIXME : this will have to be redefined correctly */
89struct global {
Willy Tarreau77074d52006-11-12 23:57:19 +010090 int uid;
91 int gid;
Simon Horman98637e52014-06-20 12:30:16 +090092 int external_check;
Willy Tarreau77074d52006-11-12 23:57:19 +010093 int nbproc;
Christopher Fauletbe0faa22017-08-29 15:37:10 +020094 int nbthread;
Cyril Bonté203ec5a2017-03-23 22:44:13 +010095 unsigned int hard_stop_after; /* maximum time allowed to perform a soft-stop */
Willy Tarreau91886b62011-09-07 14:38:31 +020096 int maxconn, hardmaxconn;
Willy Tarreau403edff2012-09-06 11:58:37 +020097 int maxsslconn;
Willy Tarreaud92aa5c2015-01-15 21:34:39 +010098 int ssl_session_max_cost; /* how many bytes an SSL session may cost */
99 int ssl_handshake_max_cost; /* how many bytes an SSL handshake may use */
Willy Tarreaufce03112015-01-15 21:32:40 +0100100 int ssl_used_frontend; /* non-zero if SSL is used in a frontend */
101 int ssl_used_backend; /* non-zero if SSL is used in a backend */
Emeric Brunece0c332017-12-06 13:51:49 +0100102 int ssl_used_async_engines; /* number of used async engines */
Emeric Brun850efd52014-01-29 12:24:34 +0100103 unsigned int ssl_server_verify; /* default verify mode on servers side */
Willy Tarreau81c25d02011-09-07 15:17:21 +0200104 struct freq_ctr conn_per_sec;
Willy Tarreau93e7c002013-10-07 18:51:07 +0200105 struct freq_ctr sess_per_sec;
Willy Tarreaue43d5322013-10-07 20:01:52 +0200106 struct freq_ctr ssl_per_sec;
Willy Tarreau0c9c2722014-05-28 12:28:58 +0200107 struct freq_ctr ssl_fe_keys_per_sec;
108 struct freq_ctr ssl_be_keys_per_sec;
William Lallemandd85f9172012-11-09 17:05:39 +0100109 struct freq_ctr comp_bps_in; /* bytes per second, before http compression */
110 struct freq_ctr comp_bps_out; /* bytes per second, after http compression */
Willy Tarreau81c25d02011-09-07 15:17:21 +0200111 int cps_lim, cps_max;
Willy Tarreau93e7c002013-10-07 18:51:07 +0200112 int sps_lim, sps_max;
Willy Tarreaue43d5322013-10-07 20:01:52 +0200113 int ssl_lim, ssl_max;
Willy Tarreau0c9c2722014-05-28 12:28:58 +0200114 int ssl_fe_keys_max, ssl_be_keys_max;
Willy Tarreauce3f9132014-05-28 16:47:01 +0200115 unsigned int shctx_lookups, shctx_misses;
William Lallemandd85f9172012-11-09 17:05:39 +0100116 int comp_rate_lim; /* HTTP compression rate limit */
Willy Tarreau3ec79b92009-01-18 20:39:42 +0100117 int maxpipes; /* max # of pipes */
Willy Tarreau77074d52006-11-12 23:57:19 +0100118 int maxsock; /* max # of sockets */
119 int rlimit_nofile; /* default ulimit-n value : 0=unset */
Willy Tarreau70060452015-12-14 12:46:07 +0100120 int rlimit_memmax_all; /* default all-process memory limit in megs ; 0=unset */
121 int rlimit_memmax; /* default per-process memory limit in megs ; 0=unset */
William Lallemande3a7d992012-11-20 11:25:20 +0100122 long maxzlibmem; /* max RAM for zlib in bytes */
Willy Tarreau77074d52006-11-12 23:57:19 +0100123 int mode;
Willy Tarreau1f0da242014-01-25 11:01:50 +0100124 unsigned int req_count; /* request counter (HTTP or TCP session) for logs and unique_id */
Willy Tarreau77074d52006-11-12 23:57:19 +0100125 int last_checks;
Krzysztof Oledzkib304dc72007-10-14 23:40:01 +0200126 int spread_checks;
Willy Tarreau1746eec2014-04-25 10:46:47 +0200127 int max_spread_checks;
Willy Tarreau18324f52014-06-27 18:10:07 +0200128 int max_syslog_len;
Willy Tarreau77074d52006-11-12 23:57:19 +0100129 char *chroot;
130 char *pidfile;
Krzysztof Piotr Oledzki48cb2ae2009-10-02 22:51:14 +0200131 char *node, *desc; /* node name & description */
Willy Tarreau83061a82018-07-13 11:56:34 +0200132 struct buffer log_tag; /* name for syslog */
William Lallemand0f99e342011-10-12 17:50:54 +0200133 struct list logsrvs;
Joe Williamsdf5b38f2010-12-29 17:05:48 +0100134 char *log_send_hostname; /* set hostname in syslog header */
Baptiste Assmann6bc89362015-08-23 09:22:25 +0200135 char *server_state_base; /* path to a directory where server state files can be found */
Baptiste Assmanne0882262015-08-23 09:54:31 +0200136 char *server_state_file; /* path to the file where server states are loaded from */
Willy Tarreau1db37712007-06-03 17:16:49 +0200137 struct {
138 int maxpollevents; /* max number of poll events at once */
Willy Tarreaua0250ba2008-01-06 11:22:57 +0100139 int maxaccept; /* max number of consecutive accept() */
Willy Tarreau43b78992009-01-25 15:42:27 +0100140 int options; /* various tuning options */
Olivier Houchard1599b802018-05-24 18:59:04 +0200141 int runqueue_depth;/* max number of tasks to run at once */
Willy Tarreau6f4a82c2009-03-21 20:43:57 +0100142 int recv_enough; /* how many input bytes at once are "enough" */
Willy Tarreau27a674e2009-08-17 07:23:33 +0200143 int bufsize; /* buffer size in bytes, defaults to BUFSIZE */
144 int maxrewrite; /* buffer max rewrite size in bytes, defaults to MAXREWRITE */
Willy Tarreaua24adf02014-11-27 01:11:56 +0100145 int reserved_bufs; /* how many buffers can only be allocated for response */
Willy Tarreau33cb0652014-12-23 22:52:37 +0100146 int buf_limit; /* if not null, how many total buffers may only be allocated */
Willy Tarreaue803de22010-01-21 17:43:04 +0100147 int client_sndbuf; /* set client sndbuf to this value if not null */
148 int client_rcvbuf; /* set client rcvbuf to this value if not null */
149 int server_sndbuf; /* set server sndbuf to this value if not null */
150 int server_rcvbuf; /* set server rcvbuf to this value if not null */
Willy Tarreau43961d52010-10-04 20:39:20 +0200151 int chksize; /* check buffer size in bytes, defaults to BUFSIZE */
Willy Tarreaubd9a0a72011-10-23 21:14:29 +0200152 int pipesize; /* pipe size in bytes, system defaults if zero */
Willy Tarreauac1932d2011-10-24 19:14:41 +0200153 int max_http_hdr; /* max number of HTTP headers, use MAX_HTTP_HDR if zero */
Stéphane Cottin23e9e932017-05-18 08:58:41 +0200154 int requri_len; /* max len of request URI, use REQURI_LEN if zero */
Willy Tarreau193b8c62012-11-22 00:17:38 +0100155 int cookie_len; /* max length of cookie captures */
Willy Tarreauf3045d22015-04-29 16:24:50 +0200156 int pattern_cache; /* max number of entries in the pattern cache. */
Emeric Brunfc32aca2012-09-03 12:10:29 +0200157 int sslcachesize; /* SSL cache size in session, defaults to 20000 */
William Lallemandf3747832012-11-09 12:33:10 +0100158 int comp_maxlevel; /* max HTTP compression level */
Willy Tarreau7e312732014-02-12 16:35:14 +0100159 unsigned short idle_timer; /* how long before an empty buffer is considered idle (ms) */
Willy Tarreau1db37712007-06-03 17:16:49 +0200160 } tune;
Emeric Bruned760922010-10-22 17:59:25 +0200161 struct {
162 char *prefix; /* path prefix of unix bind socket */
163 struct { /* UNIX socket permissions */
164 uid_t uid; /* -1 to leave unchanged */
165 gid_t gid; /* -1 to leave unchanged */
166 mode_t mode; /* 0 to leave unchanged */
Emeric Bruned760922010-10-22 17:59:25 +0200167 } ux;
168 } unix_bind;
Willy Tarreauf4571a02018-01-20 18:12:15 +0100169 struct proxy *stats_fe; /* the frontend holding the stats settings */
170 struct vars vars; /* list of variables for the process scope. */
Willy Tarreaufc6c0322012-11-16 16:12:27 +0100171#ifdef USE_CPU_AFFINITY
Christopher Fauletcb6a9452017-11-22 16:50:41 +0100172 struct {
173 unsigned long proc[LONGBITS]; /* list of CPU masks for the 32/64 first processes */
Willy Tarreau421f02e2018-01-20 18:19:22 +0100174 unsigned long thread[LONGBITS][MAX_THREADS]; /* list of CPU masks for the 32/64 first threads per process */
Christopher Fauletcb6a9452017-11-22 16:50:41 +0100175 } cpu_map;
Willy Tarreaufc6c0322012-11-16 16:12:27 +0100176#endif
Willy Tarreaubaaee002006-06-26 02:48:02 +0200177};
178
Willy Tarreaud80cb4e2018-01-20 19:30:13 +0100179/* per-thread activity reports. It's important that it's aligned on cache lines
180 * because some elements will be updated very often. Most counters are OK on
181 * 32-bit since this will be used during debugging sessions for troubleshooting
182 * in iterative mode.
183 */
184struct activity {
185 unsigned int loops; // complete loops in run_poll_loop()
186 unsigned int wake_cache; // active fd_cache prevented poll() from sleeping
187 unsigned int wake_tasks; // active tasks prevented poll() from sleeping
Willy Tarreaud80cb4e2018-01-20 19:30:13 +0100188 unsigned int wake_signal; // pending signal prevented poll() from sleeping
189 unsigned int poll_exp; // number of times poll() sees an expired timeout (includes wake_*)
190 unsigned int poll_drop; // poller dropped a dead FD from the update list
191 unsigned int poll_dead; // poller woke up with a dead FD
192 unsigned int poll_skip; // poller skipped another thread's FD
193 unsigned int fd_skip; // fd cache skipped another thread's FD
194 unsigned int fd_lock; // fd cache skipped a locked FD
195 unsigned int fd_del; // fd cache detected a deleted FD
196 unsigned int conn_dead; // conn_fd_handler woke up on an FD indicating a dead connection
197 unsigned int stream; // calls to process_stream()
198 unsigned int empty_rq; // calls to process_runnable_tasks() with nothing for the thread
199 unsigned int long_rq; // process_runnable_tasks() left with tasks in the run queue
Willy Tarreaued72d822018-10-17 19:01:24 +0200200 unsigned int cpust_total; // sum of half-ms stolen per thread
201 struct freq_ctr cpust_1s; // avg amount of half-ms stolen over last second
202 struct freq_ctr_period cpust_15s; // avg amount of half-ms stolen over last 15s
Willy Tarreaud80cb4e2018-01-20 19:30:13 +0100203 char __pad[0]; // unused except to check remaining room
204 char __end[0] __attribute__((aligned(64))); // align size to 64.
205};
206
William Lallemand7e1299b2018-10-26 14:47:31 +0200207/*
208 * Structure used to describe the processes in master worker mode
209 */
210struct mworker_proc {
211 int pid;
William Lallemand16dd1b32018-11-19 18:46:18 +0100212 char type; /* m(aster), w(orker) */
213 /* 3 bytes hole here */
William Lallemand7e1299b2018-10-26 14:47:31 +0200214 int ipc_fd[2]; /* 0 is master side, 1 is worker side */
215 int relative_pid;
216 int reloads;
William Lallemande3683302018-11-19 18:46:17 +0100217 int timestamp;
William Lallemand291810d2018-10-26 14:47:38 +0200218 struct server *srv; /* the server entry in the master proxy */
William Lallemand7e1299b2018-10-26 14:47:31 +0200219 struct list list;
220};
221
Willy Tarreaubaaee002006-06-26 02:48:02 +0200222extern struct global global;
Willy Tarreaud80cb4e2018-01-20 19:30:13 +0100223extern struct activity activity[MAX_THREADS];
Willy Tarreaubaaee002006-06-26 02:48:02 +0200224extern int pid; /* current process id */
Willy Tarreaudcd47712007-11-04 23:35:08 +0100225extern int relative_pid; /* process id starting at 1 */
Willy Tarreau387bd4f2017-11-10 19:08:14 +0100226extern unsigned long pid_bit; /* bit corresponding to the process id */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200227extern int actconn; /* # of active sessions */
Willy Tarreauaf7ad002010-08-31 15:39:26 +0200228extern int listeners;
Willy Tarreau2cc5bae2017-09-15 08:18:11 +0200229extern int jobs; /* # of active jobs (listeners, sessions, open devices) */
William Lallemanda7199262018-11-16 16:57:20 +0100230extern int unstoppable_jobs; /* # of active jobs that can't be stopped during a soft stop */
Willy Tarreau199ad242018-11-05 16:31:22 +0100231extern int active_peers; /* # of active peers (connection attempts and successes) */
Willy Tarreau2d372c22018-11-05 17:12:27 +0100232extern int connected_peers; /* # of really connected peers */
Willy Tarreau83061a82018-07-13 11:56:34 +0200233extern THREAD_LOCAL struct buffer trash;
Willy Tarreaubb545b42010-08-25 12:58:59 +0200234extern int nb_oldpids; /* contains the number of old pids found */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200235extern const int zero;
236extern const int one;
Alexandre Cassen87ea5482007-10-11 20:48:58 +0200237extern const struct linger nolinger;
Willy Tarreaubaaee002006-06-26 02:48:02 +0200238extern int stopping; /* non zero means stopping in progress */
Cyril Bonté203ec5a2017-03-23 22:44:13 +0100239extern int killed; /* non zero means a hard-stop is triggered */
Willy Tarreau3ad6a762009-08-16 10:08:02 +0200240extern char hostname[MAX_HOSTNAME_LEN];
Emeric Brun2b920a12010-09-23 18:30:22 +0200241extern char localpeer[MAX_HOSTNAME_LEN];
Willy Tarreau08ceb102011-07-24 22:58:00 +0200242extern struct list global_listener_queue; /* list of the temporarily limited listeners */
Willy Tarreaue9b26022011-08-01 20:57:55 +0200243extern struct task *global_listener_queue_task;
Willy Tarreauff055502014-04-28 22:27:06 +0200244extern unsigned int warned; /* bitfield of a few warnings to emit just once */
Olivier Houchard79321b92018-07-26 17:55:11 +0200245extern volatile unsigned long sleeping_thread_mask;
William Lallemand6e0db2f2018-10-26 14:47:34 +0200246extern struct list proc_list; /* list of process in mworker mode */
William Lallemand16dd1b32018-11-19 18:46:18 +0100247extern struct mworker_proc *proc_self; /* process structure of current process */
Willy Tarreauff055502014-04-28 22:27:06 +0200248
249/* bit values to go with "warned" above */
Willy Tarreaude9d2d72014-04-28 22:28:02 +0200250#define WARN_BLOCK_DEPRECATED 0x00000001
Willy Tarreau98d04852015-05-26 12:18:29 +0200251/* unassigned : 0x00000002 */
Willy Tarreaua3c504c2014-04-28 22:37:32 +0200252#define WARN_REDISPATCH_DEPRECATED 0x00000004
Willy Tarreaued446492014-04-28 22:56:38 +0200253#define WARN_CLITO_DEPRECATED 0x00000008
254#define WARN_SRVTO_DEPRECATED 0x00000010
255#define WARN_CONTO_DEPRECATED 0x00000020
Willy Tarreauff055502014-04-28 22:27:06 +0200256
257/* to be used with warned and WARN_* */
258static inline int already_warned(unsigned int warning)
259{
260 if (warned & warning)
261 return 1;
262 warned |= warning;
263 return 0;
264}
Willy Tarreaubaaee002006-06-26 02:48:02 +0200265
Cyril Bonté203ec5a2017-03-23 22:44:13 +0100266void deinit(void);
Willy Tarreaucdb737e2016-12-21 18:43:10 +0100267void hap_register_build_opts(const char *str, int must_free);
Willy Tarreaue6945732016-12-21 19:57:00 +0100268void hap_register_post_check(int (*fct)());
Willy Tarreau05554e62016-12-21 20:46:26 +0100269void hap_register_post_deinit(void (*fct)());
Willy Tarreaucdb737e2016-12-21 18:43:10 +0100270
Christopher Faulet415f6112017-07-25 16:52:58 +0200271void hap_register_per_thread_init(int (*fct)());
272void hap_register_per_thread_deinit(void (*fct)());
273
Willy Tarreaubaaee002006-06-26 02:48:02 +0200274#endif /* _TYPES_GLOBAL_H */
275
276/*
277 * Local variables:
278 * c-indent-level: 8
279 * c-basic-offset: 8
280 * End:
281 */