mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 05:22:25 +01:00
8fdeb079b9
When an attempt to connect to the remote server fails, Spider retries to
connect to the remote server 1000 times or until the connection attempt
succeeds. This is perceived as a hang if the remote server remains
unavailable.
I have introduced changes in Spider's table status handler to fix this problem.
Author:
Jacob Mathew.
Reviewer:
Kentoku Shiba.
Cherry-Picked:
Commit 6ee6933
on branch bb-10.3-MDEV-15712
1281 lines
44 KiB
C++
1281 lines
44 KiB
C++
/* Copyright (C) 2008-2015 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., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA */
|
|
|
|
#define SPIDER_DETAIL_VERSION "3.2.37"
|
|
#define SPIDER_HEX_VERSION 0x0302
|
|
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#else
|
|
#define my_free(A,B) my_free(A)
|
|
#ifdef pthread_mutex_t
|
|
#undef pthread_mutex_t
|
|
#endif
|
|
#define pthread_mutex_t mysql_mutex_t
|
|
#ifdef pthread_mutex_lock
|
|
#undef pthread_mutex_lock
|
|
#endif
|
|
#define pthread_mutex_lock mysql_mutex_lock
|
|
#ifdef pthread_mutex_trylock
|
|
#undef pthread_mutex_trylock
|
|
#endif
|
|
#define pthread_mutex_trylock mysql_mutex_trylock
|
|
#ifdef pthread_mutex_unlock
|
|
#undef pthread_mutex_unlock
|
|
#endif
|
|
#define pthread_mutex_unlock mysql_mutex_unlock
|
|
#ifdef pthread_mutex_destroy
|
|
#undef pthread_mutex_destroy
|
|
#endif
|
|
#define pthread_mutex_destroy mysql_mutex_destroy
|
|
#ifdef pthread_cond_t
|
|
#undef pthread_cond_t
|
|
#endif
|
|
#define pthread_cond_t mysql_cond_t
|
|
#ifdef pthread_cond_wait
|
|
#undef pthread_cond_wait
|
|
#endif
|
|
#define pthread_cond_wait mysql_cond_wait
|
|
#ifdef pthread_cond_timedwait
|
|
#undef pthread_cond_timedwait
|
|
#endif
|
|
#define pthread_cond_timedwait mysql_cond_timedwait
|
|
#ifdef pthread_cond_signal
|
|
#undef pthread_cond_signal
|
|
#endif
|
|
#define pthread_cond_signal mysql_cond_signal
|
|
#ifdef pthread_cond_broadcast
|
|
#undef pthread_cond_broadcast
|
|
#endif
|
|
#define pthread_cond_broadcast mysql_cond_broadcast
|
|
#ifdef pthread_cond_destroy
|
|
#undef pthread_cond_destroy
|
|
#endif
|
|
#define pthread_cond_destroy mysql_cond_destroy
|
|
#define my_sprintf(A,B) sprintf B
|
|
#endif
|
|
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100004
|
|
#define spider_stmt_da_message(A) thd_get_error_message(A)
|
|
#define spider_stmt_da_sql_errno(A) thd_get_error_number(A)
|
|
#define spider_user_defined_key_parts(A) (A)->user_defined_key_parts
|
|
#define spider_join_table_count(A) (A)->table_count
|
|
#define SPIDER_CAN_BG_UPDATE (1LL << 39)
|
|
#define SPIDER_ALTER_ADD_PARTITION Alter_info::ALTER_ADD_PARTITION
|
|
#define SPIDER_ALTER_DROP_PARTITION Alter_info::ALTER_DROP_PARTITION
|
|
#define SPIDER_ALTER_COALESCE_PARTITION Alter_info::ALTER_COALESCE_PARTITION
|
|
#define SPIDER_ALTER_REORGANIZE_PARTITION Alter_info::ALTER_REORGANIZE_PARTITION
|
|
#define SPIDER_ALTER_TABLE_REORG Alter_info::ALTER_TABLE_REORG
|
|
#define SPIDER_ALTER_REBUILD_PARTITION Alter_info::ALTER_REBUILD_PARTITION
|
|
#define SPIDER_WARN_LEVEL_WARN Sql_condition::WARN_LEVEL_WARN
|
|
#define SPIDER_WARN_LEVEL_NOTE Sql_condition::WARN_LEVEL_NOTE
|
|
#define SPIDER_THD_KILL_CONNECTION KILL_CONNECTION
|
|
#else
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#define spider_stmt_da_message(A) (A)->main_da.message()
|
|
#define spider_stmt_da_sql_errno(A) (A)->main_da.sql_errno()
|
|
#else
|
|
#if MYSQL_VERSION_ID < 50600
|
|
#define spider_stmt_da_message(A) (A)->stmt_da->message()
|
|
#define spider_stmt_da_sql_errno(A) (A)->stmt_da->sql_errno()
|
|
#else
|
|
#define spider_stmt_da_message(A) (A)->get_stmt_da()->message()
|
|
#define spider_stmt_da_sql_errno(A) (A)->get_stmt_da()->sql_errno()
|
|
#endif
|
|
#endif
|
|
#define spider_user_defined_key_parts(A) (A)->key_parts
|
|
#define spider_join_table_count(A) (A)->tables
|
|
#define SPIDER_ALTER_ADD_PARTITION ALTER_ADD_PARTITION
|
|
#define SPIDER_ALTER_DROP_PARTITION ALTER_DROP_PARTITION
|
|
#define SPIDER_ALTER_COALESCE_PARTITION ALTER_COALESCE_PARTITION
|
|
#define SPIDER_ALTER_REORGANIZE_PARTITION ALTER_REORGANIZE_PARTITION
|
|
#define SPIDER_ALTER_TABLE_REORG ALTER_TABLE_REORG
|
|
#define SPIDER_ALTER_REBUILD_PARTITION ALTER_REBUILD_PARTITION
|
|
#define SPIDER_WARN_LEVEL_WARN MYSQL_ERROR::WARN_LEVEL_WARN
|
|
#define SPIDER_WARN_LEVEL_NOTE MYSQL_ERROR::WARN_LEVEL_NOTE
|
|
#define SPIDER_THD_KILL_CONNECTION THD::KILL_CONNECTION
|
|
#endif
|
|
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100005
|
|
#define SPIDER_HAS_EXPLAIN_QUERY
|
|
#endif
|
|
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100009
|
|
#define SPIDER_TEST(A) MY_TEST(A)
|
|
#else
|
|
#define SPIDER_TEST(A) test(A)
|
|
#endif
|
|
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100100
|
|
#define SPIDER_FIELD_FIELDPTR_REQUIRES_THDPTR
|
|
#define SPIDER_ENGINE_CONDITION_PUSHDOWN_IS_ALWAYS_ON
|
|
#define SPIDER_XID_USES_xid_cache_iterate
|
|
#else
|
|
#define SPIDER_XID_STATE_HAS_in_thd
|
|
#endif
|
|
|
|
#if defined(MARIADB_BASE_VERSION) && MYSQL_VERSION_ID >= 100108
|
|
#define SPIDER_Item_args_arg_count_IS_PROTECTED
|
|
#endif
|
|
|
|
#if MYSQL_VERSION_ID >= 50500
|
|
#define SPIDER_HAS_HASH_VALUE_TYPE
|
|
#endif
|
|
|
|
#define spider_bitmap_size(A) ((A + 7) / 8)
|
|
#define spider_set_bit(BITMAP, BIT) \
|
|
((BITMAP)[(BIT) / 8] |= (1 << ((BIT) & 7)))
|
|
#define spider_clear_bit(BITMAP, BIT) \
|
|
((BITMAP)[(BIT) / 8] &= ~(1 << ((BIT) & 7)))
|
|
#define spider_bit_is_set(BITMAP, BIT) \
|
|
(uint) ((BITMAP)[(BIT) / 8] & (1 << ((BIT) & 7)))
|
|
|
|
#define SPIDER_LINK_STATUS_NO_CHANGE 0
|
|
#define SPIDER_LINK_STATUS_OK 1
|
|
#define SPIDER_LINK_STATUS_RECOVERY 2
|
|
#define SPIDER_LINK_STATUS_NG 3
|
|
|
|
#define SPIDER_LINK_MON_OK 0
|
|
#define SPIDER_LINK_MON_NG -1
|
|
#define SPIDER_LINK_MON_DRAW_FEW_MON 1
|
|
#define SPIDER_LINK_MON_DRAW 2
|
|
|
|
#define SPIDER_TMP_SHARE_CHAR_PTR_COUNT 19
|
|
#define SPIDER_TMP_SHARE_UINT_COUNT 17
|
|
#define SPIDER_TMP_SHARE_LONG_COUNT 18
|
|
#define SPIDER_TMP_SHARE_LONGLONG_COUNT 3
|
|
|
|
#define SPIDER_MEM_CALC_LIST_NUM 247
|
|
|
|
#define SPIDER_BACKUP_DASTATUS \
|
|
bool da_status; if (thd) da_status = thd->is_error(); else da_status = FALSE;
|
|
#define SPIDER_RESTORE_DASTATUS \
|
|
if (!da_status && thd->is_error()) thd->clear_error();
|
|
#define SPIDER_CONN_RESTORE_DASTATUS \
|
|
if (thd && conn->error_mode) {SPIDER_RESTORE_DASTATUS;}
|
|
#define SPIDER_CONN_RESTORE_DASTATUS_AND_RESET_ERROR_NUM \
|
|
if (thd && conn->error_mode) {SPIDER_RESTORE_DASTATUS; error_num = 0;}
|
|
#define SPIDER_CONN_RESTORE_DASTATUS_AND_RESET_TMP_ERROR_NUM \
|
|
if (thd && conn->error_mode) {SPIDER_RESTORE_DASTATUS; tmp_error_num = 0;}
|
|
|
|
#define SPIDER_SET_FILE_POS(A) \
|
|
{(A)->thd = current_thd; (A)->func_name = __func__; (A)->file_name = __FILE__; (A)->line_no = __LINE__;}
|
|
#define SPIDER_CLEAR_FILE_POS(A) \
|
|
{DBUG_PRINT("info", ("spider thd=%p func_name=%s file_name=%s line_no=%lu", (A)->thd, (A)->func_name ? (A)->func_name : "NULL", (A)->file_name ? (A)->file_name : "NULL", (A)->line_no)); (A)->thd = NULL; (A)->func_name = NULL; (A)->file_name = NULL; (A)->line_no = 0;}
|
|
|
|
class ha_spider;
|
|
typedef struct st_spider_share SPIDER_SHARE;
|
|
|
|
typedef struct st_spider_file_pos
|
|
{
|
|
THD *thd;
|
|
const char *func_name;
|
|
const char *file_name;
|
|
ulong line_no;
|
|
} SPIDER_FILE_POS;
|
|
|
|
typedef struct st_spider_link_for_hash
|
|
{
|
|
ha_spider *spider;
|
|
int link_idx;
|
|
spider_string *db_table_str;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type db_table_str_hash_value;
|
|
#endif
|
|
} SPIDER_LINK_FOR_HASH;
|
|
|
|
/* alter table */
|
|
typedef struct st_spider_alter_table
|
|
{
|
|
bool now_create;
|
|
char *table_name;
|
|
uint table_name_length;
|
|
char *tmp_char;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type table_name_hash_value;
|
|
#endif
|
|
longlong tmp_priority;
|
|
uint link_count;
|
|
uint all_link_count;
|
|
|
|
char **tmp_server_names;
|
|
char **tmp_tgt_table_names;
|
|
char **tmp_tgt_dbs;
|
|
char **tmp_tgt_hosts;
|
|
char **tmp_tgt_usernames;
|
|
char **tmp_tgt_passwords;
|
|
char **tmp_tgt_sockets;
|
|
char **tmp_tgt_wrappers;
|
|
char **tmp_tgt_ssl_cas;
|
|
char **tmp_tgt_ssl_capaths;
|
|
char **tmp_tgt_ssl_certs;
|
|
char **tmp_tgt_ssl_ciphers;
|
|
char **tmp_tgt_ssl_keys;
|
|
char **tmp_tgt_default_files;
|
|
char **tmp_tgt_default_groups;
|
|
long *tmp_tgt_ports;
|
|
long *tmp_tgt_ssl_vscs;
|
|
long *tmp_link_statuses;
|
|
|
|
uint *tmp_server_names_lengths;
|
|
uint *tmp_tgt_table_names_lengths;
|
|
uint *tmp_tgt_dbs_lengths;
|
|
uint *tmp_tgt_hosts_lengths;
|
|
uint *tmp_tgt_usernames_lengths;
|
|
uint *tmp_tgt_passwords_lengths;
|
|
uint *tmp_tgt_sockets_lengths;
|
|
uint *tmp_tgt_wrappers_lengths;
|
|
uint *tmp_tgt_ssl_cas_lengths;
|
|
uint *tmp_tgt_ssl_capaths_lengths;
|
|
uint *tmp_tgt_ssl_certs_lengths;
|
|
uint *tmp_tgt_ssl_ciphers_lengths;
|
|
uint *tmp_tgt_ssl_keys_lengths;
|
|
uint *tmp_tgt_default_files_lengths;
|
|
uint *tmp_tgt_default_groups_lengths;
|
|
|
|
uint tmp_server_names_charlen;
|
|
uint tmp_tgt_table_names_charlen;
|
|
uint tmp_tgt_dbs_charlen;
|
|
uint tmp_tgt_hosts_charlen;
|
|
uint tmp_tgt_usernames_charlen;
|
|
uint tmp_tgt_passwords_charlen;
|
|
uint tmp_tgt_sockets_charlen;
|
|
uint tmp_tgt_wrappers_charlen;
|
|
uint tmp_tgt_ssl_cas_charlen;
|
|
uint tmp_tgt_ssl_capaths_charlen;
|
|
uint tmp_tgt_ssl_certs_charlen;
|
|
uint tmp_tgt_ssl_ciphers_charlen;
|
|
uint tmp_tgt_ssl_keys_charlen;
|
|
uint tmp_tgt_default_files_charlen;
|
|
uint tmp_tgt_default_groups_charlen;
|
|
|
|
uint tmp_server_names_length;
|
|
uint tmp_tgt_table_names_length;
|
|
uint tmp_tgt_dbs_length;
|
|
uint tmp_tgt_hosts_length;
|
|
uint tmp_tgt_usernames_length;
|
|
uint tmp_tgt_passwords_length;
|
|
uint tmp_tgt_sockets_length;
|
|
uint tmp_tgt_wrappers_length;
|
|
uint tmp_tgt_ssl_cas_length;
|
|
uint tmp_tgt_ssl_capaths_length;
|
|
uint tmp_tgt_ssl_certs_length;
|
|
uint tmp_tgt_ssl_ciphers_length;
|
|
uint tmp_tgt_ssl_keys_length;
|
|
uint tmp_tgt_default_files_length;
|
|
uint tmp_tgt_default_groups_length;
|
|
uint tmp_tgt_ports_length;
|
|
uint tmp_tgt_ssl_vscs_length;
|
|
uint tmp_link_statuses_length;
|
|
} SPIDER_ALTER_TABLE;
|
|
|
|
/* database connection */
|
|
typedef struct st_spider_conn
|
|
{
|
|
uint conn_kind;
|
|
char *conn_key;
|
|
uint conn_key_length;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type conn_key_hash_value;
|
|
#endif
|
|
int link_idx;
|
|
spider_db_conn *db_conn;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
query_id_t hsc_query_id;
|
|
ulonglong hs_pre_age;
|
|
ulonglong hs_age;
|
|
#endif
|
|
uint opened_handlers;
|
|
ulonglong conn_id;
|
|
ulonglong connection_id;
|
|
query_id_t casual_read_query_id;
|
|
uint casual_read_current_id;
|
|
st_spider_conn *casual_read_base_conn;
|
|
pthread_mutex_t mta_conn_mutex;
|
|
volatile bool mta_conn_mutex_lock_already;
|
|
volatile bool mta_conn_mutex_unlock_later;
|
|
SPIDER_FILE_POS mta_conn_mutex_file_pos;
|
|
uint join_trx;
|
|
int trx_isolation;
|
|
bool semi_trx_isolation_chk;
|
|
int semi_trx_isolation;
|
|
bool semi_trx_chk;
|
|
bool semi_trx;
|
|
bool trx_start;
|
|
bool table_locked;
|
|
int table_lock;
|
|
bool disable_xa;
|
|
bool disable_reconnect;
|
|
int autocommit;
|
|
int sql_log_off;
|
|
THD *thd;
|
|
void *another_ha_first;
|
|
void *another_ha_last;
|
|
st_spider_conn *p_small;
|
|
st_spider_conn *p_big;
|
|
st_spider_conn *c_small;
|
|
st_spider_conn *c_big;
|
|
longlong priority;
|
|
bool server_lost;
|
|
bool ignore_dup_key;
|
|
char *error_str;
|
|
int error_length;
|
|
time_t ping_time;
|
|
CHARSET_INFO *access_charset;
|
|
Time_zone *time_zone;
|
|
uint connect_timeout;
|
|
uint net_read_timeout;
|
|
uint net_write_timeout;
|
|
int error_mode;
|
|
spider_string default_database;
|
|
|
|
char *tgt_host;
|
|
char *tgt_username;
|
|
char *tgt_password;
|
|
char *tgt_socket;
|
|
char *tgt_wrapper;
|
|
char *tgt_ssl_ca;
|
|
char *tgt_ssl_capath;
|
|
char *tgt_ssl_cert;
|
|
char *tgt_ssl_cipher;
|
|
char *tgt_ssl_key;
|
|
char *tgt_default_file;
|
|
char *tgt_default_group;
|
|
long tgt_port;
|
|
long tgt_ssl_vsc;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
char *hs_sock;
|
|
long hs_port;
|
|
#endif
|
|
|
|
uint tgt_host_length;
|
|
uint tgt_username_length;
|
|
uint tgt_password_length;
|
|
uint tgt_socket_length;
|
|
uint tgt_wrapper_length;
|
|
uint tgt_ssl_ca_length;
|
|
uint tgt_ssl_capath_length;
|
|
uint tgt_ssl_cert_length;
|
|
uint tgt_ssl_cipher_length;
|
|
uint tgt_ssl_key_length;
|
|
uint tgt_default_file_length;
|
|
uint tgt_default_group_length;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint hs_sock_length;
|
|
#endif
|
|
uint dbton_id;
|
|
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
volatile
|
|
#endif
|
|
void *quick_target;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
volatile bool bg_init;
|
|
volatile bool bg_break;
|
|
volatile bool bg_kill;
|
|
volatile bool bg_caller_wait;
|
|
volatile bool bg_caller_sync_wait;
|
|
volatile bool bg_search;
|
|
volatile bool bg_discard_result;
|
|
volatile bool bg_direct_sql;
|
|
volatile bool bg_exec_sql;
|
|
volatile bool bg_get_job_stack;
|
|
volatile bool bg_get_job_stack_off;
|
|
volatile uint bg_simple_action;
|
|
THD *bg_thd;
|
|
pthread_t bg_thread;
|
|
pthread_cond_t bg_conn_cond;
|
|
pthread_mutex_t bg_conn_mutex;
|
|
pthread_cond_t bg_conn_sync_cond;
|
|
pthread_mutex_t bg_conn_sync_mutex;
|
|
pthread_mutex_t bg_conn_chain_mutex;
|
|
pthread_mutex_t *bg_conn_chain_mutex_ptr;
|
|
volatile void *bg_target;
|
|
volatile int *bg_error_num;
|
|
volatile ulong bg_sql_type;
|
|
pthread_mutex_t bg_job_stack_mutex;
|
|
DYNAMIC_ARRAY bg_job_stack;
|
|
uint bg_job_stack_id;
|
|
const char *bg_job_stack_func_name;
|
|
const char *bg_job_stack_file_name;
|
|
ulong bg_job_stack_line_no;
|
|
uint bg_job_stack_cur_pos;
|
|
#endif
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
volatile
|
|
#endif
|
|
int *need_mon;
|
|
int *conn_need_mon;
|
|
|
|
bool use_for_active_standby;
|
|
bool in_before_query;
|
|
|
|
bool queued_connect;
|
|
bool queued_ping;
|
|
bool queued_trx_isolation;
|
|
bool queued_semi_trx_isolation;
|
|
bool queued_autocommit;
|
|
bool queued_sql_log_off;
|
|
bool queued_time_zone;
|
|
bool queued_trx_start;
|
|
bool queued_xa_start;
|
|
bool queued_net_timeout;
|
|
SPIDER_SHARE *queued_connect_share;
|
|
int queued_connect_link_idx;
|
|
ha_spider *queued_ping_spider;
|
|
int queued_ping_link_idx;
|
|
int queued_trx_isolation_val;
|
|
int queued_semi_trx_isolation_val;
|
|
bool queued_autocommit_val;
|
|
bool queued_sql_log_off_val;
|
|
Time_zone *queued_time_zone_val;
|
|
XID *queued_xa_start_xid;
|
|
|
|
#ifdef HA_CAN_BULK_ACCESS
|
|
uint bulk_access_requests;
|
|
uint bulk_access_sended;
|
|
int bulk_access_error_num;
|
|
st_spider_conn *bulk_access_next;
|
|
#endif
|
|
|
|
bool disable_connect_retry; /* TRUE if it is unnecessary to
|
|
retry to connect after a
|
|
connection error */
|
|
bool connect_error_with_message;
|
|
char connect_error_msg[MYSQL_ERRMSG_SIZE];
|
|
int connect_error;
|
|
THD *connect_error_thd;
|
|
query_id_t connect_error_query_id;
|
|
time_t connect_error_time;
|
|
} SPIDER_CONN;
|
|
|
|
typedef struct st_spider_lgtm_tblhnd_share
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type table_path_hash_value;
|
|
#endif
|
|
pthread_mutex_t auto_increment_mutex;
|
|
volatile bool auto_increment_init;
|
|
volatile ulonglong auto_increment_lclval;
|
|
ulonglong auto_increment_value;
|
|
} SPIDER_LGTM_TBLHND_SHARE;
|
|
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
typedef struct st_spider_patition_handler_share
|
|
{
|
|
uint use_count;
|
|
TABLE *table;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type table_hash_value;
|
|
#endif
|
|
void *creator;
|
|
void **handlers;
|
|
uchar *searched_bitmap;
|
|
uchar *ft_discard_bitmap;
|
|
uchar *idx_read_bitmap;
|
|
uchar *idx_write_bitmap;
|
|
uchar *rnd_read_bitmap;
|
|
uchar *rnd_write_bitmap;
|
|
bool between_flg;
|
|
bool idx_bitmap_is_set;
|
|
bool rnd_bitmap_is_set;
|
|
} SPIDER_PARTITION_HANDLER_SHARE;
|
|
|
|
typedef struct st_spider_patition_share
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type table_path_hash_value;
|
|
#endif
|
|
uint use_count;
|
|
pthread_mutex_t sts_mutex;
|
|
pthread_mutex_t crd_mutex;
|
|
pthread_mutex_t pt_handler_mutex;
|
|
HASH pt_handler_hash;
|
|
uint pt_handler_hash_id;
|
|
const char *pt_handler_hash_func_name;
|
|
const char *pt_handler_hash_file_name;
|
|
ulong pt_handler_hash_line_no;
|
|
|
|
volatile bool sts_init;
|
|
volatile bool crd_init;
|
|
volatile time_t sts_get_time;
|
|
volatile time_t crd_get_time;
|
|
ulonglong data_file_length;
|
|
ulonglong max_data_file_length;
|
|
ulonglong index_file_length;
|
|
ulonglong auto_increment_value;
|
|
ha_rows records;
|
|
ulong mean_rec_length;
|
|
time_t check_time;
|
|
time_t create_time;
|
|
time_t update_time;
|
|
|
|
longlong *cardinality;
|
|
/*
|
|
volatile SPIDER_PARTITION_HANDLER_SHARE *partition_handler_share;
|
|
*/
|
|
} SPIDER_PARTITION_SHARE;
|
|
#endif
|
|
|
|
typedef struct st_spider_transaction
|
|
{
|
|
bool trx_start;
|
|
bool trx_xa;
|
|
bool trx_consistent_snapshot;
|
|
bool trx_xa_prepared;
|
|
|
|
bool use_consistent_snapshot;
|
|
bool internal_xa;
|
|
uint internal_xa_snapshot;
|
|
|
|
query_id_t query_id;
|
|
bool tmp_flg;
|
|
bool registed_allocated_thds;
|
|
|
|
THD *thd;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type thd_hash_value;
|
|
#endif
|
|
XID xid;
|
|
HASH trx_conn_hash;
|
|
uint trx_conn_hash_id;
|
|
const char *trx_conn_hash_func_name;
|
|
const char *trx_conn_hash_file_name;
|
|
ulong trx_conn_hash_line_no;
|
|
HASH trx_another_conn_hash;
|
|
uint trx_another_conn_hash_id;
|
|
const char *trx_another_conn_hash_func_name;
|
|
const char *trx_another_conn_hash_file_name;
|
|
ulong trx_another_conn_hash_line_no;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
HASH trx_hs_r_conn_hash;
|
|
uint trx_hs_r_conn_hash_id;
|
|
const char *trx_hs_r_conn_hash_func_name;
|
|
const char *trx_hs_r_conn_hash_file_name;
|
|
ulong trx_hs_r_conn_hash_line_no;
|
|
HASH trx_hs_w_conn_hash;
|
|
uint trx_hs_w_conn_hash_id;
|
|
const char *trx_hs_w_conn_hash_func_name;
|
|
const char *trx_hs_w_conn_hash_file_name;
|
|
ulong trx_hs_w_conn_hash_line_no;
|
|
#endif
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
HASH trx_direct_hs_r_conn_hash;
|
|
uint trx_direct_hs_r_conn_hash_id;
|
|
const char *trx_direct_hs_r_conn_hash_func_name;
|
|
const char *trx_direct_hs_r_conn_hash_file_name;
|
|
ulong trx_direct_hs_r_conn_hash_line_no;
|
|
HASH trx_direct_hs_w_conn_hash;
|
|
uint trx_direct_hs_w_conn_hash_id;
|
|
const char *trx_direct_hs_w_conn_hash_func_name;
|
|
const char *trx_direct_hs_w_conn_hash_file_name;
|
|
ulong trx_direct_hs_w_conn_hash_line_no;
|
|
#endif
|
|
HASH trx_alter_table_hash;
|
|
uint trx_alter_table_hash_id;
|
|
const char *trx_alter_table_hash_func_name;
|
|
const char *trx_alter_table_hash_file_name;
|
|
ulong trx_alter_table_hash_line_no;
|
|
HASH trx_ha_hash;
|
|
uint trx_ha_hash_id;
|
|
const char *trx_ha_hash_func_name;
|
|
const char *trx_ha_hash_file_name;
|
|
ulong trx_ha_hash_line_no;
|
|
uint trx_ha_reuse_count;
|
|
XID_STATE internal_xid_state;
|
|
SPIDER_CONN *join_trx_top;
|
|
ulonglong spider_thread_id;
|
|
ulonglong trx_conn_adjustment;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
ulonglong trx_hs_r_conn_adjustment;
|
|
ulonglong trx_hs_w_conn_adjustment;
|
|
#endif
|
|
uint locked_connections;
|
|
|
|
ulonglong direct_update_count;
|
|
ulonglong direct_delete_count;
|
|
ulonglong direct_order_limit_count;
|
|
ulonglong direct_aggregate_count;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
ulonglong hs_result_free_count;
|
|
#endif
|
|
|
|
#ifdef HA_CAN_BULK_ACCESS
|
|
SPIDER_CONN *bulk_access_conn_first;
|
|
SPIDER_CONN *bulk_access_conn_last;
|
|
#endif
|
|
|
|
pthread_mutex_t *udf_table_mutexes;
|
|
CHARSET_INFO *udf_access_charset;
|
|
spider_string *udf_set_names;
|
|
|
|
time_t mem_calc_merge_time;
|
|
const char *alloc_func_name[SPIDER_MEM_CALC_LIST_NUM];
|
|
const char *alloc_file_name[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulong alloc_line_no[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulonglong total_alloc_mem[SPIDER_MEM_CALC_LIST_NUM];
|
|
longlong current_alloc_mem[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulonglong alloc_mem_count[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulonglong free_mem_count[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulonglong total_alloc_mem_buffer[SPIDER_MEM_CALC_LIST_NUM];
|
|
longlong current_alloc_mem_buffer[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulonglong alloc_mem_count_buffer[SPIDER_MEM_CALC_LIST_NUM];
|
|
ulonglong free_mem_count_buffer[SPIDER_MEM_CALC_LIST_NUM];
|
|
|
|
MEM_ROOT mem_root;
|
|
|
|
/* for transaction level query */
|
|
SPIDER_SHARE *tmp_share;
|
|
char *tmp_connect_info[SPIDER_TMP_SHARE_CHAR_PTR_COUNT];
|
|
uint tmp_connect_info_length[SPIDER_TMP_SHARE_UINT_COUNT];
|
|
long tmp_long[SPIDER_TMP_SHARE_LONG_COUNT];
|
|
longlong tmp_longlong[SPIDER_TMP_SHARE_LONGLONG_COUNT];
|
|
ha_spider *tmp_spider;
|
|
int tmp_need_mon;
|
|
spider_db_handler *tmp_dbton_handler[SPIDER_DBTON_SIZE];
|
|
} SPIDER_TRX;
|
|
|
|
typedef struct st_spider_share
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
uint use_count;
|
|
uint link_count;
|
|
uint all_link_count;
|
|
uint link_bitmap_size;
|
|
pthread_mutex_t mutex;
|
|
pthread_mutex_t sts_mutex;
|
|
pthread_mutex_t crd_mutex;
|
|
/*
|
|
pthread_mutex_t auto_increment_mutex;
|
|
*/
|
|
THR_LOCK lock;
|
|
TABLE_SHARE *table_share;
|
|
SPIDER_LGTM_TBLHND_SHARE *lgtm_tblhnd_share;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type table_name_hash_value;
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
my_hash_value_type table_path_hash_value;
|
|
#endif
|
|
#endif
|
|
|
|
volatile bool init;
|
|
volatile bool init_error;
|
|
volatile time_t init_error_time;
|
|
volatile bool link_status_init;
|
|
uchar *table_mon_mutex_bitmap;
|
|
volatile bool sts_init;
|
|
volatile time_t sts_get_time;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
volatile time_t bg_sts_try_time;
|
|
volatile double bg_sts_interval;
|
|
volatile int bg_sts_mode;
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
volatile int bg_sts_sync;
|
|
#endif
|
|
volatile bool bg_sts_init;
|
|
volatile bool bg_sts_kill;
|
|
volatile bool bg_sts_thd_wait;
|
|
THD *bg_sts_thd;
|
|
pthread_t bg_sts_thread;
|
|
pthread_cond_t bg_sts_cond;
|
|
pthread_cond_t bg_sts_sync_cond;
|
|
volatile bool crd_init;
|
|
#endif
|
|
volatile time_t crd_get_time;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
volatile time_t bg_crd_try_time;
|
|
volatile double bg_crd_interval;
|
|
volatile int bg_crd_mode;
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
volatile int bg_crd_sync;
|
|
#endif
|
|
volatile bool bg_crd_init;
|
|
volatile bool bg_crd_kill;
|
|
volatile bool bg_crd_thd_wait;
|
|
THD *bg_crd_thd;
|
|
pthread_t bg_crd_thread;
|
|
pthread_cond_t bg_crd_cond;
|
|
pthread_cond_t bg_crd_sync_cond;
|
|
#endif
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
volatile bool bg_mon_init;
|
|
volatile bool bg_mon_kill;
|
|
THD **bg_mon_thds;
|
|
pthread_t *bg_mon_threads;
|
|
pthread_mutex_t *bg_mon_mutexes;
|
|
pthread_cond_t *bg_mon_conds;
|
|
pthread_cond_t *bg_mon_sleep_conds;
|
|
#endif
|
|
/*
|
|
volatile bool auto_increment_init;
|
|
volatile ulonglong auto_increment_lclval;
|
|
*/
|
|
ulonglong data_file_length;
|
|
ulonglong max_data_file_length;
|
|
ulonglong index_file_length;
|
|
/*
|
|
ulonglong auto_increment_value;
|
|
*/
|
|
ha_rows records;
|
|
ulong mean_rec_length;
|
|
time_t check_time;
|
|
time_t create_time;
|
|
time_t update_time;
|
|
|
|
longlong static_records_for_status;
|
|
longlong static_mean_rec_length;
|
|
|
|
int bitmap_size;
|
|
spider_string *key_hint;
|
|
CHARSET_INFO *access_charset;
|
|
longlong *static_key_cardinality;
|
|
longlong *cardinality;
|
|
uchar *cardinality_upd;
|
|
longlong additional_table_flags;
|
|
bool have_recovery_link;
|
|
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
int sts_bg_mode;
|
|
#endif
|
|
double sts_interval;
|
|
int sts_mode;
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
int sts_sync;
|
|
#endif
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
int crd_bg_mode;
|
|
#endif
|
|
double crd_interval;
|
|
int crd_mode;
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
int crd_sync;
|
|
#endif
|
|
int crd_type;
|
|
double crd_weight;
|
|
longlong internal_offset;
|
|
longlong internal_limit;
|
|
longlong split_read;
|
|
double semi_split_read;
|
|
longlong semi_split_read_limit;
|
|
int init_sql_alloc_size;
|
|
int reset_sql_alloc;
|
|
int multi_split_read;
|
|
int max_order;
|
|
int semi_table_lock;
|
|
int semi_table_lock_conn;
|
|
int selupd_lock_mode;
|
|
int query_cache;
|
|
int query_cache_sync;
|
|
int internal_delayed;
|
|
int bulk_size;
|
|
int bulk_update_mode;
|
|
int bulk_update_size;
|
|
int internal_optimize;
|
|
int internal_optimize_local;
|
|
double scan_rate;
|
|
double read_rate;
|
|
longlong priority;
|
|
int quick_mode;
|
|
longlong quick_page_size;
|
|
int low_mem_read;
|
|
int table_count_mode;
|
|
int select_column_mode;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
int bgs_mode;
|
|
longlong bgs_first_read;
|
|
longlong bgs_second_read;
|
|
#endif
|
|
longlong first_read;
|
|
longlong second_read;
|
|
int auto_increment_mode;
|
|
int use_table_charset;
|
|
int use_pushdown_udf;
|
|
int skip_default_condition;
|
|
int direct_dup_insert;
|
|
longlong direct_order_limit;
|
|
int read_only_mode;
|
|
int error_read_mode;
|
|
int error_write_mode;
|
|
int active_link_count;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
longlong hs_result_free_size;
|
|
#endif
|
|
#ifdef HA_CAN_BULK_ACCESS
|
|
int bulk_access_free;
|
|
#endif
|
|
#ifdef HA_CAN_FORCE_BULK_UPDATE
|
|
int force_bulk_update;
|
|
#endif
|
|
#ifdef HA_CAN_FORCE_BULK_DELETE
|
|
int force_bulk_delete;
|
|
#endif
|
|
int casual_read;
|
|
int delete_all_rows_type;
|
|
|
|
int bka_mode;
|
|
char *bka_engine;
|
|
int bka_engine_length;
|
|
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type *conn_keys_hash_value;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
my_hash_value_type *hs_read_conn_keys_hash_value;
|
|
my_hash_value_type *hs_write_conn_keys_hash_value;
|
|
#endif
|
|
#endif
|
|
char **server_names;
|
|
char **tgt_table_names;
|
|
char **tgt_dbs;
|
|
char **tgt_hosts;
|
|
char **tgt_usernames;
|
|
char **tgt_passwords;
|
|
char **tgt_sockets;
|
|
char **tgt_wrappers;
|
|
char **tgt_ssl_cas;
|
|
char **tgt_ssl_capaths;
|
|
char **tgt_ssl_certs;
|
|
char **tgt_ssl_ciphers;
|
|
char **tgt_ssl_keys;
|
|
char **tgt_default_files;
|
|
char **tgt_default_groups;
|
|
char **tgt_pk_names;
|
|
char **tgt_sequence_names;
|
|
char **conn_keys;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
char **hs_read_socks;
|
|
char **hs_write_socks;
|
|
char **hs_read_conn_keys;
|
|
char **hs_write_conn_keys;
|
|
#endif
|
|
long *tgt_ports;
|
|
long *tgt_ssl_vscs;
|
|
long *link_statuses;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
long *monitoring_bg_flag;
|
|
long *monitoring_bg_kind;
|
|
#endif
|
|
long *monitoring_flag;
|
|
long *monitoring_kind;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
longlong *monitoring_bg_interval;
|
|
#endif
|
|
longlong *monitoring_limit;
|
|
longlong *monitoring_sid;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
long *use_hs_reads;
|
|
long *use_hs_writes;
|
|
long *hs_read_ports;
|
|
long *hs_write_ports;
|
|
long *hs_write_to_reads;
|
|
#endif
|
|
long *use_handlers;
|
|
long *connect_timeouts;
|
|
long *net_read_timeouts;
|
|
long *net_write_timeouts;
|
|
long *access_balances;
|
|
long *bka_table_name_types;
|
|
|
|
uint *server_names_lengths;
|
|
uint *tgt_table_names_lengths;
|
|
uint *tgt_dbs_lengths;
|
|
uint *tgt_hosts_lengths;
|
|
uint *tgt_usernames_lengths;
|
|
uint *tgt_passwords_lengths;
|
|
uint *tgt_sockets_lengths;
|
|
uint *tgt_wrappers_lengths;
|
|
uint *tgt_ssl_cas_lengths;
|
|
uint *tgt_ssl_capaths_lengths;
|
|
uint *tgt_ssl_certs_lengths;
|
|
uint *tgt_ssl_ciphers_lengths;
|
|
uint *tgt_ssl_keys_lengths;
|
|
uint *tgt_default_files_lengths;
|
|
uint *tgt_default_groups_lengths;
|
|
uint *tgt_pk_names_lengths;
|
|
uint *tgt_sequence_names_lengths;
|
|
uint *conn_keys_lengths;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint *hs_read_socks_lengths;
|
|
uint *hs_write_socks_lengths;
|
|
uint *hs_read_conn_keys_lengths;
|
|
uint *hs_write_conn_keys_lengths;
|
|
#endif
|
|
uint *sql_dbton_ids;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint *hs_dbton_ids;
|
|
#endif
|
|
|
|
uint server_names_charlen;
|
|
uint tgt_table_names_charlen;
|
|
uint tgt_dbs_charlen;
|
|
uint tgt_hosts_charlen;
|
|
uint tgt_usernames_charlen;
|
|
uint tgt_passwords_charlen;
|
|
uint tgt_sockets_charlen;
|
|
uint tgt_wrappers_charlen;
|
|
uint tgt_ssl_cas_charlen;
|
|
uint tgt_ssl_capaths_charlen;
|
|
uint tgt_ssl_certs_charlen;
|
|
uint tgt_ssl_ciphers_charlen;
|
|
uint tgt_ssl_keys_charlen;
|
|
uint tgt_default_files_charlen;
|
|
uint tgt_default_groups_charlen;
|
|
uint tgt_pk_names_charlen;
|
|
uint tgt_sequence_names_charlen;
|
|
uint conn_keys_charlen;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint hs_read_socks_charlen;
|
|
uint hs_write_socks_charlen;
|
|
uint hs_read_conn_keys_charlen;
|
|
uint hs_write_conn_keys_charlen;
|
|
#endif
|
|
|
|
uint server_names_length;
|
|
uint tgt_table_names_length;
|
|
uint tgt_dbs_length;
|
|
uint tgt_hosts_length;
|
|
uint tgt_usernames_length;
|
|
uint tgt_passwords_length;
|
|
uint tgt_sockets_length;
|
|
uint tgt_wrappers_length;
|
|
uint tgt_ssl_cas_length;
|
|
uint tgt_ssl_capaths_length;
|
|
uint tgt_ssl_certs_length;
|
|
uint tgt_ssl_ciphers_length;
|
|
uint tgt_ssl_keys_length;
|
|
uint tgt_default_files_length;
|
|
uint tgt_default_groups_length;
|
|
uint tgt_pk_names_length;
|
|
uint tgt_sequence_names_length;
|
|
uint conn_keys_length;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint hs_read_socks_length;
|
|
uint hs_write_socks_length;
|
|
uint hs_read_conn_keys_length;
|
|
uint hs_write_conn_keys_length;
|
|
#endif
|
|
uint tgt_ports_length;
|
|
uint tgt_ssl_vscs_length;
|
|
uint link_statuses_length;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
uint monitoring_bg_flag_length;
|
|
uint monitoring_bg_kind_length;
|
|
#endif
|
|
uint monitoring_flag_length;
|
|
uint monitoring_kind_length;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
uint monitoring_bg_interval_length;
|
|
#endif
|
|
uint monitoring_limit_length;
|
|
uint monitoring_sid_length;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint use_hs_reads_length;
|
|
uint use_hs_writes_length;
|
|
uint hs_read_ports_length;
|
|
uint hs_write_ports_length;
|
|
uint hs_write_to_reads_length;
|
|
#endif
|
|
uint use_handlers_length;
|
|
uint connect_timeouts_length;
|
|
uint net_read_timeouts_length;
|
|
uint net_write_timeouts_length;
|
|
uint access_balances_length;
|
|
uint bka_table_name_types_length;
|
|
|
|
/* for dbton */
|
|
uchar dbton_bitmap[spider_bitmap_size(SPIDER_DBTON_SIZE)];
|
|
spider_db_share *dbton_share[SPIDER_DBTON_SIZE];
|
|
uint use_dbton_count;
|
|
uint use_dbton_ids[SPIDER_DBTON_SIZE];
|
|
uint dbton_id_to_seq[SPIDER_DBTON_SIZE];
|
|
uint use_sql_dbton_count;
|
|
uint use_sql_dbton_ids[SPIDER_DBTON_SIZE];
|
|
uint sql_dbton_id_to_seq[SPIDER_DBTON_SIZE];
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
uint use_hs_dbton_count;
|
|
uint use_hs_dbton_ids[SPIDER_DBTON_SIZE];
|
|
uint hs_dbton_id_to_seq[SPIDER_DBTON_SIZE];
|
|
#endif
|
|
|
|
SPIDER_ALTER_TABLE alter_table;
|
|
#ifdef WITH_PARTITION_STORAGE_ENGINE
|
|
SPIDER_PARTITION_SHARE *partition_share;
|
|
#endif
|
|
} SPIDER_SHARE;
|
|
|
|
typedef struct st_spider_link_pack
|
|
{
|
|
SPIDER_SHARE *share;
|
|
int link_idx;
|
|
} SPIDER_LINK_PACK;
|
|
|
|
typedef struct st_spider_init_error_table
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type table_name_hash_value;
|
|
#endif
|
|
bool init_error_with_message;
|
|
char init_error_msg[MYSQL_ERRMSG_SIZE];
|
|
volatile int init_error;
|
|
volatile time_t init_error_time;
|
|
} SPIDER_INIT_ERROR_TABLE;
|
|
|
|
typedef struct st_spider_direct_sql
|
|
{
|
|
int table_count;
|
|
char **db_names;
|
|
char **table_names;
|
|
TABLE **tables;
|
|
int *iop;
|
|
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#else
|
|
/* for using real table */
|
|
bool real_table_used;
|
|
TABLE_LIST *table_list_first;
|
|
TABLE_LIST *table_list;
|
|
uchar *real_table_bitmap;
|
|
Open_tables_backup open_tables_backup;
|
|
THD *open_tables_thd;
|
|
#endif
|
|
|
|
char *sql;
|
|
ulong sql_length;
|
|
|
|
SPIDER_TRX *trx;
|
|
SPIDER_CONN *conn;
|
|
|
|
bool modified_non_trans_table;
|
|
|
|
int table_loop_mode;
|
|
longlong priority;
|
|
int connect_timeout;
|
|
int net_read_timeout;
|
|
int net_write_timeout;
|
|
longlong bulk_insert_rows;
|
|
int connection_channel;
|
|
#if defined(HS_HAS_SQLCOM) && defined(HAVE_HANDLERSOCKET)
|
|
int access_mode;
|
|
#endif
|
|
#if MYSQL_VERSION_ID < 50500
|
|
#else
|
|
int use_real_table;
|
|
#endif
|
|
int error_rw_mode;
|
|
|
|
char *server_name;
|
|
char *tgt_default_db_name;
|
|
char *tgt_host;
|
|
char *tgt_username;
|
|
char *tgt_password;
|
|
char *tgt_socket;
|
|
char *tgt_wrapper;
|
|
char *tgt_ssl_ca;
|
|
char *tgt_ssl_capath;
|
|
char *tgt_ssl_cert;
|
|
char *tgt_ssl_cipher;
|
|
char *tgt_ssl_key;
|
|
char *tgt_default_file;
|
|
char *tgt_default_group;
|
|
char *conn_key;
|
|
long tgt_port;
|
|
long tgt_ssl_vsc;
|
|
|
|
uint server_name_length;
|
|
uint tgt_default_db_name_length;
|
|
uint tgt_host_length;
|
|
uint tgt_username_length;
|
|
uint tgt_password_length;
|
|
uint tgt_socket_length;
|
|
uint tgt_wrapper_length;
|
|
uint tgt_ssl_ca_length;
|
|
uint tgt_ssl_capath_length;
|
|
uint tgt_ssl_cert_length;
|
|
uint tgt_ssl_cipher_length;
|
|
uint tgt_ssl_key_length;
|
|
uint tgt_default_file_length;
|
|
uint tgt_default_group_length;
|
|
uint conn_key_length;
|
|
uint dbton_id;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type conn_key_hash_value;
|
|
#endif
|
|
|
|
pthread_mutex_t *bg_mutex;
|
|
pthread_cond_t *bg_cond;
|
|
volatile st_spider_direct_sql *prev;
|
|
volatile st_spider_direct_sql *next;
|
|
void *parent;
|
|
} SPIDER_DIRECT_SQL;
|
|
|
|
typedef struct st_spider_bg_direct_sql
|
|
{
|
|
longlong called_cnt;
|
|
char bg_error_msg[MYSQL_ERRMSG_SIZE];
|
|
volatile int bg_error;
|
|
volatile bool modified_non_trans_table;
|
|
pthread_mutex_t bg_mutex;
|
|
pthread_cond_t bg_cond;
|
|
volatile SPIDER_DIRECT_SQL *direct_sql;
|
|
} SPIDER_BG_DIRECT_SQL;
|
|
|
|
typedef struct st_spider_mon_table_result
|
|
{
|
|
int result_status;
|
|
SPIDER_TRX *trx;
|
|
} SPIDER_MON_TABLE_RESULT;
|
|
|
|
typedef struct st_spider_table_mon
|
|
{
|
|
SPIDER_SHARE *share;
|
|
uint32 server_id;
|
|
st_spider_table_mon *next;
|
|
} SPIDER_TABLE_MON;
|
|
|
|
typedef struct st_spider_table_mon_list
|
|
{
|
|
char *key;
|
|
uint key_length;
|
|
#ifdef SPIDER_HAS_HASH_VALUE_TYPE
|
|
my_hash_value_type key_hash_value;
|
|
#endif
|
|
|
|
uint use_count;
|
|
uint mutex_hash;
|
|
ulonglong mon_table_cache_version;
|
|
|
|
char *table_name;
|
|
int link_id;
|
|
uint table_name_length;
|
|
|
|
int list_size;
|
|
SPIDER_TABLE_MON *first;
|
|
SPIDER_TABLE_MON *current;
|
|
volatile int mon_status;
|
|
|
|
SPIDER_SHARE *share;
|
|
|
|
pthread_mutex_t caller_mutex;
|
|
pthread_mutex_t receptor_mutex;
|
|
pthread_mutex_t monitor_mutex;
|
|
pthread_mutex_t update_status_mutex;
|
|
volatile int last_caller_result;
|
|
volatile int last_receptor_result;
|
|
volatile int last_mon_result;
|
|
} SPIDER_TABLE_MON_LIST;
|
|
|
|
typedef struct st_spider_copy_table_conn
|
|
{
|
|
SPIDER_SHARE *share;
|
|
int link_idx;
|
|
SPIDER_CONN *conn;
|
|
spider_db_copy_table *copy_table;
|
|
ha_spider *spider;
|
|
int need_mon;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
int bg_error_num;
|
|
#endif
|
|
st_spider_copy_table_conn *next;
|
|
} SPIDER_COPY_TABLE_CONN;
|
|
|
|
typedef struct st_spider_copy_tables
|
|
{
|
|
SPIDER_TRX *trx;
|
|
char *spider_db_name;
|
|
int spider_db_name_length;
|
|
char *spider_table_name;
|
|
int spider_table_name_length;
|
|
char *spider_real_table_name;
|
|
int spider_real_table_name_length;
|
|
TABLE_LIST spider_table_list;
|
|
CHARSET_INFO *access_charset;
|
|
|
|
SPIDER_COPY_TABLE_CONN *table_conn[2];
|
|
bool use_auto_mode[2];
|
|
int link_idx_count[2];
|
|
int *link_idxs[2];
|
|
|
|
int bulk_insert_interval;
|
|
longlong bulk_insert_rows;
|
|
int use_table_charset;
|
|
int use_transaction;
|
|
#ifndef WITHOUT_SPIDER_BG_SEARCH
|
|
int bg_mode;
|
|
#endif
|
|
|
|
char *database;
|
|
|
|
int database_length;
|
|
} SPIDER_COPY_TABLES;
|
|
|
|
class SPIDER_SORT
|
|
{
|
|
public:
|
|
ulong sort;
|
|
};
|
|
|
|
typedef struct st_spider_trx_ha
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
SPIDER_TRX *trx;
|
|
SPIDER_SHARE *share;
|
|
uint link_count;
|
|
uint link_bitmap_size;
|
|
uint *conn_link_idx;
|
|
uchar *conn_can_fo;
|
|
bool wait_for_reusing;
|
|
} SPIDER_TRX_HA;
|
|
|
|
#ifdef HA_CAN_BULK_ACCESS
|
|
typedef struct st_spider_bulk_access_link
|
|
{
|
|
ha_spider *spider;
|
|
uint sequence_num;
|
|
bool used;
|
|
bool called;
|
|
MEM_ROOT mem_root;
|
|
st_spider_bulk_access_link *next;
|
|
} SPIDER_BULK_ACCESS_LINK;
|
|
#endif
|
|
|
|
#define SPIDER_INT_HLD_TGT_SIZE 100
|
|
typedef struct st_spider_int_hld
|
|
{
|
|
uint tgt_num;
|
|
int tgt[SPIDER_INT_HLD_TGT_SIZE];
|
|
st_spider_int_hld *next;
|
|
} SPIDER_INT_HLD;
|
|
|
|
typedef struct st_spider_item_hld
|
|
{
|
|
uint tgt_num;
|
|
Item *item;
|
|
#ifdef SPIDER_ITEM_STRING_WITHOUT_SET_STR_WITH_COPY_AND_THDPTR
|
|
bool init_mem_root;
|
|
MEM_ROOT mem_root;
|
|
#endif
|
|
st_spider_item_hld *next;
|
|
} SPIDER_ITEM_HLD;
|
|
|
|
char *spider_create_string(
|
|
const char *str,
|
|
uint length
|
|
);
|