228 lines
6.0 KiB
C++
228 lines
6.0 KiB
C++
#pragma once
|
|
|
|
#include <errno.h>
|
|
#include <string>
|
|
#include <set>
|
|
#include <string>
|
|
|
|
#include <maxbase/ccdefs.hh>
|
|
#include <maxtest/mariadb_func.hh>
|
|
|
|
typedef std::set<std::string> StringSet;
|
|
|
|
|
|
class Nodes
|
|
{
|
|
public:
|
|
/**
|
|
* Sets up the nodes. *Must* be called before instance is used.
|
|
*
|
|
* @return True, if the instance could be setup, false otherwise.
|
|
*/
|
|
virtual bool setup() = 0;
|
|
|
|
char * IP[256];
|
|
/**
|
|
* @brief private IP address strings for every backend node (for AWS)
|
|
*/
|
|
|
|
char * IP_private[256];
|
|
/**
|
|
* @brief IP address strings for every backend node (IPv6)
|
|
*/
|
|
char * IP6[256];
|
|
|
|
/**
|
|
* @brief use_ipv6 If true IPv6 addresses will be used to connect Maxscale and backed
|
|
* Also IPv6 addresses go to maxscale.cnf
|
|
*/
|
|
bool use_ipv6 = false;
|
|
|
|
/**
|
|
* @brief Path to ssh key for every backend node
|
|
*/
|
|
char * sshkey[256];
|
|
|
|
/**
|
|
* @brief Number of backend nodes
|
|
*/
|
|
int N;
|
|
|
|
/**
|
|
* @brief name of backend setup (like 'repl' or 'galera')
|
|
*/
|
|
char prefix[16];
|
|
|
|
/**
|
|
* @brief access_user Unix users name to access nodes via ssh
|
|
*/
|
|
char * access_user[256];
|
|
|
|
/**
|
|
* @brief access_sudo empty if sudo is not needed or "sudo " if sudo is needed.
|
|
*/
|
|
char * access_sudo[256];
|
|
|
|
/**
|
|
* @brief access_homedir home directory of access_user
|
|
*/
|
|
char * access_homedir[256];
|
|
|
|
char * hostname[256];
|
|
|
|
/**
|
|
* @brief stop_vm_command Command to suspend VM
|
|
*/
|
|
char * stop_vm_command[256];
|
|
/**
|
|
*
|
|
* @brief start_vm_command Command to resume VM
|
|
*/
|
|
char * start_vm_command[256];
|
|
|
|
/**
|
|
* @brief User name to access backend nodes
|
|
*/
|
|
char * user_name;
|
|
/**
|
|
* @brief Password to access backend nodes
|
|
*/
|
|
char * password;
|
|
|
|
/**
|
|
* @brief network_config Content of MDBCI network_config file
|
|
*/
|
|
std::string network_config;
|
|
|
|
/**
|
|
* @brief Verbose command output
|
|
*/
|
|
bool verbose;
|
|
|
|
/**
|
|
* @brief Get IP address
|
|
*
|
|
* @return The current IP address
|
|
*/
|
|
const char* ip(int i = 0) const;
|
|
|
|
/**
|
|
* @brief mdbci_node_name
|
|
* @param node
|
|
* @return name of the node in MDBCI format
|
|
*/
|
|
std::string mdbci_node_name(int node);
|
|
|
|
/**
|
|
* @brief Generate command line to execute command on the node via ssh
|
|
* @param cmd result
|
|
* @param node number of the node (index)
|
|
* @param ssh command to execute
|
|
* @param sudo if true the command is executed with root privelegues
|
|
*/
|
|
void generate_ssh_cmd(char* cmd, int node, const char* ssh, bool sudo);
|
|
|
|
/**
|
|
* @brief executes shell command on the node using ssh
|
|
* @param node number of the node (index)
|
|
* @param ssh command to execute
|
|
* @param sudo if true the command is executed with root privelegues
|
|
* @param pointer to variable to store process exit code
|
|
* @return output of the command
|
|
*/
|
|
char* ssh_node_output_f(int node,
|
|
bool sudo,
|
|
int* exit_code,
|
|
const char* format,
|
|
...) mxb_attribute((format(printf, 5, 6)));
|
|
char* ssh_node_output(int node, const char* ssh, bool sudo, int* exit_code);
|
|
|
|
// Simplified C++ version
|
|
std::pair<int, std::string> ssh_output(std::string ssh, int node = 0, bool sudo = true)
|
|
{
|
|
int rc;
|
|
char* out = ssh_node_output(node, ssh.c_str(), sudo, &rc);
|
|
std::string rval(out);
|
|
free(out);
|
|
return {rc, rval};
|
|
}
|
|
|
|
/**
|
|
* @brief executes shell command on the node using ssh
|
|
* @param index number of the node (index)
|
|
* @param ssh command to execute
|
|
* @param sudo if true the command is executed with root privelegues
|
|
* @return exit code of the coomand
|
|
*/
|
|
int ssh_node(int node, const char* ssh, bool sudo);
|
|
int ssh_node_f(int node, bool sudo, const char* format, ...) mxb_attribute((format(printf, 4, 5)));
|
|
|
|
/**
|
|
* @brief Copy a local file to the Node i machine
|
|
* @param src Source file on the local filesystem
|
|
* @param dest Destination file on the remote file system
|
|
* @param i Node index
|
|
* @return exit code of the system command or 1 in case of i > N
|
|
*/
|
|
int copy_to_node_legacy(const char* src, const char* dest, int i = 0);
|
|
int copy_to_node(int i, const char* src, const char* dest);
|
|
|
|
/**
|
|
* @brief Copy a local file to the Node i machine
|
|
* @param src Source file on the remote filesystem
|
|
* @param dest Destination file on the local file system
|
|
* @param i Node index
|
|
* @return exit code of the system command or 1 in case of i > N
|
|
*/
|
|
int copy_from_node_legacy(const char* src, const char* dest, int i);
|
|
int copy_from_node(int i, const char* src, const char* dest);
|
|
|
|
/**
|
|
* @brief Check node via ssh and restart it if it is not resposible
|
|
* @param node Node index
|
|
* @return True if node is ok, false if start failed
|
|
*/
|
|
bool check_nodes();
|
|
|
|
/**
|
|
* @brief read_basic_env Read IP, sshkey, etc - common parameters for all kinds of nodes
|
|
* @return 0 in case of success
|
|
*/
|
|
int read_basic_env();
|
|
|
|
/**
|
|
* @brief get_nc_item Find variable in the MDBCI network_config file
|
|
* @param item_name Name of the variable
|
|
* @return value of variable or empty value if not found
|
|
*/
|
|
std::string get_nc_item(const char* item_name);
|
|
|
|
/**
|
|
* @brief get_N Calculate the number of nodes discribed in the _netoek_config file
|
|
* @return Number of nodes
|
|
*/
|
|
int get_N();
|
|
|
|
/**
|
|
* @brief start_vm Start virtual machine
|
|
* @param node Node number
|
|
* @return 0 in case of success
|
|
*/
|
|
int start_vm(int node);
|
|
|
|
/**
|
|
* @brief stop_vm Stop virtual machine
|
|
* @param node Node number
|
|
* @return 0 in case of success
|
|
*/
|
|
int stop_vm(int node);
|
|
|
|
protected:
|
|
Nodes(const char* pref,
|
|
const std::string& network_config,
|
|
bool verbose);
|
|
|
|
private:
|
|
bool check_node_ssh(int node);
|
|
};
|