Files
MaxScale/maxscale-system-test/clustrix_nodes.h
Johan Wikman a8487a945a MXS-2481 When Clustrix [un]block health port as well
In the case of Clustrix, it is not sufficient to block the MariaDB
port alone, but the health-check port must be blocked as well.
2019-05-28 12:36:21 +03:00

61 lines
1.6 KiB
C++

/**
* @file clustrix_nodes.h - work with Clustrix setup
*
* ~/.config/mdbci/clustrix_license file have to contain SQL
* which setups license to the Clustrix node
*
* TODO: move functionality of install_clustrix() to MDBCI
*/
#pragma once
#include <errno.h>
#include <string>
#include "nodes.h"
#include "mariadb_nodes.h"
#define CLUSTRIX_DEPS_YUM "yum install -y bzip2 wget screen ntp ntpdate vim htop mdadm"
#define WGET_CLUSTRIX "wget http://files.clustrix.com/releases/software/clustrix-9.1.4.el7.tar.bz2"
#define UNPACK_CLUSTRIX "tar xvjf clustrix-9.1.4.el7.tar.bz2"
#define INSTALL_CLUSTRIX "cd clustrix-9.1.4.el7; sudo ./clxnode_install.py --yes --force"
class Clustrix_nodes : public Mariadb_nodes
{
public:
Clustrix_nodes(const char* pref, const char* test_cwd, bool verbose, std::string network_config)
: Mariadb_nodes(pref, test_cwd, verbose, network_config)
{
}
/**
* @brief start_cluster Intstalls Clustrix on all nodes, configure license, form cluster
* @return 0 in case of success
*/
int start_replication();
/**
* @brief cnf_servers Generate Clustrix servers description for maxscale.cnf
* @return text for maxscale.cnf
*/
std::string cnf_servers();
/**
* @brief check_replication Checks if Clustrix Cluster is up and running
* @return 0 if Clustrix Cluster is ok
*/
int check_replication();
/**
* @brief install_clustrix
* @param m node index
* @return 0 in case of success
*/
int prepare_server(int i);
std::string block_command(int node) const override;
std::string unblock_command(int node) const override;
};