2018-08-28 14:43:46 +00:00
|
|
|
#ifndef ODYSSEY_SERVER_H
|
|
|
|
#define ODYSSEY_SERVER_H
|
2017-05-25 12:00:58 +00:00
|
|
|
|
|
|
|
/*
|
2018-03-12 14:03:15 +00:00
|
|
|
* Odyssey.
|
2017-05-25 12:00:58 +00:00
|
|
|
*
|
2018-04-04 13:19:58 +00:00
|
|
|
* Scalable PostgreSQL connection pooler.
|
2020-04-02 11:00:56 +00:00
|
|
|
*/
|
2017-05-25 12:00:58 +00:00
|
|
|
|
2018-08-02 13:38:36 +00:00
|
|
|
typedef struct od_server od_server_t;
|
2017-05-25 12:00:58 +00:00
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
typedef enum {
|
2018-08-28 14:43:46 +00:00
|
|
|
OD_SERVER_UNDEF,
|
|
|
|
OD_SERVER_IDLE,
|
2021-02-18 09:36:49 +00:00
|
|
|
OD_SERVER_ACTIVE,
|
2018-08-28 14:43:46 +00:00
|
|
|
} od_server_state_t;
|
2017-05-25 12:00:58 +00:00
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
struct od_server {
|
2020-04-02 11:00:56 +00:00
|
|
|
od_server_state_t state;
|
2020-11-27 18:03:42 +00:00
|
|
|
#ifdef USE_SCRAM
|
2020-04-02 11:00:56 +00:00
|
|
|
od_scram_state_t scram_state;
|
2020-11-27 18:03:42 +00:00
|
|
|
#endif
|
2020-04-02 11:00:56 +00:00
|
|
|
od_id_t id;
|
|
|
|
machine_tls_t *tls;
|
|
|
|
od_io_t io;
|
|
|
|
od_relay_t relay;
|
|
|
|
int is_allocated;
|
|
|
|
int is_transaction;
|
|
|
|
int is_copy;
|
|
|
|
int deploy_sync;
|
|
|
|
od_stat_state_t stats_state;
|
|
|
|
uint64_t sync_request;
|
|
|
|
uint64_t sync_reply;
|
|
|
|
int idle_time;
|
|
|
|
kiwi_key_t key;
|
|
|
|
kiwi_key_t key_client;
|
|
|
|
kiwi_vars_t vars;
|
|
|
|
machine_msg_t *error_connect;
|
|
|
|
void *client;
|
|
|
|
void *route;
|
|
|
|
od_global_t *global;
|
2021-02-18 09:36:49 +00:00
|
|
|
int offline;
|
2020-04-02 11:00:56 +00:00
|
|
|
uint64_t init_time_us;
|
|
|
|
od_list_t link;
|
2021-03-17 14:16:46 +00:00
|
|
|
bool synced_settings;
|
2017-05-25 12:00:58 +00:00
|
|
|
};
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline void od_server_init(od_server_t *server)
|
2017-05-25 12:00:58 +00:00
|
|
|
{
|
2020-12-28 10:43:31 +00:00
|
|
|
server->state = OD_SERVER_UNDEF;
|
|
|
|
server->route = NULL;
|
|
|
|
server->client = NULL;
|
|
|
|
server->global = NULL;
|
|
|
|
server->tls = NULL;
|
|
|
|
server->idle_time = 0;
|
|
|
|
server->is_allocated = 0;
|
2017-05-25 12:00:58 +00:00
|
|
|
server->is_transaction = 0;
|
2020-12-28 10:43:31 +00:00
|
|
|
server->is_copy = 0;
|
|
|
|
server->deploy_sync = 0;
|
|
|
|
server->sync_request = 0;
|
|
|
|
server->sync_reply = 0;
|
|
|
|
server->init_time_us = machine_time_us();
|
|
|
|
server->error_connect = NULL;
|
2021-02-18 09:36:49 +00:00
|
|
|
server->offline = 0;
|
2021-03-17 14:33:21 +00:00
|
|
|
server->synced_settings = false;
|
2018-08-09 14:39:36 +00:00
|
|
|
od_stat_state_init(&server->stats_state);
|
2021-02-18 09:36:49 +00:00
|
|
|
|
2020-11-27 18:03:42 +00:00
|
|
|
#ifdef USE_SCRAM
|
2019-11-11 09:28:50 +00:00
|
|
|
od_scram_state_init(&server->scram_state);
|
2020-11-27 18:03:42 +00:00
|
|
|
#endif
|
|
|
|
|
2018-08-28 14:43:46 +00:00
|
|
|
kiwi_key_init(&server->key);
|
|
|
|
kiwi_key_init(&server->key_client);
|
2018-12-12 13:07:25 +00:00
|
|
|
kiwi_vars_init(&server->vars);
|
2019-01-23 15:43:52 +00:00
|
|
|
od_io_init(&server->io);
|
|
|
|
od_relay_init(&server->relay, &server->io);
|
2017-05-25 12:00:58 +00:00
|
|
|
od_list_init(&server->link);
|
2017-06-20 15:39:52 +00:00
|
|
|
memset(&server->id, 0, sizeof(server->id));
|
2017-05-25 12:00:58 +00:00
|
|
|
}
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline od_server_t *od_server_allocate(void)
|
2017-05-25 12:00:58 +00:00
|
|
|
{
|
|
|
|
od_server_t *server = malloc(sizeof(*server));
|
|
|
|
if (server == NULL)
|
|
|
|
return NULL;
|
|
|
|
od_server_init(server);
|
2017-06-02 13:49:20 +00:00
|
|
|
server->is_allocated = 1;
|
2017-05-25 12:00:58 +00:00
|
|
|
return server;
|
|
|
|
}
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline void od_server_free(od_server_t *server)
|
2017-05-25 12:00:58 +00:00
|
|
|
{
|
2020-11-23 08:10:00 +00:00
|
|
|
if (server->is_allocated) {
|
|
|
|
od_relay_free(&server->relay);
|
|
|
|
od_io_free(&server->io);
|
2017-06-02 13:49:20 +00:00
|
|
|
free(server);
|
2020-11-23 08:10:00 +00:00
|
|
|
}
|
2017-05-25 12:00:58 +00:00
|
|
|
}
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline void od_server_sync_request(od_server_t *server, uint64_t count)
|
2018-08-08 13:58:39 +00:00
|
|
|
{
|
|
|
|
server->sync_request += count;
|
|
|
|
}
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline void od_server_sync_reply(od_server_t *server)
|
2018-08-08 13:58:39 +00:00
|
|
|
{
|
2020-04-02 11:00:56 +00:00
|
|
|
server->sync_reply++;
|
2018-08-08 13:58:39 +00:00
|
|
|
}
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline int od_server_in_deploy(od_server_t *server)
|
2019-01-23 15:43:52 +00:00
|
|
|
{
|
|
|
|
return server->deploy_sync > 0;
|
|
|
|
}
|
|
|
|
|
2020-12-28 10:43:31 +00:00
|
|
|
static inline int od_server_synchronized(od_server_t *server)
|
2017-09-12 13:23:59 +00:00
|
|
|
{
|
2018-08-08 13:58:39 +00:00
|
|
|
return server->sync_request == server->sync_reply;
|
2017-09-12 13:23:59 +00:00
|
|
|
}
|
|
|
|
|
2021-02-18 09:36:49 +00:00
|
|
|
static inline int od_server_grac_shutdown(od_server_t *server)
|
|
|
|
{
|
|
|
|
server->offline = 1;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-08-28 14:43:46 +00:00
|
|
|
#endif /* ODYSSEY_SERVER_H */
|