Merge branch '2.2' into develop
This commit is contained in:
@ -1773,7 +1773,7 @@ void mon_process_state_changes(MXS_MONITOR *monitor, const char *script, uint64_
|
||||
master_up = true;
|
||||
}
|
||||
|
||||
if (script && *script && (events & event))
|
||||
if (script && (events & event))
|
||||
{
|
||||
monitor_launch_script(monitor, ptr, script, monitor->script_timeout);
|
||||
}
|
||||
|
@ -629,6 +629,25 @@ static bool check_server_permissions(SERVICE *service, SERVER* server,
|
||||
}
|
||||
}
|
||||
|
||||
// Check whether the current user has the SHOW DATABASES privilege
|
||||
if (mxs_mysql_query(mysql, "SELECT show_db_priv FROM mysql.user "
|
||||
"WHERE CONCAT(user, '@', host) = CURRENT_USER()") == 0)
|
||||
{
|
||||
MYSQL_RES* res = mysql_use_result(mysql);
|
||||
if (res)
|
||||
{
|
||||
MYSQL_ROW row = mysql_fetch_row(res);
|
||||
|
||||
if (row && strcasecmp(row[0], "Y") != 0)
|
||||
{
|
||||
MXS_WARNING("[%s] User '%s' is missing the SHOW DATABASES privilege.",
|
||||
service->name, user);
|
||||
}
|
||||
|
||||
mysql_free_result(res);
|
||||
}
|
||||
}
|
||||
|
||||
mysql_close(mysql);
|
||||
|
||||
return rval;
|
||||
|
@ -35,7 +35,7 @@ USTR [%-_[:alnum:][:punct:]]+
|
||||
CMP [=<>!]+
|
||||
|
||||
%%
|
||||
"\n"+ return '\n';
|
||||
{SPACE}"\n"+ return '\n';
|
||||
{COMMENT} return FWTOK_COMMENT;
|
||||
deny|allow MXS_WARNING("Use of '%s' is deprecated, use 'match' instead", yytext);return FWTOK_MATCH;
|
||||
rule return FWTOK_RULE;
|
||||
|
@ -17,7 +17,7 @@
|
||||
|
||||
#define MXS_MODULE_NAME "mariadbmon"
|
||||
|
||||
#include "mariadbmon.hh"
|
||||
#include "../mysqlmon.h"
|
||||
#include <inttypes.h>
|
||||
#include <limits>
|
||||
#include <string>
|
||||
@ -31,7 +31,6 @@
|
||||
#include <maxscale/modulecmd.h>
|
||||
#include <maxscale/modutil.h>
|
||||
#include <maxscale/mysql_utils.h>
|
||||
#include <maxscale/secrets.h>
|
||||
#include <maxscale/utils.h>
|
||||
// TODO: For monitorAddParameters
|
||||
#include "../../../core/internal/monitor.h"
|
||||
@ -990,10 +989,8 @@ static bool set_replication_credentials(MYSQL_MONITOR *handle, const MXS_CONFIG_
|
||||
|
||||
if (*repl_user && *repl_pw)
|
||||
{
|
||||
handle->replication_user = repl_user;
|
||||
char* decrypted = decrypt_password(repl_pw);
|
||||
handle->replication_password = decrypted;
|
||||
MXS_FREE(decrypted);
|
||||
handle->replication_user = MXS_STRDUP_A(repl_user);
|
||||
handle->replication_password = decrypt_password(repl_pw);
|
||||
rval = true;
|
||||
}
|
||||
|
||||
@ -1036,22 +1033,22 @@ startMonitor(MXS_MONITOR *monitor, const MXS_CONFIG_PARAMETER* params)
|
||||
if (handle)
|
||||
{
|
||||
handle->shutdown = 0;
|
||||
handle->script.clear();
|
||||
handle->replication_user.clear();
|
||||
handle->replication_password.clear();
|
||||
MXS_FREE(handle->script);
|
||||
MXS_FREE(handle->replication_user);
|
||||
MXS_FREE(handle->replication_password);
|
||||
MXS_FREE(handle->excluded_servers);
|
||||
handle->excluded_servers = NULL;
|
||||
handle->n_excluded = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
handle = new MYSQL_MONITOR;
|
||||
handle = (MYSQL_MONITOR *) MXS_MALLOC(sizeof(MYSQL_MONITOR));
|
||||
HASHTABLE *server_info = hashtable_alloc(MAX_NUM_SLAVES,
|
||||
hashtable_item_strhash, hashtable_item_strcmp);
|
||||
|
||||
if (server_info == NULL)
|
||||
if (handle == NULL || server_info == NULL)
|
||||
{
|
||||
delete handle;
|
||||
MXS_FREE(handle);
|
||||
hashtable_free(server_info);
|
||||
return NULL;
|
||||
}
|
||||
@ -1063,6 +1060,7 @@ startMonitor(MXS_MONITOR *monitor, const MXS_CONFIG_PARAMETER* params)
|
||||
handle->id = config_get_global_options()->id;
|
||||
handle->warn_set_standalone_master = true;
|
||||
handle->master_gtid_domain = -1;
|
||||
handle->external_master_host[0] = '\0';
|
||||
handle->external_master_port = PORT_UNKNOWN;
|
||||
handle->monitor = monitor;
|
||||
}
|
||||
@ -1079,14 +1077,15 @@ startMonitor(MXS_MONITOR *monitor, const MXS_CONFIG_PARAMETER* params)
|
||||
handle->failcount = config_get_integer(params, CN_FAILCOUNT);
|
||||
handle->allow_cluster_recovery = config_get_bool(params, "allow_cluster_recovery");
|
||||
handle->mysql51_replication = config_get_bool(params, "mysql51_replication");
|
||||
handle->script = config_get_string(params, "script");
|
||||
handle->script = config_copy_string(params, "script");
|
||||
handle->events = config_get_enum(params, "events", mxs_monitor_event_enum_values);
|
||||
handle->auto_failover = config_get_bool(params, CN_AUTO_FAILOVER);
|
||||
handle->failover_timeout = config_get_integer(params, CN_FAILOVER_TIMEOUT);
|
||||
handle->switchover_timeout = config_get_integer(params, CN_SWITCHOVER_TIMEOUT);
|
||||
handle->auto_failover = config_get_bool(params, CN_AUTO_FAILOVER);
|
||||
handle->auto_rejoin = config_get_bool(params, CN_AUTO_REJOIN);
|
||||
handle->verify_master_failure = config_get_bool(params, CN_VERIFY_MASTER_FAILURE);
|
||||
handle->master_failure_timeout = config_get_integer(params, CN_MASTER_FAILURE_TIMEOUT);
|
||||
handle->auto_rejoin = config_get_bool(params, CN_AUTO_REJOIN);
|
||||
|
||||
handle->excluded_servers = NULL;
|
||||
handle->n_excluded = mon_config_get_servers(params, CN_NO_PROMOTE_SERVERS, monitor,
|
||||
&handle->excluded_servers);
|
||||
@ -1115,8 +1114,9 @@ startMonitor(MXS_MONITOR *monitor, const MXS_CONFIG_PARAMETER* params)
|
||||
if (error)
|
||||
{
|
||||
hashtable_free(handle->server_info);
|
||||
MXS_FREE(handle->script);
|
||||
MXS_FREE(handle->excluded_servers);
|
||||
delete handle;
|
||||
MXS_FREE(handle);
|
||||
handle = NULL;
|
||||
}
|
||||
else
|
||||
@ -1127,7 +1127,8 @@ startMonitor(MXS_MONITOR *monitor, const MXS_CONFIG_PARAMETER* params)
|
||||
{
|
||||
MXS_ERROR("Failed to start monitor thread for monitor '%s'.", monitor->name);
|
||||
hashtable_free(handle->server_info);
|
||||
delete handle;
|
||||
MXS_FREE(handle->script);
|
||||
MXS_FREE(handle);
|
||||
handle = NULL;
|
||||
}
|
||||
}
|
||||
@ -1206,7 +1207,8 @@ static void diagnostics(DCB *dcb, const MXS_MONITOR *mon)
|
||||
dcb_printf(dcb, "Switchover timeout: %u\n", handle->switchover_timeout);
|
||||
dcb_printf(dcb, "Automatic rejoin: %s\n", handle->auto_rejoin ? "Enabled" : "Disabled");
|
||||
dcb_printf(dcb, "MaxScale monitor ID: %lu\n", handle->id);
|
||||
dcb_printf(dcb, "Detect replication lag: %s\n", (handle->replicationHeartbeat) ? "Enabled" : "Disabled");
|
||||
dcb_printf(dcb, "Detect replication lag: %s\n", (handle->replicationHeartbeat == 1) ?
|
||||
"Enabled" : "Disabled");
|
||||
dcb_printf(dcb, "Detect stale master: %s\n", (handle->detectStaleMaster == 1) ?
|
||||
"Enabled" : "Disabled");
|
||||
if (handle->n_excluded > 0)
|
||||
@ -1280,9 +1282,9 @@ static json_t* diagnostics_json(const MXS_MONITOR *mon)
|
||||
json_object_set_new(rval, CN_SWITCHOVER_TIMEOUT, json_integer(handle->switchover_timeout));
|
||||
json_object_set_new(rval, CN_AUTO_REJOIN, json_boolean(handle->auto_rejoin));
|
||||
|
||||
if (!handle->script.empty())
|
||||
if (handle->script)
|
||||
{
|
||||
json_object_set_new(rval, "script", json_string(handle->script.c_str()));
|
||||
json_object_set_new(rval, "script", json_string(handle->script));
|
||||
}
|
||||
if (handle->n_excluded > 0)
|
||||
{
|
||||
@ -1433,7 +1435,7 @@ static bool do_show_slave_status(MYSQL_MONITOR* mon,
|
||||
* root master server.
|
||||
* Please note, there could be no slaves at all if Slave_SQL_Running == 'No'
|
||||
*/
|
||||
if (serv_info->slave_status.slave_io_running && server_version != MYSQL_SERVER_VERSION_51)
|
||||
if (server_version != MYSQL_SERVER_VERSION_51)
|
||||
{
|
||||
/* Get Master_Server_Id */
|
||||
master_server_id = scan_server_id(row[i_master_server_id]);
|
||||
@ -2110,7 +2112,7 @@ monitorMain(void *arg)
|
||||
MYSQL_MONITOR *handle = (MYSQL_MONITOR *) arg;
|
||||
MXS_MONITOR* mon = handle->monitor;
|
||||
MXS_MONITORED_SERVER *ptr;
|
||||
bool replication_heartbeat;
|
||||
int replication_heartbeat;
|
||||
bool detect_stale_master;
|
||||
int num_servers = 0;
|
||||
MXS_MONITORED_SERVER *root_master = NULL;
|
||||
@ -2283,20 +2285,21 @@ monitorMain(void *arg)
|
||||
if (master_info->slave_status.master_host != handle->external_master_host ||
|
||||
master_info->slave_status.master_port != handle->external_master_port)
|
||||
{
|
||||
const string new_ext_host = master_info->slave_status.master_host;
|
||||
const char* new_ext_host = master_info->slave_status.master_host.c_str();
|
||||
const int new_ext_port = master_info->slave_status.master_port;
|
||||
if (handle->external_master_port == PORT_UNKNOWN)
|
||||
{
|
||||
MXS_NOTICE("Cluster master server is replicating from an external master: %s:%d",
|
||||
new_ext_host.c_str(), new_ext_port);
|
||||
new_ext_host, new_ext_port);
|
||||
}
|
||||
else
|
||||
{
|
||||
MXS_NOTICE("The external master of the cluster has changed: %s:%d -> %s:%d.",
|
||||
handle->external_master_host.c_str(), handle->external_master_port,
|
||||
new_ext_host.c_str(), new_ext_port);
|
||||
handle->external_master_host, handle->external_master_port,
|
||||
new_ext_host, new_ext_port);
|
||||
}
|
||||
handle->external_master_host = new_ext_host;
|
||||
snprintf(handle->external_master_host, sizeof(handle->external_master_host),
|
||||
"%s", new_ext_host);
|
||||
handle->external_master_port = new_ext_port;
|
||||
}
|
||||
}
|
||||
@ -2306,7 +2309,7 @@ monitorMain(void *arg)
|
||||
{
|
||||
MXS_NOTICE("Cluster lost the external master.");
|
||||
}
|
||||
handle->external_master_host.clear();
|
||||
handle->external_master_host[0] = '\0';
|
||||
handle->external_master_port = PORT_UNKNOWN;
|
||||
}
|
||||
}
|
||||
@ -2467,7 +2470,7 @@ monitorMain(void *arg)
|
||||
* After updating the status of all servers, check if monitor events
|
||||
* need to be launched.
|
||||
*/
|
||||
mon_process_state_changes(mon, handle->script.c_str(), handle->events);
|
||||
mon_process_state_changes(mon, handle->script, handle->events);
|
||||
bool failover_performed = false; // Has an automatic failover been performed this loop?
|
||||
|
||||
if (handle->auto_failover)
|
||||
@ -3666,7 +3669,7 @@ bool start_external_replication(MYSQL_MONITOR* mon, MXS_MONITORED_SERVER* new_ma
|
||||
mxs_mysql_query(new_master->con, "START SLAVE;") == 0)
|
||||
{
|
||||
MXS_NOTICE("New master starting replication from external master %s:%d.",
|
||||
mon->external_master_host.c_str(), mon->external_master_port);
|
||||
mon->external_master_host, mon->external_master_port);
|
||||
rval = true;
|
||||
}
|
||||
else
|
||||
|
@ -1,6 +1,6 @@
|
||||
#pragma once
|
||||
#ifndef _MARIADBMON_H
|
||||
#define _MARIADBMON_H
|
||||
#ifndef _MYSQLMON_H
|
||||
#define _MYSQLMON_H
|
||||
/*
|
||||
* Copyright (c) 2016 MariaDB Corporation Ab
|
||||
*
|
||||
@ -15,65 +15,72 @@
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file mysqlmon.hh - The MySQL monitor
|
||||
* @file mysqlmon.h - The MySQL monitor
|
||||
*/
|
||||
|
||||
#include <maxscale/cppdefs.hh>
|
||||
#include <string>
|
||||
|
||||
#include <maxscale/config.h>
|
||||
#include <maxscale/dcb.h>
|
||||
#include <maxscale/hashtable.h>
|
||||
#include <maxscale/cdefs.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <maxscale/monitor.h>
|
||||
#include <maxscale/spinlock.h>
|
||||
#include <maxscale/thread.h>
|
||||
#include <mysql.h>
|
||||
#include <mysqld_error.h>
|
||||
#include <maxscale/log_manager.h>
|
||||
#include <maxscale/secrets.h>
|
||||
#include <maxscale/dcb.h>
|
||||
#include <maxscale/modinfo.h>
|
||||
#include <maxscale/config.h>
|
||||
#include <maxscale/hashtable.h>
|
||||
|
||||
using std::string;
|
||||
// MySQL Monitor module instance
|
||||
class MYSQL_MONITOR
|
||||
MXS_BEGIN_DECLS
|
||||
|
||||
/**
|
||||
* The handle for an instance of a MySQL Monitor module
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
public:
|
||||
MXS_MONITOR* monitor; /**< Generic monitor object */
|
||||
THREAD thread; /**< Monitor thread */
|
||||
int shutdown; /**< Flag to shutdown the monitor thread */
|
||||
int status; /**< Monitor status */
|
||||
MXS_MONITORED_SERVER *master; /**< Master server for MySQL Master/Slave replication */
|
||||
HASHTABLE *server_info; /**< Contains server specific information */
|
||||
bool warn_set_standalone_master; /**< Log a warning when setting standalone master */
|
||||
unsigned long id; /**< Monitor ID */
|
||||
|
||||
// Values updated by monitor
|
||||
int64_t master_gtid_domain; /**< Gtid domain currently used by the master */
|
||||
string external_master_host; /**< External master host, for fail/switchover */
|
||||
int external_master_port; /**< External master port */
|
||||
|
||||
// Replication topology detection settings
|
||||
bool mysql51_replication; /**< Use MySQL 5.1 replication */
|
||||
int replicationHeartbeat; /**< Monitor flag for MySQL replication heartbeat */
|
||||
bool detectStaleMaster; /**< Monitor flag for MySQL replication Stale Master detection */
|
||||
bool detectStaleSlave; /**< Monitor flag for MySQL replication Stale Master detection */
|
||||
bool multimaster; /**< Detect and handle multi-master topologies */
|
||||
bool ignore_external_masters; /**< Ignore masters outside of the monitor configuration */
|
||||
int disableMasterFailback; /**< Monitor flag for Galera Cluster Master failback */
|
||||
int availableWhenDonor; /**< Monitor flag for Galera Cluster Donor availability */
|
||||
int disableMasterRoleSetting; /**< Monitor flag to disable setting master role */
|
||||
bool mysql51_replication; /**< Use MySQL 5.1 replication */
|
||||
MXS_MONITORED_SERVER *master; /**< Master server for MySQL Master/Slave replication */
|
||||
char* script; /**< Script to call when state changes occur on servers */
|
||||
uint64_t events; /**< enabled events */
|
||||
HASHTABLE *server_info; /**< Contains server specific information */
|
||||
bool detect_standalone_master; /**< If standalone master are detected */
|
||||
bool replicationHeartbeat; /**< Monitor flag for MySQL replication heartbeat */
|
||||
|
||||
// Failover, switchover and rejoin settings
|
||||
string replication_user; /**< Replication user for CHANGE MASTER TO-commands */
|
||||
string replication_password; /**< Replication password for CHANGE MASTER TO-commands */
|
||||
int failcount; /**< How many monitoring cycles master must be down before auto-failover
|
||||
* begins */
|
||||
int failcount; /**< How many monitoring cycles servers must be
|
||||
down before failover is initiated */
|
||||
bool allow_cluster_recovery; /**< Allow failed servers to rejoin the cluster */
|
||||
bool warn_set_standalone_master; /**< Log a warning when setting standalone master */
|
||||
bool auto_failover; /**< If automatic master failover is enabled */
|
||||
uint32_t failover_timeout; /**< Timeout in seconds for the master failover */
|
||||
uint32_t switchover_timeout; /**< Timeout in seconds for the master switchover */
|
||||
char* replication_user; /**< Replication user for failover */
|
||||
char* replication_password; /**< Replication password for failover*/
|
||||
bool verify_master_failure; /**< Whether master failure is verified via slaves */
|
||||
int master_failure_timeout; /**< Master failure verification (via slaves) time in seconds */
|
||||
bool auto_failover; /**< If automatic master failover is enabled */
|
||||
int master_failure_timeout; /**< Time in seconds to wait before doing failover */
|
||||
int64_t master_gtid_domain; /**< Gtid domain currently used by the master */
|
||||
char external_master_host[MAX_SERVER_ADDRESS_LEN]; /**< External master host, for fail/switchover */
|
||||
int external_master_port; /**< External master port */
|
||||
bool auto_rejoin; /**< Attempt to start slave replication on standalone servers or servers
|
||||
* replicating from the wrong master automatically. */
|
||||
MXS_MONITORED_SERVER** excluded_servers; /**< Servers banned for master promotion during auto-failover. */
|
||||
replicating from the wrong master. */
|
||||
int n_excluded; /**< Number of excluded servers */
|
||||
MXS_MONITORED_SERVER** excluded_servers; /**< Servers banned for master promotion during auto-failover. */
|
||||
|
||||
// Other settings
|
||||
string script; /**< Script to call when state changes occur on servers */
|
||||
uint64_t events; /**< enabled events */
|
||||
bool allow_cluster_recovery; /**< Allow failed servers to rejoin the cluster */
|
||||
};
|
||||
MXS_MONITOR* monitor;
|
||||
} MYSQL_MONITOR;
|
||||
|
||||
MXS_END_DECLS
|
||||
|
||||
#endif
|
@ -17,7 +17,7 @@
|
||||
|
||||
#define MXS_MODULE_NAME "ndbclustermon"
|
||||
|
||||
#include "ndbclustermon.h"
|
||||
#include "../mysqlmon.h"
|
||||
#include <maxscale/alloc.h>
|
||||
#include <maxscale/mysql_utils.h>
|
||||
|
||||
@ -103,7 +103,7 @@ MXS_MODULE* MXS_CREATE_MODULE()
|
||||
static void *
|
||||
startMonitor(MXS_MONITOR *mon, const MXS_CONFIG_PARAMETER *params)
|
||||
{
|
||||
NDBC_MONITOR *handle = mon->handle;
|
||||
MYSQL_MONITOR *handle = mon->handle;
|
||||
bool have_events = false, script_error = false;
|
||||
|
||||
if (handle != NULL)
|
||||
@ -113,7 +113,7 @@ startMonitor(MXS_MONITOR *mon, const MXS_CONFIG_PARAMETER *params)
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((handle = (NDBC_MONITOR *) MXS_MALLOC(sizeof(NDBC_MONITOR))) == NULL)
|
||||
if ((handle = (MYSQL_MONITOR *) MXS_MALLOC(sizeof(MYSQL_MONITOR))) == NULL)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
@ -154,7 +154,7 @@ startMonitor(MXS_MONITOR *mon, const MXS_CONFIG_PARAMETER *params)
|
||||
static void
|
||||
stopMonitor(MXS_MONITOR *mon)
|
||||
{
|
||||
NDBC_MONITOR *handle = (NDBC_MONITOR *) mon->handle;
|
||||
MYSQL_MONITOR *handle = (MYSQL_MONITOR *) mon->handle;
|
||||
|
||||
handle->shutdown = 1;
|
||||
thread_wait(handle->thread);
|
||||
@ -306,7 +306,7 @@ monitorDatabase(MXS_MONITORED_SERVER *database, char *defaultUser, char *default
|
||||
static void
|
||||
monitorMain(void *arg)
|
||||
{
|
||||
NDBC_MONITOR *handle = (NDBC_MONITOR*)arg;
|
||||
MYSQL_MONITOR *handle = (MYSQL_MONITOR*)arg;
|
||||
MXS_MONITOR* mon = handle->monitor;
|
||||
MXS_MONITORED_SERVER *ptr;
|
||||
size_t nrounds = 0;
|
||||
|
@ -1,6 +1,5 @@
|
||||
#pragma once
|
||||
#ifndef _NDBCMON_H
|
||||
#define _NDBCMON_H
|
||||
#ifndef _MYSQLMON_H
|
||||
#define _MYSQLMON_H
|
||||
/*
|
||||
* Copyright (c) 2016 MariaDB Corporation Ab
|
||||
*
|
||||
@ -14,27 +13,39 @@
|
||||
* Public License.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <monitor.h>
|
||||
#include <spinlock.h>
|
||||
#include <thread.h>
|
||||
#include <mysql.h>
|
||||
#include <mysqld_error.h>
|
||||
#include <log_manager.h>
|
||||
#include <secrets.h>
|
||||
#include <dcb.h>
|
||||
#include <modinfo.h>
|
||||
#include <config.h>
|
||||
#include <externcmd.h>
|
||||
|
||||
/**
|
||||
* @file ndbclustermon.h - The NDB Cluster monitor
|
||||
*
|
||||
*/
|
||||
|
||||
#include <maxscale/monitor.h>
|
||||
#include <maxscale/spinlock.h>
|
||||
#include <maxscale/thread.h>
|
||||
|
||||
// The handle for an instance of a NDB Cluster Monitor module
|
||||
/**
|
||||
* The handle for an instance of a NDB Cluster Monitor module
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
THREAD thread; /**< Monitor thread */
|
||||
SPINLOCK lock; /**< The monitor spinlock */
|
||||
unsigned long id; /**< Monitor ID */
|
||||
uint64_t events; /*< enabled events */
|
||||
pthread_t tid; /**< id of monitor thread */
|
||||
int shutdown; /**< Flag to shutdown the monitor thread */
|
||||
int status; /**< Monitor status */
|
||||
MXS_MONITORED_SERVER *master; /**< Master server for MySQL Master/Slave replication */
|
||||
unsigned long id; /**< Monitor ID */
|
||||
MONITOR_SERVERS *master; /**< Master server for MySQL Master/Slave replication */
|
||||
char* script; /*< Script to call when state changes occur on servers */
|
||||
MXS_MONITOR* monitor;
|
||||
} NDBC_MONITOR;
|
||||
bool events[MAX_MONITOR_EVENT]; /*< enabled events */
|
||||
} MYSQL_MONITOR;
|
||||
|
||||
#endif
|
||||
|
@ -548,27 +548,20 @@ static inline bool connection_is_valid(ROUTER_INSTANCE* inst, ROUTER_CLIENT_SES*
|
||||
if (SERVER_IS_RUNNING(router_cli_ses->backend->server) &&
|
||||
(router_cli_ses->backend->server->status & inst->bitmask & inst->bitvalue))
|
||||
{
|
||||
if (inst->bitvalue & SERVER_MASTER)
|
||||
if ((inst->bitvalue & SERVER_MASTER) && router_cli_ses->backend->active)
|
||||
{
|
||||
SERVER_REF* master = get_root_master(inst->service->dbref);
|
||||
|
||||
if (master)
|
||||
{
|
||||
/** Check that the master we are connected to and the one we
|
||||
* determined from the replication topology are one and the same */
|
||||
rval = router_cli_ses->backend == get_root_master(inst->service->dbref);
|
||||
}
|
||||
else
|
||||
{
|
||||
/** No master is available but the one we are connected to is
|
||||
* still a master. This most likely means that the servers for
|
||||
* the service have been modified at runtime. */
|
||||
rval = true;
|
||||
}
|
||||
// If we're using an active master server, verify that it is still a master
|
||||
rval = router_cli_ses->backend == get_root_master(inst->service->dbref);
|
||||
}
|
||||
else
|
||||
{
|
||||
// Not a master and bitmask check is OK, everything is OK
|
||||
/**
|
||||
* Either we don't use master type servers or the server reference
|
||||
* is deactivated. We let deactivated connection close gracefully
|
||||
* so we simply assume it is OK. This allows a server to be taken
|
||||
* out of use in a manner that won't cause errors to the connected
|
||||
* clients.
|
||||
*/
|
||||
rval = true;
|
||||
}
|
||||
}
|
||||
|
@ -174,12 +174,13 @@ log_transaction_status(RWSplitSession *rses, GWBUF *querybuf, uint32_t qtype)
|
||||
MXS_SESSION *ses = rses->client_dcb->session;
|
||||
const char *autocommit = session_is_autocommit(ses) ? "[enabled]" : "[disabled]";
|
||||
const char *transaction = session_trx_is_active(ses) ? "[open]" : "[not open]";
|
||||
uint32_t plen = MYSQL_GET_PACKET_LEN(querybuf);
|
||||
const char *querytype = qtypestr == NULL ? "N/A" : qtypestr;
|
||||
const char *hint = querybuf->hint == NULL ? "" : ", Hint:";
|
||||
const char *hint_type = querybuf->hint == NULL ? "" : STRHINTTYPE(querybuf->hint->type);
|
||||
|
||||
MXS_INFO("> Autocommit: %s, trx is %s, cmd: (0x%02x) %s, type: %s, stmt: %.*s%s %s",
|
||||
autocommit, transaction, command, STRPACKETTYPE(command),
|
||||
MXS_INFO("> Autocommit: %s, trx is %s, cmd: (0x%02x) %s, plen: %u, type: %s, pastmt: %.*s%s %s",
|
||||
autocommit, transaction, command, STRPACKETTYPE(command), plen,
|
||||
querytype, len, sql, hint, hint_type);
|
||||
|
||||
MXS_FREE(qtypestr);
|
||||
|
@ -835,10 +835,10 @@ handle_multi_temp_and_load(RWSplitSession *rses, GWBUF *querybuf,
|
||||
/**
|
||||
* Check if the query has anything to do with temporary tables.
|
||||
*/
|
||||
if (rses->have_tmp_tables)
|
||||
if (rses->have_tmp_tables && is_packet_a_query(packet_type))
|
||||
{
|
||||
check_drop_tmp_table(rses, querybuf);
|
||||
if (is_packet_a_query(packet_type) && is_read_tmp_table(rses, querybuf, *qtype))
|
||||
if (is_read_tmp_table(rses, querybuf, *qtype))
|
||||
{
|
||||
*qtype |= QUERY_TYPE_MASTER_READ;
|
||||
}
|
||||
|
Reference in New Issue
Block a user