mirror of
https://github.com/haproxy/haproxy.git
synced 2026-03-01 04:40:54 -05:00
Make usage of the APIs implemented for dictionaries (dict.c) and their LRU caches (struct dcache) so that to send/receive server names used for the server by name stickiness. These names are sent over the network as follows: - in every case we send the encode length of the data (STD_T_DICT), then - if the server names is not present in the cache used upon transmission (struct dcache_tx) we cache it and we the ID of this TX cache entry followed the encode length of the server name, and finally the sever name itseft (non NULL terminated string). - if the server name is present, we repead these operations but we only send the TX cache entry ID. Upon receipt, the couple of (cache IDs, server name) are stored the LRU cache used only upon receipt (struct dcache_rx). As the peers protocol is symetrical, the fact that the server name is present in the received data (resp. or not) denotes if the entry is absent (resp. or not).
134 lines
4.3 KiB
C
134 lines
4.3 KiB
C
/*
|
|
* 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>
|
|
|
|
#include <types/dict.h>
|
|
|
|
struct shared_table {
|
|
struct stktable *table; /* stick table to sync */
|
|
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;
|
|
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;
|
|
struct sockaddr_storage addr; /* peer address */
|
|
struct protocol *proto; /* peer address protocol */
|
|
struct xprt_ops *xprt; /* peer socket operations at transport layer */
|
|
void *sock_init_arg; /* socket operations's opaque init argument if needed */
|
|
unsigned int flags; /* peer session flags */
|
|
unsigned int statuscode; /* current/last session status code */
|
|
unsigned int reconnect; /* next connect timer */
|
|
unsigned int heartbeat; /* next heartbeat timer */
|
|
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;
|
|
struct server *srv;
|
|
struct dcache *dcache; /* dictionary cache */
|
|
__decl_hathreads(HA_SPINLOCK_T lock); /* lock used to handle this peer section */
|
|
struct peer *next; /* next peer in the list */
|
|
};
|
|
|
|
|
|
struct peers {
|
|
int state; /* proxy state */
|
|
char *id; /* peer section name */
|
|
struct task *sync_task; /* main sync task */
|
|
struct sig_handler *sighandler; /* signal handler */
|
|
struct peer *remote; /* remote peers list */
|
|
struct peer *local; /* local peer list */
|
|
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 */
|
|
unsigned int flags; /* current peers section resync state */
|
|
unsigned int resync_timeout; /* resync timeout timer */
|
|
int count; /* total of peers */
|
|
};
|
|
|
|
/* LRU cache for dictionaies */
|
|
struct dcache_tx {
|
|
/* The last recently used key */
|
|
unsigned int lru_key;
|
|
/* The maximum number of entries in this cache */
|
|
size_t max_entries;
|
|
/* ebtree for keys (eb32_nodes from 0 included up to <max_entries> excluded) */
|
|
struct eb_root keys;
|
|
/* ebtree for values (ebpt_node, pointers to dict struct entries) */
|
|
struct eb_root values;
|
|
};
|
|
|
|
struct dcache_rx {
|
|
unsigned int id;
|
|
struct dict_entry *de;
|
|
};
|
|
|
|
struct dcache_tx_entry {
|
|
struct eb32_node key;
|
|
struct ebpt_node value;
|
|
};
|
|
|
|
/* stick-table data type cache */
|
|
struct dcache {
|
|
/* Cache used upon transmission */
|
|
struct dcache_tx *tx;
|
|
/* Cache used upon receipt */
|
|
struct dcache_rx *rx;
|
|
/* Maximum number of entries in this cache */
|
|
size_t max_entries;
|
|
};
|
|
|
|
extern struct peers *cfg_peers;
|
|
|
|
#endif /* _TYPES_PEERS_H */
|
|
|