2010-09-23 12:30:22 -04:00
|
|
|
/*
|
|
|
|
|
* include/types/peers.h
|
|
|
|
|
* This file defines everything related to peers.
|
|
|
|
|
*
|
|
|
|
|
* Copyright 2010 EXCELIANCE, Emeric Brun <ebrun@exceliance.fr>
|
|
|
|
|
*
|
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
|
* License as published by the Free Software Foundation, version 2.1
|
|
|
|
|
* exclusively.
|
|
|
|
|
*
|
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef _TYPES_PEERS_H
|
|
|
|
|
#define _TYPES_PEERS_H
|
|
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
#include <sys/socket.h>
|
|
|
|
|
#include <netinet/in.h>
|
|
|
|
|
#include <arpa/inet.h>
|
|
|
|
|
|
|
|
|
|
#include <common/config.h>
|
|
|
|
|
#include <common/mini-clist.h>
|
|
|
|
|
#include <common/regex.h>
|
|
|
|
|
#include <common/tools.h>
|
|
|
|
|
#include <eb32tree.h>
|
|
|
|
|
|
|
|
|
|
struct shared_table {
|
|
|
|
|
struct stktable *table; /* stick table to sync */
|
2015-05-12 12:49:09 -04:00
|
|
|
int local_id;
|
|
|
|
|
int remote_id;
|
|
|
|
|
int flags;
|
|
|
|
|
uint64_t remote_data;
|
|
|
|
|
unsigned int last_acked;
|
|
|
|
|
unsigned int last_pushed;
|
|
|
|
|
unsigned int last_get;
|
|
|
|
|
unsigned int teaching_origin;
|
|
|
|
|
unsigned int update;
|
2010-09-23 12:30:22 -04:00
|
|
|
struct shared_table *next; /* next shared table in list */
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct peer {
|
|
|
|
|
int local; /* proxy state */
|
|
|
|
|
char *id;
|
|
|
|
|
struct {
|
|
|
|
|
const char *file; /* file where the section appears */
|
|
|
|
|
int line; /* line where the section appears */
|
|
|
|
|
} conf; /* config information */
|
|
|
|
|
time_t last_change;
|
2011-03-10 16:26:24 -05:00
|
|
|
struct sockaddr_storage addr; /* peer address */
|
2012-05-07 12:12:14 -04:00
|
|
|
struct protocol *proto; /* peer address protocol */
|
REORG: connection: rename the data layer the "transport layer"
While working on the changes required to make the health checks use the
new connections, it started to become obvious that some naming was not
logical at all in the connections. Specifically, it is not logical to
call the "data layer" the layer which is in charge for all the handshake
and which does not yet provide a data layer once established until a
session has allocated all the required buffers.
In fact, it's more a transport layer, which makes much more sense. The
transport layer offers a medium on which data can transit, and it offers
the functions to move these data when the upper layer requests this. And
it is the upper layer which iterates over the transport layer's functions
to move data which should be called the data layer.
The use case where it's obvious is with embryonic sessions : an incoming
SSL connection is accepted. Only the connection is allocated, not the
buffers nor stream interface, etc... The connection handles the SSL
handshake by itself. Once this handshake is complete, we can't use the
data functions because the buffers and stream interface are not there
yet. Hence we have to first call a specific function to complete the
session initialization, after which we'll be able to use the data
functions. This clearly proves that SSL here is only a transport layer
and that the stream interface constitutes the data layer.
A similar change will be performed to rename app_cb => data, but the
two could not be in the same commit for obvious reasons.
2012-10-02 18:19:48 -04:00
|
|
|
struct xprt_ops *xprt; /* peer socket operations at transport layer */
|
2012-05-11 12:32:18 -04:00
|
|
|
void *sock_init_arg; /* socket operations's opaque init argument if needed */
|
2015-05-12 12:49:09 -04:00
|
|
|
unsigned int flags; /* peer session flags */
|
|
|
|
|
unsigned int statuscode; /* current/last session status code */
|
|
|
|
|
unsigned int reconnect; /* next connect timer */
|
2019-02-11 11:49:39 -05:00
|
|
|
unsigned int heartbeat; /* next heartbeat timer */
|
2015-05-12 12:49:09 -04:00
|
|
|
unsigned int confirm; /* confirm message counter */
|
|
|
|
|
struct appctx *appctx; /* the appctx running it */
|
|
|
|
|
struct shared_table *remote_table;
|
|
|
|
|
struct shared_table *last_local_table;
|
|
|
|
|
struct shared_table *tables;
|
2018-04-26 08:35:21 -04:00
|
|
|
struct server *srv;
|
2017-11-13 04:34:01 -05:00
|
|
|
__decl_hathreads(HA_SPINLOCK_T lock); /* lock used to handle this peer section */
|
2010-09-23 12:30:22 -04:00
|
|
|
struct peer *next; /* next peer in the list */
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
struct peers {
|
|
|
|
|
int state; /* proxy state */
|
|
|
|
|
char *id; /* peer section name */
|
2015-05-12 12:49:09 -04:00
|
|
|
struct task *sync_task; /* main sync task */
|
|
|
|
|
struct sig_handler *sighandler; /* signal handler */
|
2010-09-23 12:30:22 -04:00
|
|
|
struct peer *remote; /* remote peers list */
|
2015-05-12 12:49:09 -04:00
|
|
|
struct peer *local; /* local peer list */
|
2010-09-23 12:30:22 -04:00
|
|
|
struct proxy *peers_fe; /* peer frontend */
|
|
|
|
|
struct {
|
|
|
|
|
const char *file; /* file where the section appears */
|
|
|
|
|
int line; /* line where the section appears */
|
|
|
|
|
} conf; /* config information */
|
|
|
|
|
time_t last_change;
|
|
|
|
|
struct peers *next; /* next peer section */
|
2015-05-12 12:49:09 -04:00
|
|
|
unsigned int flags; /* current peers section resync state */
|
|
|
|
|
unsigned int resync_timeout; /* resync timeout timer */
|
2010-09-23 12:30:22 -04:00
|
|
|
int count; /* total of peers */
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2017-07-13 03:07:09 -04:00
|
|
|
extern struct peers *cfg_peers;
|
2010-09-23 12:30:22 -04:00
|
|
|
|
|
|
|
|
#endif /* _TYPES_PEERS_H */
|
|
|
|
|
|