MDEV-22570 Implement wsrep_provider_options as plugin

- Provider options are read from the provider during
  startup, before plugins are initialized.
- New wsrep_provider plugin for which sysvars are generated
  dynamically from options read from the provider.
- The plugin is enabled by option plugin-wsrep-provider=ON.
  If enabled, wsrep_provider_options can no longer be used,
  (an error is raised on attempts to do so).
- Each option is either string, integer, double or bool
- Options can be dynamic / readonly
- Options can be deprecated

Limitations:

- We do not check that the value of a provider option falls
  within a certain range. This type of validation is still
  done in Galera side.

Reviewed-by: Jan Lindström <jan.lindstrom@mariadb.com>
This commit is contained in:
Daniele Sciascia 2021-02-09 20:06:59 +02:00 committed by Sergei Golubchik
commit 79d0194eef
15 changed files with 1860 additions and 12 deletions

View file

@ -1,4 +1,4 @@
/* Copyright 2018 Codership Oy <info@codership.com>
/* Copyright 2018-2021 Codership Oy <info@codership.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@ -19,6 +19,7 @@
/* wsrep-lib */
#include "wsrep/server_state.hpp"
#include "wsrep/provider.hpp"
#include "wsrep/provider_options.hpp"
/* implementation */
#include "wsrep_server_service.h"
@ -34,6 +35,10 @@ public:
const std::string& working_dir,
const wsrep::gtid& initial_position,
int max_protocol_version);
static int init_provider(const std::string& provider,
const std::string& options);
static int init_options();
static void deinit_provider();
static void destroy();
static Wsrep_server_state& instance()
@ -51,6 +56,11 @@ public:
return instance().provider();
}
static wsrep::provider_options* get_options()
{
return m_options.get();
}
static bool has_capability(int capability)
{
return (get_provider().capabilities() & capability);
@ -77,7 +87,11 @@ private:
Wsrep_server_service m_service;
static wsrep::provider::services m_provider_services;
static Wsrep_server_state* m_instance;
static std::unique_ptr<wsrep::provider_options> m_options;
// Sysvars for provider plugin. We keep these here because
// they are allocated dynamically and must be freed at some
// point during shutdown (after the plugin is deinitialized).
static std::vector<st_mysql_sys_var *> m_sysvars;
};
#endif // WSREP_SERVER_STATE_H