mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 21:42:35 +01:00
3139 lines
69 KiB
C++
3139 lines
69 KiB
C++
/* Copyright (C) 2008-2014 Kentoku Shiba
|
|
|
|
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
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
#define MYSQL_SERVER 1
|
|
#include "mysql_version.h"
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#include "mysql_priv.h"
|
|
#include <mysql/plugin.h>
|
|
#else
|
|
#include "sql_priv.h"
|
|
#include "probes_mysql.h"
|
|
#include "sql_class.h"
|
|
#include "sql_partition.h"
|
|
#endif
|
|
#include <my_getopt.h>
|
|
#include "spd_err.h"
|
|
#include "spd_db_include.h"
|
|
#include "spd_include.h"
|
|
#include "ha_spider.h"
|
|
#include "spd_table.h"
|
|
#include "spd_trx.h"
|
|
|
|
extern struct st_mysql_plugin spider_i_s_alloc_mem;
|
|
#ifdef MARIADB_BASE_VERSION
|
|
extern struct st_maria_plugin spider_i_s_alloc_mem_maria;
|
|
#endif
|
|
|
|
extern volatile ulonglong spider_mon_table_cache_version;
|
|
extern volatile ulonglong spider_mon_table_cache_version_req;
|
|
|
|
#ifdef HANDLER_HAS_DIRECT_UPDATE_ROWS
|
|
static int spider_direct_update(THD *thd, SHOW_VAR *var, char *buff)
|
|
{
|
|
int error_num = 0;
|
|
SPIDER_TRX *trx;
|
|
DBUG_ENTER("spider_direct_update");
|
|
var->type = SHOW_LONGLONG;
|
|
if ((trx = spider_get_trx(thd, TRUE, &error_num)))
|
|
var->value = (char *) &trx->direct_update_count;
|
|
DBUG_RETURN(error_num);
|
|
}
|
|
|
|
static int spider_direct_delete(THD *thd, SHOW_VAR *var, char *buff)
|
|
{
|
|
int error_num = 0;
|
|
SPIDER_TRX *trx;
|
|
DBUG_ENTER("spider_direct_delete");
|
|
var->type = SHOW_LONGLONG;
|
|
if ((trx = spider_get_trx(thd, TRUE, &error_num)))
|
|
var->value = (char *) &trx->direct_delete_count;
|
|
DBUG_RETURN(error_num);
|
|
}
|
|
#endif
|
|
|
|
static int spider_direct_order_limit(THD *thd, SHOW_VAR *var, char *buff)
|
|
{
|
|
int error_num = 0;
|
|
SPIDER_TRX *trx;
|
|
DBUG_ENTER("spider_direct_order_limit");
|
|
var->type = SHOW_LONGLONG;
|
|
if ((trx = spider_get_trx(thd, TRUE, &error_num)))
|
|
var->value = (char *) &trx->direct_order_limit_count;
|
|
DBUG_RETURN(error_num);
|
|
}
|
|
|
|
static int spider_direct_aggregate(THD *thd, SHOW_VAR *var, char *buff)
|
|
{
|
|
int error_num = 0;
|
|
SPIDER_TRX *trx;
|
|
DBUG_ENTER("spider_direct_aggregate");
|
|
var->type = SHOW_LONGLONG;
|
|
if ((trx = spider_get_trx(thd, TRUE, &error_num)))
|
|
var->value = (char *) &trx->direct_aggregate_count;
|
|
DBUG_RETURN(error_num);
|
|
}
|
|
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
static int spider_hs_result_free(THD *thd, SHOW_VAR *var, char *buff)
|
|
{
|
|
int error_num = 0;
|
|
SPIDER_TRX *trx;
|
|
DBUG_ENTER("spider_hs_result_free");
|
|
var->type = SHOW_LONGLONG;
|
|
if ((trx = spider_get_trx(thd, TRUE, &error_num)))
|
|
var->value = (char *) &trx->hs_result_free_count;
|
|
DBUG_RETURN(error_num);
|
|
}
|
|
#endif
|
|
|
|
struct st_mysql_show_var spider_status_variables[] =
|
|
{
|
|
{"Spider_mon_table_cache_version",
|
|
(char *) &spider_mon_table_cache_version, SHOW_LONGLONG},
|
|
{"Spider_mon_table_cache_version_req",
|
|
(char *) &spider_mon_table_cache_version_req, SHOW_LONGLONG},
|
|
#ifdef HANDLER_HAS_DIRECT_UPDATE_ROWS
|
|
#ifdef SPIDER_HAS_SHOW_SIMPLE_FUNC
|
|
{"Spider_direct_update", (char *) &spider_direct_update, SHOW_SIMPLE_FUNC},
|
|
{"Spider_direct_delete", (char *) &spider_direct_delete, SHOW_SIMPLE_FUNC},
|
|
#else
|
|
{"Spider_direct_update", (char *) &spider_direct_update, SHOW_FUNC},
|
|
{"Spider_direct_delete", (char *) &spider_direct_delete, SHOW_FUNC},
|
|
#endif
|
|
#endif
|
|
#ifdef SPIDER_HAS_SHOW_SIMPLE_FUNC
|
|
{"Spider_direct_order_limit",
|
|
(char *) &spider_direct_order_limit, SHOW_SIMPLE_FUNC},
|
|
{"Spider_direct_aggregate",
|
|
(char *) &spider_direct_aggregate, SHOW_SIMPLE_FUNC},
|
|
#else
|
|
{"Spider_direct_order_limit",
|
|
(char *) &spider_direct_order_limit, SHOW_FUNC},
|
|
{"Spider_direct_aggregate",
|
|
(char *) &spider_direct_aggregate, SHOW_FUNC},
|
|
#endif
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
#ifdef SPIDER_HAS_SHOW_SIMPLE_FUNC
|
|
{"Spider_hs_result_free", (char *) &spider_hs_result_free, SHOW_SIMPLE_FUNC},
|
|
#else
|
|
{"Spider_hs_result_free", (char *) &spider_hs_result_free, SHOW_FUNC},
|
|
#endif
|
|
#endif
|
|
{NullS, NullS, SHOW_LONG}
|
|
};
|
|
|
|
typedef DECLARE_MYSQL_THDVAR_SIMPLE(thdvar_int_t, int);
|
|
#if MYSQL_VERSION_ID < 50500
|
|
extern bool throw_bounds_warning(THD *thd, bool fixed, bool unsignd,
|
|
const char *name, long long val);
|
|
#else
|
|
extern bool throw_bounds_warning(THD *thd, const char *name, bool fixed,
|
|
bool is_unsignd, longlong v);
|
|
#endif
|
|
|
|
static my_bool spider_support_xa;
|
|
static MYSQL_SYSVAR_BOOL(
|
|
support_xa,
|
|
spider_support_xa,
|
|
PLUGIN_VAR_OPCMDARG | PLUGIN_VAR_READONLY,
|
|
"XA support",
|
|
NULL,
|
|
NULL,
|
|
TRUE
|
|
);
|
|
|
|
my_bool spider_param_support_xa()
|
|
{
|
|
DBUG_ENTER("spider_param_support_xa");
|
|
DBUG_RETURN(spider_support_xa);
|
|
}
|
|
|
|
static my_bool spider_connect_mutex;
|
|
static MYSQL_SYSVAR_BOOL(
|
|
connect_mutex,
|
|
spider_connect_mutex,
|
|
PLUGIN_VAR_OPCMDARG,
|
|
"Use mutex at connecting",
|
|
NULL,
|
|
NULL,
|
|
FALSE
|
|
);
|
|
|
|
my_bool spider_param_connect_mutex()
|
|
{
|
|
DBUG_ENTER("spider_param_connect_mutex");
|
|
DBUG_RETURN(spider_connect_mutex);
|
|
}
|
|
|
|
static uint spider_table_init_error_interval;
|
|
/*
|
|
0-: interval
|
|
*/
|
|
static MYSQL_SYSVAR_UINT(
|
|
table_init_error_interval,
|
|
spider_table_init_error_interval,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Return same error code until interval passes if table init is failed",
|
|
NULL,
|
|
NULL,
|
|
1,
|
|
0,
|
|
4294967295U,
|
|
0
|
|
);
|
|
|
|
uint spider_param_table_init_error_interval()
|
|
{
|
|
DBUG_ENTER("spider_param_table_init_error_interval");
|
|
DBUG_RETURN(spider_table_init_error_interval);
|
|
}
|
|
|
|
static int spider_use_table_charset;
|
|
/*
|
|
-1 :use table parameter
|
|
0 :use utf8
|
|
1 :use table charset
|
|
*/
|
|
static MYSQL_SYSVAR_INT(
|
|
use_table_charset,
|
|
spider_use_table_charset,
|
|
PLUGIN_VAR_RQCMDARG | PLUGIN_VAR_READONLY,
|
|
"Use table charset for remote access",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
1,
|
|
0
|
|
);
|
|
|
|
int spider_param_use_table_charset(
|
|
int use_table_charset
|
|
) {
|
|
DBUG_ENTER("spider_param_use_table_charset");
|
|
DBUG_RETURN(spider_use_table_charset == -1 ?
|
|
use_table_charset : spider_use_table_charset);
|
|
}
|
|
|
|
/*
|
|
0: no recycle
|
|
1: recycle in instance
|
|
2: recycle in thread
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
conn_recycle_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Connection recycle mode", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_conn_recycle_mode(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_conn_recycle_mode");
|
|
DBUG_RETURN(THDVAR(thd, conn_recycle_mode));
|
|
}
|
|
|
|
/*
|
|
0: weak
|
|
1: strict
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
conn_recycle_strict, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Strict connection recycle", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_conn_recycle_strict(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_conn_recycle_strict");
|
|
DBUG_RETURN(THDVAR(thd, conn_recycle_strict));
|
|
}
|
|
|
|
/*
|
|
FALSE: no sync
|
|
TRUE: sync
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
sync_trx_isolation, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Sync transaction isolation level", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
TRUE /* def */
|
|
);
|
|
|
|
bool spider_param_sync_trx_isolation(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_sync_trx_isolation");
|
|
DBUG_RETURN(THDVAR(thd, sync_trx_isolation));
|
|
}
|
|
|
|
/*
|
|
FALSE: no use
|
|
TRUE: use
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
use_consistent_snapshot, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Use start transaction with consistent snapshot", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_use_consistent_snapshot(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_use_consistent_snapshot");
|
|
DBUG_RETURN(THDVAR(thd, use_consistent_snapshot));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
internal_xa, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Use inner xa transaction", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_internal_xa(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_xa");
|
|
DBUG_RETURN(THDVAR(thd, internal_xa));
|
|
}
|
|
|
|
/*
|
|
0 :err when use a spider table
|
|
1 :err when start trx
|
|
2 :start trx with snapshot on remote server(not use xa)
|
|
3 :start xa on remote server(not use trx with snapshot)
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
internal_xa_snapshot, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Action of inner xa and snapshot both using", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_internal_xa_snapshot(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_xa_snapshot");
|
|
DBUG_RETURN(THDVAR(thd, internal_xa_snapshot));
|
|
}
|
|
|
|
/*
|
|
0 :off
|
|
1 :continue prepare, commit, rollback if xid not found return
|
|
2 :continue prepare, commit, rollback if all error return
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
force_commit, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Force prepare, commit, rollback mode", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
1, /* def */
|
|
0, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_force_commit(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_force_commit");
|
|
DBUG_RETURN(THDVAR(thd, force_commit));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:offset
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
internal_offset, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Internal offset", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_internal_offset(
|
|
THD *thd,
|
|
longlong internal_offset
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_offset");
|
|
DBUG_RETURN(THDVAR(thd, internal_offset) < 0 ?
|
|
internal_offset : THDVAR(thd, internal_offset));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:limit
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
internal_limit, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Internal limit", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_internal_limit(
|
|
THD *thd,
|
|
longlong internal_limit
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_limit");
|
|
DBUG_RETURN(THDVAR(thd, internal_limit) < 0 ?
|
|
internal_limit : THDVAR(thd, internal_limit));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:number of rows at a select
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
split_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of rows at a select", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_split_read(
|
|
THD *thd,
|
|
longlong split_read
|
|
) {
|
|
DBUG_ENTER("spider_param_split_read");
|
|
DBUG_RETURN(THDVAR(thd, split_read) < 0 ?
|
|
split_read : THDVAR(thd, split_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :doesn't use "offset" and "limit" for "split_read"
|
|
1-:magnification
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
semi_split_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use offset and limit parameter in SQL for split_read parameter.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
double spider_param_semi_split_read(
|
|
THD *thd,
|
|
double semi_split_read
|
|
) {
|
|
DBUG_ENTER("spider_param_semi_split_read");
|
|
DBUG_RETURN(THDVAR(thd, semi_split_read) < 0 ?
|
|
semi_split_read : THDVAR(thd, semi_split_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:the limit value
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
semi_split_read_limit, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"The limit value for semi_split_read", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_semi_split_read_limit(
|
|
THD *thd,
|
|
longlong semi_split_read_limit
|
|
) {
|
|
DBUG_ENTER("spider_param_semi_split_read_limit");
|
|
DBUG_RETURN(THDVAR(thd, semi_split_read_limit) < 0 ?
|
|
semi_split_read_limit : THDVAR(thd, semi_split_read_limit));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :no alloc
|
|
1-:alloc size
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
init_sql_alloc_size, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Initial sql string alloc size", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_init_sql_alloc_size(
|
|
THD *thd,
|
|
int init_sql_alloc_size
|
|
) {
|
|
DBUG_ENTER("spider_param_init_sql_alloc_size");
|
|
DBUG_RETURN(THDVAR(thd, init_sql_alloc_size) < 0 ?
|
|
init_sql_alloc_size : THDVAR(thd, init_sql_alloc_size));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :off
|
|
1 :on
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
reset_sql_alloc, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Reset sql string alloc after execute", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_reset_sql_alloc(
|
|
THD *thd,
|
|
int reset_sql_alloc
|
|
) {
|
|
DBUG_ENTER("spider_param_reset_sql_alloc");
|
|
DBUG_RETURN(THDVAR(thd, reset_sql_alloc) < 0 ?
|
|
reset_sql_alloc : THDVAR(thd, reset_sql_alloc));
|
|
}
|
|
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
/*
|
|
-1 :use table parameter
|
|
0-:result free size for handlersocket
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
hs_result_free_size, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Result free size for handlersocket", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_hs_result_free_size(
|
|
THD *thd,
|
|
longlong hs_result_free_size
|
|
) {
|
|
DBUG_ENTER("spider_param_hs_result_free_size");
|
|
DBUG_RETURN(THDVAR(thd, hs_result_free_size) < 0 ?
|
|
hs_result_free_size : THDVAR(thd, hs_result_free_size));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :off
|
|
1 :on
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
multi_split_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Sprit read mode for multi range", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_multi_split_read(
|
|
THD *thd,
|
|
int multi_split_read
|
|
) {
|
|
DBUG_ENTER("spider_param_multi_split_read");
|
|
DBUG_RETURN(THDVAR(thd, multi_split_read) < 0 ?
|
|
multi_split_read : THDVAR(thd, multi_split_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:max order columns
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
max_order, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Max columns for order by", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
32767, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_max_order(
|
|
THD *thd,
|
|
int max_order
|
|
) {
|
|
DBUG_ENTER("spider_param_max_order");
|
|
DBUG_RETURN(THDVAR(thd, max_order) < 0 ?
|
|
max_order : THDVAR(thd, max_order));
|
|
}
|
|
|
|
/*
|
|
-1 :off
|
|
0 :read uncommitted
|
|
1 :read committed
|
|
2 :repeatable read
|
|
3 :serializable
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
semi_trx_isolation, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Transaction isolation level during execute a sql", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_semi_trx_isolation(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_semi_trx_isolation");
|
|
DBUG_RETURN(THDVAR(thd, semi_trx_isolation));
|
|
}
|
|
|
|
static int spider_param_semi_table_lock_check(
|
|
MYSQL_THD thd,
|
|
struct st_mysql_sys_var *var,
|
|
void *save,
|
|
struct st_mysql_value *value
|
|
) {
|
|
int error_num;
|
|
SPIDER_TRX *trx;
|
|
my_bool fixed;
|
|
long long tmp;
|
|
struct my_option options;
|
|
DBUG_ENTER("spider_param_semi_table_lock_check");
|
|
if (!(trx = spider_get_trx((THD *) thd, TRUE, &error_num)))
|
|
DBUG_RETURN(error_num);
|
|
if (trx->locked_connections)
|
|
{
|
|
my_message(ER_SPIDER_ALTER_BEFORE_UNLOCK_NUM,
|
|
ER_SPIDER_ALTER_BEFORE_UNLOCK_STR, MYF(0));
|
|
DBUG_RETURN(ER_SPIDER_ALTER_BEFORE_UNLOCK_NUM);
|
|
}
|
|
value->val_int(value, &tmp);
|
|
options.sub_size = 0;
|
|
options.var_type = GET_INT;
|
|
options.def_value = ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->def_val;
|
|
options.min_value = ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->min_val;
|
|
options.max_value = ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->max_val;
|
|
options.block_size =
|
|
(long) ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->blk_sz;
|
|
options.arg_type = REQUIRED_ARG;
|
|
*((int *) save) = (int) getopt_ll_limit_value(tmp, &options, &fixed);
|
|
#if MYSQL_VERSION_ID < 50500
|
|
DBUG_RETURN(throw_bounds_warning(thd, fixed, FALSE,
|
|
((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->name, (long long) tmp));
|
|
#else
|
|
DBUG_RETURN(throw_bounds_warning(thd,
|
|
((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->name, fixed, FALSE,
|
|
(longlong) tmp));
|
|
#endif
|
|
}
|
|
|
|
/*
|
|
0 :off
|
|
1 :on
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
semi_table_lock, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Table lock during execute a sql", /* comment */
|
|
&spider_param_semi_table_lock_check, /* check */
|
|
NULL, /* update */
|
|
1, /* def */
|
|
0, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_semi_table_lock(
|
|
THD *thd,
|
|
int semi_table_lock
|
|
) {
|
|
DBUG_ENTER("spider_param_semi_table_lock");
|
|
DBUG_RETURN((semi_table_lock & THDVAR(thd, semi_table_lock)));
|
|
}
|
|
|
|
static int spider_param_semi_table_lock_connection_check(
|
|
MYSQL_THD thd,
|
|
struct st_mysql_sys_var *var,
|
|
void *save,
|
|
struct st_mysql_value *value
|
|
) {
|
|
int error_num;
|
|
SPIDER_TRX *trx;
|
|
my_bool fixed;
|
|
long long tmp;
|
|
struct my_option options;
|
|
DBUG_ENTER("spider_param_semi_table_lock_connection_check");
|
|
if (!(trx = spider_get_trx((THD *) thd, TRUE, &error_num)))
|
|
DBUG_RETURN(error_num);
|
|
if (trx->locked_connections)
|
|
{
|
|
my_message(ER_SPIDER_ALTER_BEFORE_UNLOCK_NUM,
|
|
ER_SPIDER_ALTER_BEFORE_UNLOCK_STR, MYF(0));
|
|
DBUG_RETURN(ER_SPIDER_ALTER_BEFORE_UNLOCK_NUM);
|
|
}
|
|
value->val_int(value, &tmp);
|
|
options.sub_size = 0;
|
|
options.var_type = GET_INT;
|
|
options.def_value = ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->def_val;
|
|
options.min_value = ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->min_val;
|
|
options.max_value = ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->max_val;
|
|
options.block_size =
|
|
(long) ((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->blk_sz;
|
|
options.arg_type = REQUIRED_ARG;
|
|
*((int *) save) = (int) getopt_ll_limit_value(tmp, &options, &fixed);
|
|
#if MYSQL_VERSION_ID < 50500
|
|
DBUG_RETURN(throw_bounds_warning(thd, fixed, FALSE,
|
|
((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->name, (long long) tmp));
|
|
#else
|
|
DBUG_RETURN(throw_bounds_warning(thd,
|
|
((MYSQL_SYSVAR_NAME(thdvar_int_t) *) var)->name, fixed, FALSE,
|
|
(longlong) tmp));
|
|
#endif
|
|
}
|
|
|
|
/*
|
|
-1 :off
|
|
0 :use same connection
|
|
1 :use different connection
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
semi_table_lock_connection, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use different connection if semi_table_lock is enabled", /* comment */
|
|
&spider_param_semi_table_lock_connection_check, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_semi_table_lock_connection(
|
|
THD *thd,
|
|
int semi_table_lock_connection
|
|
) {
|
|
DBUG_ENTER("spider_param_semi_table_lock_connection");
|
|
DBUG_RETURN(THDVAR(thd, semi_table_lock_connection) == -1 ?
|
|
semi_table_lock_connection : THDVAR(thd, semi_table_lock_connection));
|
|
}
|
|
|
|
/*
|
|
0-:block_size
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
block_size, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Index block size", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
16384, /* def */
|
|
0, /* min */
|
|
4294967295U, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_block_size(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_block_size");
|
|
DBUG_RETURN(THDVAR(thd, block_size));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :off
|
|
1 :lock in share mode
|
|
2 :for update
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
selupd_lock_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Lock for select with update", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_selupd_lock_mode(
|
|
THD *thd,
|
|
int selupd_lock_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_selupd_lock_mode");
|
|
DBUG_RETURN(THDVAR(thd, selupd_lock_mode) == -1 ?
|
|
selupd_lock_mode : THDVAR(thd, selupd_lock_mode));
|
|
}
|
|
|
|
/*
|
|
FALSE: no sync
|
|
TRUE: sync
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
sync_autocommit, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Sync autocommit", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
TRUE /* def */
|
|
);
|
|
|
|
bool spider_param_sync_autocommit(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_sync_autocommit");
|
|
DBUG_RETURN(THDVAR(thd, sync_autocommit));
|
|
}
|
|
|
|
/*
|
|
FALSE: no sync
|
|
TRUE: sync
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
sync_time_zone, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Sync time_zone", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_sync_time_zone(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_sync_time_zone");
|
|
DBUG_RETURN(THDVAR(thd, sync_time_zone));
|
|
}
|
|
|
|
/*
|
|
FALSE: not use
|
|
TRUE: use
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
use_default_database, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Use default database", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
TRUE /* def */
|
|
);
|
|
|
|
bool spider_param_use_default_database(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_use_default_database");
|
|
DBUG_RETURN(THDVAR(thd, use_default_database));
|
|
}
|
|
|
|
/*
|
|
FALSE: sql_log_off = 0
|
|
TRUE: sql_log_off = 1
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
internal_sql_log_off, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Sync sql_log_off", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
TRUE /* def */
|
|
);
|
|
|
|
bool spider_param_internal_sql_log_off(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_sql_log_off");
|
|
DBUG_RETURN(THDVAR(thd, internal_sql_log_off));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:bulk insert size
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
bulk_size, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Bulk insert size", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_bulk_size(
|
|
THD *thd,
|
|
int bulk_size
|
|
) {
|
|
DBUG_ENTER("spider_param_bulk_size");
|
|
DBUG_RETURN(THDVAR(thd, bulk_size) < 0 ?
|
|
bulk_size : THDVAR(thd, bulk_size));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 : Send "update" and "delete" statements one by one.
|
|
1 : Send collected multiple "update" and "delete" statements.
|
|
(Collected statements are sent one by one)
|
|
2 : Send collected multiple "update" and "delete" statements.
|
|
(Collected statements are sent together)
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
bulk_update_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"The mode of bulk updating and deleting", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_bulk_update_mode(
|
|
THD *thd,
|
|
int bulk_update_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_bulk_update_mode");
|
|
DBUG_RETURN(THDVAR(thd, bulk_update_mode) == -1 ?
|
|
bulk_update_mode : THDVAR(thd, bulk_update_mode));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:bulk update size
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
bulk_update_size, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Bulk update size", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_bulk_update_size(
|
|
THD *thd,
|
|
int bulk_update_size
|
|
) {
|
|
DBUG_ENTER("spider_param_bulk_update_size");
|
|
DBUG_RETURN(THDVAR(thd, bulk_update_size) == -1 ?
|
|
bulk_update_size : THDVAR(thd, bulk_update_size));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :off
|
|
1 :on
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
internal_optimize, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Execute optimize to remote server", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_internal_optimize(
|
|
THD *thd,
|
|
int internal_optimize
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_optimize");
|
|
DBUG_RETURN(THDVAR(thd, internal_optimize) == -1 ?
|
|
internal_optimize : THDVAR(thd, internal_optimize));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :off
|
|
1 :on
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
internal_optimize_local, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Execute optimize to remote server with local", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_internal_optimize_local(
|
|
THD *thd,
|
|
int internal_optimize_local
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_optimize_local");
|
|
DBUG_RETURN(THDVAR(thd, internal_optimize_local) == -1 ?
|
|
internal_optimize_local : THDVAR(thd, internal_optimize_local));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
use_flash_logs, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Execute flush logs to remote server", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_use_flash_logs(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_use_flash_logs");
|
|
DBUG_RETURN(THDVAR(thd, use_flash_logs));
|
|
}
|
|
|
|
/*
|
|
0 :off
|
|
1 :flush tables with read lock
|
|
2 :flush tables another connection
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
use_snapshot_with_flush_tables, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Execute optimize to remote server with local", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_use_snapshot_with_flush_tables(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_use_snapshot_with_flush_tables");
|
|
DBUG_RETURN(THDVAR(thd, use_snapshot_with_flush_tables));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
use_all_conns_snapshot, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"When start trx with snapshot, it send to all connections", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_use_all_conns_snapshot(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_use_all_conns_snapshot");
|
|
DBUG_RETURN(THDVAR(thd, use_all_conns_snapshot));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
lock_exchange, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Exchange select lock to lock tables", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_lock_exchange(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_lock_exchange");
|
|
DBUG_RETURN(THDVAR(thd, lock_exchange));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
internal_unlock, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Unlock tables for using connections in sql", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_internal_unlock(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_unlock");
|
|
DBUG_RETURN(THDVAR(thd, internal_unlock));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
semi_trx, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Take a transaction during execute a sql", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
TRUE /* def */
|
|
);
|
|
|
|
bool spider_param_semi_trx(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_semi_trx");
|
|
DBUG_RETURN(THDVAR(thd, semi_trx));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:seconds of timeout
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
connect_timeout, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Wait timeout of connecting to remote server", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_connect_timeout(
|
|
THD *thd,
|
|
int connect_timeout
|
|
) {
|
|
DBUG_ENTER("spider_param_connect_timeout");
|
|
if (thd)
|
|
DBUG_RETURN(THDVAR(thd, connect_timeout) == -1 ?
|
|
connect_timeout : THDVAR(thd, connect_timeout));
|
|
DBUG_RETURN(connect_timeout);
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:seconds of timeout
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
net_read_timeout, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Wait timeout of receiving data from remote server", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_net_read_timeout(
|
|
THD *thd,
|
|
int net_read_timeout
|
|
) {
|
|
DBUG_ENTER("spider_param_net_read_timeout");
|
|
if (thd)
|
|
DBUG_RETURN(THDVAR(thd, net_read_timeout) == -1 ?
|
|
net_read_timeout : THDVAR(thd, net_read_timeout));
|
|
DBUG_RETURN(net_read_timeout);
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:seconds of timeout
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
net_write_timeout, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Wait timeout of sending data to remote server", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_net_write_timeout(
|
|
THD *thd,
|
|
int net_write_timeout
|
|
) {
|
|
DBUG_ENTER("spider_param_net_write_timeout");
|
|
if (thd)
|
|
DBUG_RETURN(THDVAR(thd, net_write_timeout) == -1 ?
|
|
net_write_timeout : THDVAR(thd, net_write_timeout));
|
|
DBUG_RETURN(net_write_timeout);
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :It acquires it collectively.
|
|
1 :Acquisition one by one.If it discontinues once, and it will need
|
|
it later, it retrieves it again when there is interrupt on the way.
|
|
2 :Acquisition one by one.Interrupt is waited for until end of getting
|
|
result when there is interrupt on the way.
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
quick_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"The retrieval result from a remote server is acquired by acquisition one by one", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_quick_mode(
|
|
THD *thd,
|
|
int quick_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_quick_mode");
|
|
DBUG_RETURN(THDVAR(thd, quick_mode) < 0 ?
|
|
quick_mode : THDVAR(thd, quick_mode));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:number of records
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
quick_page_size, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of records in a page when acquisition one by one", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_quick_page_size(
|
|
THD *thd,
|
|
longlong quick_page_size
|
|
) {
|
|
DBUG_ENTER("spider_param_quick_page_size");
|
|
DBUG_RETURN(THDVAR(thd, quick_page_size) < 0 ?
|
|
quick_page_size : THDVAR(thd, quick_page_size));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :It doesn't use low memory mode.
|
|
1 :It uses low memory mode.
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
low_mem_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use low memory mode when SQL(SELECT) internally issued to a remote server is executed and get a result list", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_low_mem_read(
|
|
THD *thd,
|
|
int low_mem_read
|
|
) {
|
|
DBUG_ENTER("spider_param_low_mem_read");
|
|
DBUG_RETURN(THDVAR(thd, low_mem_read) < 0 ?
|
|
low_mem_read : THDVAR(thd, low_mem_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :Use index columns if select statement can solve by using index,
|
|
otherwise use all columns.
|
|
1 :Use columns that are judged necessary.
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
select_column_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"The mode of using columns at select clause", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_select_column_mode(
|
|
THD *thd,
|
|
int select_column_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_select_column_mode");
|
|
DBUG_RETURN(THDVAR(thd, select_column_mode) == -1 ?
|
|
select_column_mode : THDVAR(thd, select_column_mode));
|
|
}
|
|
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
/*
|
|
-1 :use table parameter
|
|
0 :background search is disabled
|
|
1 :background search is used if search with no lock
|
|
2 :background search is used if search with no lock or shared lock
|
|
3 :background search is used regardless of the lock
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
bgs_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of background search", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_bgs_mode(
|
|
THD *thd,
|
|
int bgs_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_bgs_mode");
|
|
DBUG_RETURN(THDVAR(thd, bgs_mode) < 0 ?
|
|
bgs_mode : THDVAR(thd, bgs_mode));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :records is gotten usually
|
|
1-:number of records
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
bgs_first_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of first read records when background search is used", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_bgs_first_read(
|
|
THD *thd,
|
|
longlong bgs_first_read
|
|
) {
|
|
DBUG_ENTER("spider_param_bgs_first_read");
|
|
DBUG_RETURN(THDVAR(thd, bgs_first_read) < 0 ?
|
|
bgs_first_read : THDVAR(thd, bgs_first_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :records is gotten usually
|
|
1-:number of records
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
bgs_second_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of second read records when background search is used", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_bgs_second_read(
|
|
THD *thd,
|
|
longlong bgs_second_read
|
|
) {
|
|
DBUG_ENTER("spider_param_bgs_second_read");
|
|
DBUG_RETURN(THDVAR(thd, bgs_second_read) < 0 ?
|
|
bgs_second_read : THDVAR(thd, bgs_second_read));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :records is gotten usually
|
|
1-:number of records
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
first_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of first read records", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_first_read(
|
|
THD *thd,
|
|
longlong first_read
|
|
) {
|
|
DBUG_ENTER("spider_param_first_read");
|
|
DBUG_RETURN(THDVAR(thd, first_read) < 0 ?
|
|
first_read : THDVAR(thd, first_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :records is gotten usually
|
|
1-:number of records
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
second_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of second read records", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_second_read(
|
|
THD *thd,
|
|
longlong second_read
|
|
) {
|
|
DBUG_ENTER("spider_param_second_read");
|
|
DBUG_RETURN(THDVAR(thd, second_read) < 0 ?
|
|
second_read : THDVAR(thd, second_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :always get the newest information
|
|
1-:interval
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
crd_interval, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Interval of cardinality confirmation.(second)", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
double spider_param_crd_interval(
|
|
THD *thd,
|
|
double crd_interval
|
|
) {
|
|
DBUG_ENTER("spider_param_crd_interval");
|
|
DBUG_RETURN(THDVAR(thd, crd_interval) == -1 ?
|
|
crd_interval : THDVAR(thd, crd_interval));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :use table parameter
|
|
1 :use show command
|
|
2 :use information schema
|
|
3 :use explain
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
crd_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of cardinality confirmation.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_crd_mode(
|
|
THD *thd,
|
|
int crd_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_crd_mode");
|
|
DBUG_RETURN(THDVAR(thd, crd_mode) <= 0 ?
|
|
crd_mode : THDVAR(thd, crd_mode));
|
|
}
|
|
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
/*
|
|
-1 :use table parameter
|
|
0 :No synchronization.
|
|
1 :Cardinality is synchronized when opening a table.
|
|
Then no synchronization.
|
|
2 :Synchronization.
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
crd_sync, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Cardinality synchronization in partitioned table.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_crd_sync(
|
|
THD *thd,
|
|
int crd_sync
|
|
) {
|
|
DBUG_ENTER("spider_param_crd_sync");
|
|
DBUG_RETURN(THDVAR(thd, crd_sync) == -1 ?
|
|
crd_sync : THDVAR(thd, crd_sync));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :The crd_weight is used as a fixed value.
|
|
1 :The crd_weight is used as an addition value.
|
|
2 :The crd_weight is used as a multiplication value.
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
crd_type, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Type of cardinality calculation.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_crd_type(
|
|
THD *thd,
|
|
int crd_type
|
|
) {
|
|
DBUG_ENTER("spider_param_crd_type");
|
|
DBUG_RETURN(THDVAR(thd, crd_type) == -1 ?
|
|
crd_type : THDVAR(thd, crd_type));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0-:weight
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
crd_weight, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Weight coefficient to calculate effectiveness of index from cardinality of column.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
double spider_param_crd_weight(
|
|
THD *thd,
|
|
double crd_weight
|
|
) {
|
|
DBUG_ENTER("spider_param_crd_weight");
|
|
DBUG_RETURN(THDVAR(thd, crd_weight) == -1 ?
|
|
crd_weight : THDVAR(thd, crd_weight));
|
|
}
|
|
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
/*
|
|
-1 :use table parameter
|
|
0 :Background confirmation is disabled
|
|
1 :Background confirmation is enabled
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
crd_bg_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of cardinality confirmation at background.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_crd_bg_mode(
|
|
THD *thd,
|
|
int crd_bg_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_crd_bg_mode");
|
|
DBUG_RETURN(THDVAR(thd, crd_bg_mode) == -1 ?
|
|
crd_bg_mode : THDVAR(thd, crd_bg_mode));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :always get the newest information
|
|
1-:interval
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
sts_interval, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Interval of table state confirmation.(second)", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
double spider_param_sts_interval(
|
|
THD *thd,
|
|
double sts_interval
|
|
) {
|
|
DBUG_ENTER("spider_param_sts_interval");
|
|
DBUG_RETURN(THDVAR(thd, sts_interval) == -1 ?
|
|
sts_interval : THDVAR(thd, sts_interval));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :use table parameter
|
|
1 :use show command
|
|
2 :use information schema
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
sts_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of table state confirmation.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_sts_mode(
|
|
THD *thd,
|
|
int sts_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_sts_mode");
|
|
DBUG_RETURN(THDVAR(thd, sts_mode) <= 0 ?
|
|
sts_mode : THDVAR(thd, sts_mode));
|
|
}
|
|
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
/*
|
|
-1 :use table parameter
|
|
0 :No synchronization.
|
|
1 :Table state is synchronized when opening a table.
|
|
Then no synchronization.
|
|
2 :Synchronization.
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
sts_sync, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Table state synchronization in partitioned table.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_sts_sync(
|
|
THD *thd,
|
|
int sts_sync
|
|
) {
|
|
DBUG_ENTER("spider_param_sts_sync");
|
|
DBUG_RETURN(THDVAR(thd, sts_sync) == -1 ?
|
|
sts_sync : THDVAR(thd, sts_sync));
|
|
}
|
|
#endif
|
|
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
/*
|
|
-1 :use table parameter
|
|
0 :Background confirmation is disabled
|
|
1 :Background confirmation is enabled
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
sts_bg_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of table state confirmation at background.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_sts_bg_mode(
|
|
THD *thd,
|
|
int sts_bg_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_sts_bg_mode");
|
|
DBUG_RETURN(THDVAR(thd, sts_bg_mode) == -1 ?
|
|
sts_bg_mode : THDVAR(thd, sts_bg_mode));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
0 :always ping
|
|
1-:interval
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
ping_interval_at_trx_start, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Ping interval at transaction start", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
3600, /* def */
|
|
0, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
double spider_param_ping_interval_at_trx_start(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_ping_interval_at_trx_start");
|
|
DBUG_RETURN(THDVAR(thd, ping_interval_at_trx_start));
|
|
}
|
|
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
/*
|
|
0 :always ping
|
|
1-:interval
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
hs_ping_interval, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Ping interval for handlersocket", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
30, /* def */
|
|
0, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
double spider_param_hs_ping_interval(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_hs_ping_interval");
|
|
DBUG_RETURN(THDVAR(thd, hs_ping_interval));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :normal mode
|
|
1 :quick mode
|
|
2 :set 0 value
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
auto_increment_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of auto increment.", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_auto_increment_mode(
|
|
THD *thd,
|
|
int auto_increment_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_auto_increment_mode");
|
|
DBUG_RETURN(THDVAR(thd, auto_increment_mode) == -1 ?
|
|
auto_increment_mode : THDVAR(thd, auto_increment_mode));
|
|
}
|
|
|
|
/*
|
|
FALSE: off
|
|
TRUE: on
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
same_server_link, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Permit to link same server's table", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_same_server_link(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_same_server_link");
|
|
DBUG_RETURN(THDVAR(thd, same_server_link));
|
|
}
|
|
|
|
/*
|
|
FALSE: transmits
|
|
TRUE: don't transmit
|
|
*/
|
|
static MYSQL_THDVAR_BOOL(
|
|
local_lock_table, /* name */
|
|
PLUGIN_VAR_OPCMDARG, /* opt */
|
|
"Remote server transmission when lock tables is executed at local",
|
|
/* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
FALSE /* def */
|
|
);
|
|
|
|
bool spider_param_local_lock_table(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_local_lock_table");
|
|
DBUG_RETURN(THDVAR(thd, local_lock_table));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :don't transmit
|
|
1 :transmits
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
use_pushdown_udf, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Remote server transmission existence when UDF is used at condition and \"engine_condition_pushdown=1\"", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_use_pushdown_udf(
|
|
THD *thd,
|
|
int use_pushdown_udf
|
|
) {
|
|
DBUG_ENTER("spider_param_use_pushdown_udf");
|
|
DBUG_RETURN(THDVAR(thd, use_pushdown_udf) == -1 ?
|
|
use_pushdown_udf : THDVAR(thd, use_pushdown_udf));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :duplicate check on local server
|
|
1 :avoid duplicate check on local server
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
direct_dup_insert, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Execute \"REPLACE\" and \"INSERT IGNORE\" on remote server and avoid duplicate check on local server", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_direct_dup_insert(
|
|
THD *thd,
|
|
int direct_dup_insert
|
|
) {
|
|
DBUG_ENTER("spider_param_direct_dup_insert");
|
|
DBUG_RETURN(THDVAR(thd, direct_dup_insert) < 0 ?
|
|
direct_dup_insert : THDVAR(thd, direct_dup_insert));
|
|
}
|
|
|
|
static uint spider_udf_table_lock_mutex_count;
|
|
/*
|
|
1-: mutex count
|
|
*/
|
|
static MYSQL_SYSVAR_UINT(
|
|
udf_table_lock_mutex_count,
|
|
spider_udf_table_lock_mutex_count,
|
|
PLUGIN_VAR_RQCMDARG | PLUGIN_VAR_READONLY,
|
|
"Mutex count of table lock for Spider UDFs",
|
|
NULL,
|
|
NULL,
|
|
20,
|
|
1,
|
|
4294967295U,
|
|
0
|
|
);
|
|
|
|
uint spider_param_udf_table_lock_mutex_count()
|
|
{
|
|
DBUG_ENTER("spider_param_udf_table_lock_mutex_count");
|
|
DBUG_RETURN(spider_udf_table_lock_mutex_count);
|
|
}
|
|
|
|
static uint spider_udf_table_mon_mutex_count;
|
|
/*
|
|
1-: mutex count
|
|
*/
|
|
static MYSQL_SYSVAR_UINT(
|
|
udf_table_mon_mutex_count,
|
|
spider_udf_table_mon_mutex_count,
|
|
PLUGIN_VAR_RQCMDARG | PLUGIN_VAR_READONLY,
|
|
"Mutex count of table mon for Spider UDFs",
|
|
NULL,
|
|
NULL,
|
|
20,
|
|
1,
|
|
4294967295U,
|
|
0
|
|
);
|
|
|
|
uint spider_param_udf_table_mon_mutex_count()
|
|
{
|
|
DBUG_ENTER("spider_param_udf_table_mon_mutex_count");
|
|
DBUG_RETURN(spider_udf_table_mon_mutex_count);
|
|
}
|
|
|
|
/*
|
|
1-:number of rows
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
udf_ds_bulk_insert_rows, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Number of rows for bulk inserting", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_udf_ds_bulk_insert_rows(
|
|
THD *thd,
|
|
longlong udf_ds_bulk_insert_rows
|
|
) {
|
|
DBUG_ENTER("spider_param_udf_ds_bulk_insert_rows");
|
|
DBUG_RETURN(THDVAR(thd, udf_ds_bulk_insert_rows) <= 0 ?
|
|
udf_ds_bulk_insert_rows : THDVAR(thd, udf_ds_bulk_insert_rows));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :drop records
|
|
1 :insert last table
|
|
2 :insert first table and loop again
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
udf_ds_table_loop_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Table loop mode if the number of tables in table list are less than the number of result sets", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_udf_ds_table_loop_mode(
|
|
THD *thd,
|
|
int udf_ds_table_loop_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_udf_ds_table_loop_mode");
|
|
DBUG_RETURN(THDVAR(thd, udf_ds_table_loop_mode) == -1 ?
|
|
udf_ds_table_loop_mode : THDVAR(thd, udf_ds_table_loop_mode));
|
|
}
|
|
|
|
static char *spider_remote_access_charset;
|
|
/*
|
|
*/
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100000
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_access_charset,
|
|
spider_remote_access_charset,
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote access charset at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#else
|
|
#ifdef PLUGIN_VAR_CAN_MEMALLOC
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_access_charset,
|
|
spider_remote_access_charset,
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote access charset at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#else
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_access_charset,
|
|
spider_remote_access_charset,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote access charset at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#endif
|
|
#endif
|
|
|
|
char *spider_param_remote_access_charset()
|
|
{
|
|
DBUG_ENTER("spider_param_remote_access_charset");
|
|
DBUG_RETURN(spider_remote_access_charset);
|
|
}
|
|
|
|
static int spider_remote_autocommit;
|
|
/*
|
|
-1 :don't set
|
|
0 :autocommit = 0
|
|
1 :autocommit = 1
|
|
*/
|
|
static MYSQL_SYSVAR_INT(
|
|
remote_autocommit,
|
|
spider_remote_autocommit,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set autocommit mode at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
1,
|
|
0
|
|
);
|
|
|
|
int spider_param_remote_autocommit()
|
|
{
|
|
DBUG_ENTER("spider_param_remote_autocommit");
|
|
DBUG_RETURN(spider_remote_autocommit);
|
|
}
|
|
|
|
static char *spider_remote_time_zone;
|
|
/*
|
|
*/
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100000
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_time_zone,
|
|
spider_remote_time_zone,
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote time_zone at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#else
|
|
#ifdef PLUGIN_VAR_CAN_MEMALLOC
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_time_zone,
|
|
spider_remote_time_zone,
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote time_zone at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#else
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_time_zone,
|
|
spider_remote_time_zone,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote time_zone at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#endif
|
|
#endif
|
|
|
|
char *spider_param_remote_time_zone()
|
|
{
|
|
DBUG_ENTER("spider_param_remote_time_zone");
|
|
DBUG_RETURN(spider_remote_time_zone);
|
|
}
|
|
|
|
static int spider_remote_sql_log_off;
|
|
/*
|
|
-1 :don't set
|
|
0 :sql_log_off = 0
|
|
1 :sql_log_off = 1
|
|
*/
|
|
static MYSQL_SYSVAR_INT(
|
|
remote_sql_log_off,
|
|
spider_remote_sql_log_off,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set sql_log_off mode at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
1,
|
|
0
|
|
);
|
|
|
|
int spider_param_remote_sql_log_off()
|
|
{
|
|
DBUG_ENTER("spider_param_remote_sql_log_off");
|
|
DBUG_RETURN(spider_remote_sql_log_off);
|
|
}
|
|
|
|
static int spider_remote_trx_isolation;
|
|
/*
|
|
-1 :don't set
|
|
0 :READ UNCOMMITTED
|
|
1 :READ COMMITTED
|
|
2 :REPEATABLE READ
|
|
3 :SERIALIZABLE
|
|
*/
|
|
static MYSQL_SYSVAR_INT(
|
|
remote_trx_isolation,
|
|
spider_remote_trx_isolation,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set transaction isolation level at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
3,
|
|
0
|
|
);
|
|
|
|
int spider_param_remote_trx_isolation()
|
|
{
|
|
DBUG_ENTER("spider_param_remote_trx_isolation");
|
|
DBUG_RETURN(spider_remote_trx_isolation);
|
|
}
|
|
|
|
static char *spider_remote_default_database;
|
|
/*
|
|
*/
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100000
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_default_database,
|
|
spider_remote_default_database,
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote database at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#else
|
|
#ifdef PLUGIN_VAR_CAN_MEMALLOC
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_default_database,
|
|
spider_remote_default_database,
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote database at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#else
|
|
static MYSQL_SYSVAR_STR(
|
|
remote_default_database,
|
|
spider_remote_default_database,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Set remote database at connecting for improvement performance of connection if you know",
|
|
NULL,
|
|
NULL,
|
|
NULL
|
|
);
|
|
#endif
|
|
#endif
|
|
|
|
char *spider_param_remote_default_database()
|
|
{
|
|
DBUG_ENTER("spider_param_remote_default_database");
|
|
DBUG_RETURN(spider_remote_default_database);
|
|
}
|
|
|
|
/*
|
|
0-:connect retry interval (micro second)
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
connect_retry_interval, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Connect retry interval", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
1000, /* def */
|
|
0, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_connect_retry_interval(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_connect_retry_interval");
|
|
if (thd)
|
|
DBUG_RETURN(THDVAR(thd, connect_retry_interval));
|
|
DBUG_RETURN(0);
|
|
}
|
|
|
|
/*
|
|
0-:connect retry count
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
connect_retry_count, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Connect retry count", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
1000, /* def */
|
|
0, /* min */
|
|
2147483647, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_connect_retry_count(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_connect_retry_count");
|
|
if (thd)
|
|
DBUG_RETURN(THDVAR(thd, connect_retry_count));
|
|
DBUG_RETURN(0);
|
|
}
|
|
|
|
/*
|
|
*/
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100000
|
|
static MYSQL_THDVAR_STR(
|
|
bka_engine, /* name */
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Temporary table's engine for BKA", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
NULL /* def */
|
|
);
|
|
#else
|
|
#ifdef PLUGIN_VAR_CAN_MEMALLOC
|
|
static MYSQL_THDVAR_STR(
|
|
bka_engine, /* name */
|
|
PLUGIN_VAR_MEMALLOC |
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Temporary table's engine for BKA", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
NULL /* def */
|
|
);
|
|
#else
|
|
static MYSQL_THDVAR_STR(
|
|
bka_engine, /* name */
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Temporary table's engine for BKA", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
NULL /* def */
|
|
);
|
|
#endif
|
|
#endif
|
|
|
|
char *spider_param_bka_engine(
|
|
THD *thd,
|
|
char *bka_engine
|
|
) {
|
|
DBUG_ENTER("spider_param_bka_engine");
|
|
DBUG_RETURN(THDVAR(thd, bka_engine) ?
|
|
THDVAR(thd, bka_engine) : bka_engine);
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :use union all
|
|
1 :use temporary table
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
bka_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Mode of BKA for Spider", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_bka_mode(
|
|
THD *thd,
|
|
int bka_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_bka_mode");
|
|
DBUG_RETURN(THDVAR(thd, bka_mode) == -1 ?
|
|
bka_mode : THDVAR(thd, bka_mode));
|
|
}
|
|
|
|
static int spider_udf_ct_bulk_insert_interval;
|
|
/*
|
|
-1 : The UDF parameter is adopted.
|
|
0 or more : Milliseconds.
|
|
*/
|
|
static MYSQL_SYSVAR_INT(
|
|
udf_ct_bulk_insert_interval,
|
|
spider_udf_ct_bulk_insert_interval,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"The interval time between bulk insert and next bulk insert at coping",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
2147483647,
|
|
0
|
|
);
|
|
|
|
int spider_param_udf_ct_bulk_insert_interval(
|
|
int udf_ct_bulk_insert_interval
|
|
) {
|
|
DBUG_ENTER("spider_param_udf_ct_bulk_insert_interval");
|
|
DBUG_RETURN(spider_udf_ct_bulk_insert_interval < 0 ?
|
|
udf_ct_bulk_insert_interval : spider_udf_ct_bulk_insert_interval);
|
|
}
|
|
|
|
static longlong spider_udf_ct_bulk_insert_rows;
|
|
/*
|
|
-1,0 : The UDF parameter is adopted.
|
|
1 or more : Number of rows.
|
|
*/
|
|
static MYSQL_SYSVAR_LONGLONG(
|
|
udf_ct_bulk_insert_rows,
|
|
spider_udf_ct_bulk_insert_rows,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"The number of rows inserted with bulk insert of one time at coping",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
9223372036854775807LL,
|
|
0
|
|
);
|
|
|
|
longlong spider_param_udf_ct_bulk_insert_rows(
|
|
longlong udf_ct_bulk_insert_rows
|
|
) {
|
|
DBUG_ENTER("spider_param_udf_ct_bulk_insert_rows");
|
|
DBUG_RETURN(spider_udf_ct_bulk_insert_rows <= 0 ?
|
|
udf_ct_bulk_insert_rows : spider_udf_ct_bulk_insert_rows);
|
|
}
|
|
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
/*
|
|
0: no recycle
|
|
1: recycle in instance
|
|
2: recycle in thread
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
hs_r_conn_recycle_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Handlersocket connection recycle mode", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
2, /* def */
|
|
0, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_hs_r_conn_recycle_mode(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_hs_r_conn_recycle_mode");
|
|
DBUG_RETURN(THDVAR(thd, hs_r_conn_recycle_mode));
|
|
}
|
|
|
|
/*
|
|
0: weak
|
|
1: strict
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
hs_r_conn_recycle_strict, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Strict handlersocket connection recycle", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_hs_r_conn_recycle_strict(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_hs_r_conn_recycle_strict");
|
|
DBUG_RETURN(THDVAR(thd, hs_r_conn_recycle_strict));
|
|
}
|
|
|
|
/*
|
|
0: no recycle
|
|
1: recycle in instance
|
|
2: recycle in thread
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
hs_w_conn_recycle_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Handlersocket connection recycle mode", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
2, /* def */
|
|
0, /* min */
|
|
2, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_hs_w_conn_recycle_mode(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_hs_w_conn_recycle_mode");
|
|
DBUG_RETURN(THDVAR(thd, hs_w_conn_recycle_mode));
|
|
}
|
|
|
|
/*
|
|
0: weak
|
|
1: strict
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
hs_w_conn_recycle_strict, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Strict handlersocket connection recycle", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_hs_w_conn_recycle_strict(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_hs_w_conn_recycle_strict");
|
|
DBUG_RETURN(THDVAR(thd, hs_w_conn_recycle_strict));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :not use
|
|
1 :use handlersocket
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
use_hs_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use handlersocket for reading", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_use_hs_read(
|
|
THD *thd,
|
|
int use_hs_read
|
|
) {
|
|
DBUG_ENTER("spider_param_use_hs_read");
|
|
DBUG_RETURN(THDVAR(thd, use_hs_read) == -1 ?
|
|
use_hs_read : THDVAR(thd, use_hs_read));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :not use
|
|
1 :use handlersocket
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
use_hs_write, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use handlersocket for writing", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_use_hs_write(
|
|
THD *thd,
|
|
int use_hs_write
|
|
) {
|
|
DBUG_ENTER("spider_param_use_hs_write");
|
|
DBUG_RETURN(THDVAR(thd, use_hs_write) == -1 ?
|
|
use_hs_write : THDVAR(thd, use_hs_write));
|
|
}
|
|
#endif
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :not use
|
|
1 :use handler
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
use_handler, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use handler for reading", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
3, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_use_handler(
|
|
THD *thd,
|
|
int use_handler
|
|
) {
|
|
DBUG_ENTER("spider_param_use_handler");
|
|
DBUG_RETURN(THDVAR(thd, use_handler) == -1 ?
|
|
use_handler : THDVAR(thd, use_handler));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :return error if error
|
|
1 :return 0 record if error
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
error_read_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Read error mode if error", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_error_read_mode(
|
|
THD *thd,
|
|
int error_read_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_error_read_mode");
|
|
DBUG_RETURN(THDVAR(thd, error_read_mode) == -1 ?
|
|
error_read_mode : THDVAR(thd, error_read_mode));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :return error if error
|
|
1 :return 0 record if error
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
error_write_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Write error mode if error", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_error_write_mode(
|
|
THD *thd,
|
|
int error_write_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_error_write_mode");
|
|
DBUG_RETURN(THDVAR(thd, error_write_mode) == -1 ?
|
|
error_write_mode : THDVAR(thd, error_write_mode));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :not skip
|
|
1 :skip
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
skip_default_condition, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Skip generating internal default condition", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_skip_default_condition(
|
|
THD *thd,
|
|
int skip_default_condition
|
|
) {
|
|
DBUG_ENTER("spider_param_skip_default_condition");
|
|
DBUG_RETURN(THDVAR(thd, skip_default_condition) == -1 ?
|
|
skip_default_condition : THDVAR(thd, skip_default_condition));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :not send directly
|
|
1-:send directly
|
|
*/
|
|
static MYSQL_THDVAR_LONGLONG(
|
|
direct_order_limit, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Send 'ORDER BY' and 'LIMIT' to remote server directly", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
9223372036854775807LL, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
longlong spider_param_direct_order_limit(
|
|
THD *thd,
|
|
longlong direct_order_limit
|
|
) {
|
|
DBUG_ENTER("spider_param_direct_order_limit");
|
|
DBUG_RETURN(THDVAR(thd, direct_order_limit) == -1 ?
|
|
direct_order_limit : THDVAR(thd, direct_order_limit));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :writable
|
|
1 :read only
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
read_only_mode, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Read only", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_read_only_mode(
|
|
THD *thd,
|
|
int read_only_mode
|
|
) {
|
|
DBUG_ENTER("spider_param_read_only_mode");
|
|
DBUG_RETURN(THDVAR(thd, read_only_mode) == -1 ?
|
|
read_only_mode : THDVAR(thd, read_only_mode));
|
|
}
|
|
|
|
#ifdef HA_CAN_BULK_ACCESS
|
|
static int spider_bulk_access_free;
|
|
/*
|
|
-1 :use table parameter
|
|
0 :in reset
|
|
1 :in close
|
|
*/
|
|
static MYSQL_SYSVAR_INT(
|
|
bulk_access_free,
|
|
spider_bulk_access_free,
|
|
PLUGIN_VAR_RQCMDARG | PLUGIN_VAR_READONLY,
|
|
"Free mode of bulk access resources",
|
|
NULL,
|
|
NULL,
|
|
-1,
|
|
-1,
|
|
1,
|
|
0
|
|
);
|
|
|
|
int spider_param_bulk_access_free(
|
|
int bulk_access_free
|
|
) {
|
|
DBUG_ENTER("spider_param_bulk_access_free");
|
|
DBUG_RETURN(spider_bulk_access_free == -1 ?
|
|
bulk_access_free : spider_bulk_access_free);
|
|
}
|
|
#endif
|
|
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#else
|
|
/*
|
|
-1 :use UDF parameter
|
|
0 :can not use
|
|
1 :can use
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
udf_ds_use_real_table, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Use real table for temporary table list", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_udf_ds_use_real_table(
|
|
THD *thd,
|
|
int udf_ds_use_real_table
|
|
) {
|
|
DBUG_ENTER("spider_param_udf_ds_use_real_table");
|
|
DBUG_RETURN(THDVAR(thd, udf_ds_use_real_table) == -1 ?
|
|
udf_ds_use_real_table : THDVAR(thd, udf_ds_use_real_table));
|
|
}
|
|
#endif
|
|
|
|
static my_bool spider_general_log;
|
|
static MYSQL_SYSVAR_BOOL(
|
|
general_log,
|
|
spider_general_log,
|
|
PLUGIN_VAR_OPCMDARG,
|
|
"Log query to remote server in general log",
|
|
NULL,
|
|
NULL,
|
|
FALSE
|
|
);
|
|
|
|
my_bool spider_param_general_log()
|
|
{
|
|
DBUG_ENTER("spider_param_general_log");
|
|
DBUG_RETURN(spider_general_log);
|
|
}
|
|
|
|
static uint spider_log_result_errors;
|
|
/*
|
|
0: no log
|
|
1: log error
|
|
2: log warning summary
|
|
3: log warning
|
|
4: log info
|
|
*/
|
|
static MYSQL_SYSVAR_UINT(
|
|
log_result_errors,
|
|
spider_log_result_errors,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Log error from remote server in error log",
|
|
NULL,
|
|
NULL,
|
|
0,
|
|
0,
|
|
4,
|
|
0
|
|
);
|
|
|
|
uint spider_param_log_result_errors()
|
|
{
|
|
DBUG_ENTER("spider_param_log_result_errors");
|
|
DBUG_RETURN(spider_log_result_errors);
|
|
}
|
|
|
|
static uint spider_log_result_error_with_sql;
|
|
/*
|
|
0: no log
|
|
1: log spider sql at logging result errors
|
|
2: log user sql at logging result errors
|
|
3: log both sql at logging result errors
|
|
*/
|
|
static MYSQL_SYSVAR_UINT(
|
|
log_result_error_with_sql,
|
|
spider_log_result_error_with_sql,
|
|
PLUGIN_VAR_RQCMDARG,
|
|
"Log sql at logging result errors",
|
|
NULL,
|
|
NULL,
|
|
0,
|
|
0,
|
|
3,
|
|
0
|
|
);
|
|
|
|
uint spider_param_log_result_error_with_sql()
|
|
{
|
|
DBUG_ENTER("spider_param_log_result_error_with_sql");
|
|
DBUG_RETURN(spider_log_result_error_with_sql);
|
|
}
|
|
|
|
static char *spider_version = (char *) SPIDER_DETAIL_VERSION;
|
|
static MYSQL_SYSVAR_STR(
|
|
version,
|
|
spider_version,
|
|
PLUGIN_VAR_NOCMDOPT | PLUGIN_VAR_READONLY,
|
|
"The version of Spider",
|
|
NULL,
|
|
NULL,
|
|
SPIDER_DETAIL_VERSION
|
|
);
|
|
|
|
/*
|
|
0: server_id + thread_id
|
|
1: server_id + thread_id + query_id
|
|
*/
|
|
static MYSQL_THDVAR_UINT(
|
|
internal_xa_id_type, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"The type of internal_xa id", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
0, /* def */
|
|
0, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
uint spider_param_internal_xa_id_type(
|
|
THD *thd
|
|
) {
|
|
DBUG_ENTER("spider_param_internal_xa_id_type");
|
|
DBUG_RETURN(THDVAR(thd, internal_xa_id_type));
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :OFF
|
|
1 :automatic channel
|
|
2-63 :use custom channel
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
casual_read, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"Read casually if it is possible", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
63, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_casual_read(
|
|
THD *thd,
|
|
int casual_read
|
|
) {
|
|
DBUG_ENTER("spider_param_casual_read");
|
|
DBUG_RETURN(THDVAR(thd, casual_read) == -1 ?
|
|
casual_read : THDVAR(thd, casual_read));
|
|
}
|
|
|
|
static my_bool spider_dry_access;
|
|
static MYSQL_SYSVAR_BOOL(
|
|
dry_access,
|
|
spider_dry_access,
|
|
PLUGIN_VAR_OPCMDARG | PLUGIN_VAR_READONLY,
|
|
"dry access",
|
|
NULL,
|
|
NULL,
|
|
FALSE
|
|
);
|
|
|
|
my_bool spider_param_dry_access()
|
|
{
|
|
DBUG_ENTER("spider_param_dry_access");
|
|
DBUG_RETURN(spider_dry_access);
|
|
}
|
|
|
|
/*
|
|
-1 :use table parameter
|
|
0 :fast
|
|
1 :correct delete row number
|
|
*/
|
|
static MYSQL_THDVAR_INT(
|
|
delete_all_rows_type, /* name */
|
|
PLUGIN_VAR_RQCMDARG, /* opt */
|
|
"The type of delete_all_rows", /* comment */
|
|
NULL, /* check */
|
|
NULL, /* update */
|
|
-1, /* def */
|
|
-1, /* min */
|
|
1, /* max */
|
|
0 /* blk */
|
|
);
|
|
|
|
int spider_param_delete_all_rows_type(
|
|
THD *thd,
|
|
int delete_all_rows_type
|
|
) {
|
|
DBUG_ENTER("spider_param_delete_all_rows_type");
|
|
DBUG_RETURN(THDVAR(thd, delete_all_rows_type) == -1 ?
|
|
delete_all_rows_type : THDVAR(thd, delete_all_rows_type));
|
|
}
|
|
|
|
static struct st_mysql_storage_engine spider_storage_engine =
|
|
{ MYSQL_HANDLERTON_INTERFACE_VERSION };
|
|
|
|
static struct st_mysql_sys_var* spider_system_variables[] = {
|
|
MYSQL_SYSVAR(support_xa),
|
|
MYSQL_SYSVAR(table_init_error_interval),
|
|
MYSQL_SYSVAR(use_table_charset),
|
|
MYSQL_SYSVAR(conn_recycle_mode),
|
|
MYSQL_SYSVAR(conn_recycle_strict),
|
|
MYSQL_SYSVAR(sync_trx_isolation),
|
|
MYSQL_SYSVAR(use_consistent_snapshot),
|
|
MYSQL_SYSVAR(internal_xa),
|
|
MYSQL_SYSVAR(internal_xa_snapshot),
|
|
MYSQL_SYSVAR(force_commit),
|
|
MYSQL_SYSVAR(internal_offset),
|
|
MYSQL_SYSVAR(internal_limit),
|
|
MYSQL_SYSVAR(split_read),
|
|
MYSQL_SYSVAR(semi_split_read),
|
|
MYSQL_SYSVAR(semi_split_read_limit),
|
|
MYSQL_SYSVAR(init_sql_alloc_size),
|
|
MYSQL_SYSVAR(reset_sql_alloc),
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
MYSQL_SYSVAR(hs_result_free_size),
|
|
#endif
|
|
MYSQL_SYSVAR(multi_split_read),
|
|
MYSQL_SYSVAR(max_order),
|
|
MYSQL_SYSVAR(semi_trx_isolation),
|
|
MYSQL_SYSVAR(semi_table_lock),
|
|
MYSQL_SYSVAR(semi_table_lock_connection),
|
|
MYSQL_SYSVAR(block_size),
|
|
MYSQL_SYSVAR(selupd_lock_mode),
|
|
MYSQL_SYSVAR(sync_autocommit),
|
|
MYSQL_SYSVAR(sync_time_zone),
|
|
MYSQL_SYSVAR(use_default_database),
|
|
MYSQL_SYSVAR(internal_sql_log_off),
|
|
MYSQL_SYSVAR(bulk_size),
|
|
MYSQL_SYSVAR(bulk_update_mode),
|
|
MYSQL_SYSVAR(bulk_update_size),
|
|
MYSQL_SYSVAR(internal_optimize),
|
|
MYSQL_SYSVAR(internal_optimize_local),
|
|
MYSQL_SYSVAR(use_flash_logs),
|
|
MYSQL_SYSVAR(use_snapshot_with_flush_tables),
|
|
MYSQL_SYSVAR(use_all_conns_snapshot),
|
|
MYSQL_SYSVAR(lock_exchange),
|
|
MYSQL_SYSVAR(internal_unlock),
|
|
MYSQL_SYSVAR(semi_trx),
|
|
MYSQL_SYSVAR(connect_timeout),
|
|
MYSQL_SYSVAR(net_read_timeout),
|
|
MYSQL_SYSVAR(net_write_timeout),
|
|
MYSQL_SYSVAR(quick_mode),
|
|
MYSQL_SYSVAR(quick_page_size),
|
|
MYSQL_SYSVAR(low_mem_read),
|
|
MYSQL_SYSVAR(select_column_mode),
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
MYSQL_SYSVAR(bgs_mode),
|
|
MYSQL_SYSVAR(bgs_first_read),
|
|
MYSQL_SYSVAR(bgs_second_read),
|
|
#endif
|
|
MYSQL_SYSVAR(first_read),
|
|
MYSQL_SYSVAR(second_read),
|
|
MYSQL_SYSVAR(crd_interval),
|
|
MYSQL_SYSVAR(crd_mode),
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
MYSQL_SYSVAR(crd_sync),
|
|
#endif
|
|
MYSQL_SYSVAR(crd_type),
|
|
MYSQL_SYSVAR(crd_weight),
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
MYSQL_SYSVAR(crd_bg_mode),
|
|
#endif
|
|
MYSQL_SYSVAR(sts_interval),
|
|
MYSQL_SYSVAR(sts_mode),
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
MYSQL_SYSVAR(sts_sync),
|
|
#endif
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
MYSQL_SYSVAR(sts_bg_mode),
|
|
#endif
|
|
MYSQL_SYSVAR(ping_interval_at_trx_start),
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
MYSQL_SYSVAR(hs_ping_interval),
|
|
#endif
|
|
MYSQL_SYSVAR(auto_increment_mode),
|
|
MYSQL_SYSVAR(same_server_link),
|
|
MYSQL_SYSVAR(local_lock_table),
|
|
MYSQL_SYSVAR(use_pushdown_udf),
|
|
MYSQL_SYSVAR(direct_dup_insert),
|
|
MYSQL_SYSVAR(udf_table_lock_mutex_count),
|
|
MYSQL_SYSVAR(udf_table_mon_mutex_count),
|
|
MYSQL_SYSVAR(udf_ds_bulk_insert_rows),
|
|
MYSQL_SYSVAR(udf_ds_table_loop_mode),
|
|
MYSQL_SYSVAR(remote_access_charset),
|
|
MYSQL_SYSVAR(remote_autocommit),
|
|
MYSQL_SYSVAR(remote_time_zone),
|
|
MYSQL_SYSVAR(remote_sql_log_off),
|
|
MYSQL_SYSVAR(remote_trx_isolation),
|
|
MYSQL_SYSVAR(remote_default_database),
|
|
MYSQL_SYSVAR(connect_retry_interval),
|
|
MYSQL_SYSVAR(connect_retry_count),
|
|
MYSQL_SYSVAR(connect_mutex),
|
|
MYSQL_SYSVAR(bka_engine),
|
|
MYSQL_SYSVAR(bka_mode),
|
|
MYSQL_SYSVAR(udf_ct_bulk_insert_interval),
|
|
MYSQL_SYSVAR(udf_ct_bulk_insert_rows),
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
MYSQL_SYSVAR(hs_r_conn_recycle_mode),
|
|
MYSQL_SYSVAR(hs_r_conn_recycle_strict),
|
|
MYSQL_SYSVAR(hs_w_conn_recycle_mode),
|
|
MYSQL_SYSVAR(hs_w_conn_recycle_strict),
|
|
MYSQL_SYSVAR(use_hs_read),
|
|
MYSQL_SYSVAR(use_hs_write),
|
|
#endif
|
|
MYSQL_SYSVAR(use_handler),
|
|
MYSQL_SYSVAR(error_read_mode),
|
|
MYSQL_SYSVAR(error_write_mode),
|
|
MYSQL_SYSVAR(skip_default_condition),
|
|
MYSQL_SYSVAR(direct_order_limit),
|
|
MYSQL_SYSVAR(read_only_mode),
|
|
#ifdef HA_CAN_BULK_ACCESS
|
|
MYSQL_SYSVAR(bulk_access_free),
|
|
#endif
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#else
|
|
MYSQL_SYSVAR(udf_ds_use_real_table),
|
|
#endif
|
|
MYSQL_SYSVAR(general_log),
|
|
MYSQL_SYSVAR(log_result_errors),
|
|
MYSQL_SYSVAR(log_result_error_with_sql),
|
|
MYSQL_SYSVAR(version),
|
|
MYSQL_SYSVAR(internal_xa_id_type),
|
|
MYSQL_SYSVAR(casual_read),
|
|
MYSQL_SYSVAR(dry_access),
|
|
MYSQL_SYSVAR(delete_all_rows_type),
|
|
NULL
|
|
};
|
|
|
|
mysql_declare_plugin(spider)
|
|
{
|
|
MYSQL_STORAGE_ENGINE_PLUGIN,
|
|
&spider_storage_engine,
|
|
"SPIDER",
|
|
"Kentoku Shiba",
|
|
"Spider storage engine",
|
|
PLUGIN_LICENSE_GPL,
|
|
spider_db_init,
|
|
spider_db_done,
|
|
SPIDER_HEX_VERSION,
|
|
spider_status_variables,
|
|
spider_system_variables,
|
|
NULL,
|
|
#if MYSQL_VERSION_ID >= 50600
|
|
0,
|
|
#endif
|
|
},
|
|
spider_i_s_alloc_mem
|
|
mysql_declare_plugin_end;
|
|
|
|
#ifdef MARIADB_BASE_VERSION
|
|
maria_declare_plugin(spider)
|
|
{
|
|
MYSQL_STORAGE_ENGINE_PLUGIN,
|
|
&spider_storage_engine,
|
|
"SPIDER",
|
|
"Kentoku Shiba",
|
|
"Spider storage engine",
|
|
PLUGIN_LICENSE_GPL,
|
|
spider_db_init,
|
|
spider_db_done,
|
|
SPIDER_HEX_VERSION,
|
|
spider_status_variables,
|
|
spider_system_variables,
|
|
SPIDER_DETAIL_VERSION,
|
|
MariaDB_PLUGIN_MATURITY_GAMMA
|
|
},
|
|
spider_i_s_alloc_mem_maria
|
|
maria_declare_plugin_end;
|
|
#endif
|