mirror of
https://github.com/MariaDB/server.git
synced 2025-01-16 03:52:35 +01:00
1621 lines
58 KiB
C++
1621 lines
58 KiB
C++
/* Copyright (C) 2008-2020 Kentoku Shiba
|
|
Copyright (C) 2019-2022 MariaDB corp
|
|
|
|
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 02110-1335 USA */
|
|
|
|
#define SPIDER_DETAIL_VERSION PACKAGE_VERSION
|
|
#define SPIDER_HEX_VERSION (MYSQL_VERSION_MAJOR << 8 | MYSQL_VERSION_MINOR)
|
|
|
|
#define spider_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
|
|
#define pthread_mutex_assert_owner(A) mysql_mutex_assert_owner(A)
|
|
#define pthread_mutex_assert_not_owner(A) mysql_mutex_assert_not_owner(A)
|
|
#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
|
|
|
|
#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_PARTITION_ADD ALTER_PARTITION_ADD
|
|
#define SPIDER_ALTER_PARTITION_DROP ALTER_PARTITION_DROP
|
|
#define SPIDER_ALTER_PARTITION_COALESCE ALTER_PARTITION_COALESCE
|
|
#define SPIDER_ALTER_PARTITION_REORGANIZE ALTER_PARTITION_REORGANIZE
|
|
#define SPIDER_ALTER_PARTITION_TABLE_REORG ALTER_PARTITION_TABLE_REORG
|
|
#define SPIDER_ALTER_PARTITION_REBUILD ALTER_PARTITION_REBUILD
|
|
#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
|
|
|
|
#define SPIDER_HAS_EXPLAIN_QUERY
|
|
|
|
#define SPIDER_TEST(A) MY_TEST(A)
|
|
|
|
#define SPIDER_ENGINE_CONDITION_PUSHDOWN_IS_ALWAYS_ON
|
|
|
|
#define SPIDER_Item_args_arg_count_IS_PROTECTED
|
|
|
|
#define SPIDER_Item_func_conv_charset_conv_charset collation.collation
|
|
|
|
#define SPIDER_WITHOUT_HA_STATISTIC_INCREMENT
|
|
#define SPIDER_init_read_record(A,B,C,D,E,F,G,H) init_read_record(A,B,C,D,E,F,G,H)
|
|
#define SPIDER_HAS_NEXT_THREAD_ID
|
|
#define SPIDER_new_THD(A) (new THD(A))
|
|
#define SPIDER_order_direction_is_asc(A) (A->direction == ORDER::ORDER_ASC)
|
|
|
|
#define SPIDER_open_temporary_table
|
|
|
|
#define SPIDER_generate_partition_syntax(A,B,C,D,E,F,G,H) generate_partition_syntax(A,B,C,E,F,G)
|
|
|
|
#define SPIDER_create_partition_name(A,B,C,D,E,F) create_partition_name(A,B,C,D,E,F)
|
|
#define SPIDER_create_subpartition_name(A,B,C,D,E,F) create_subpartition_name(A,B,C,D,E,F)
|
|
#define SPIDER_free_part_syntax(A,B)
|
|
|
|
#define SPIDER_read_record_read_record(A) read_record()
|
|
#define SPIDER_has_Item_with_subquery
|
|
#define SPIDER_use_LEX_CSTRING_for_database_tablename_alias
|
|
#define SPIDER_THD_db_str(A) (A)->db.str
|
|
#define SPIDER_THD_db_length(A) (A)->db.length
|
|
#define SPIDER_TABLE_LIST_db_str(A) (A)->db.str
|
|
#define SPIDER_TABLE_LIST_db_length(A) (A)->db.length
|
|
#define SPIDER_TABLE_LIST_table_name_str(A) (A)->table_name.str
|
|
#define SPIDER_TABLE_LIST_table_name_length(A) (A)->table_name.length
|
|
#define SPIDER_TABLE_LIST_alias_str(A) (A)->alias.str
|
|
#define SPIDER_TABLE_LIST_alias_length(A) (A)->alias.length
|
|
#define SPIDER_field_name_str(A) (A)->field_name.str
|
|
#define SPIDER_field_name_length(A) (A)->field_name.length
|
|
#define SPIDER_item_name_str(A) (A)->name.str
|
|
#define SPIDER_item_name_length(A) (A)->name.length
|
|
const LEX_CSTRING SPIDER_empty_string = {"", 0};
|
|
|
|
#define SPIDER_date_mode_t(A) date_mode_t(A)
|
|
#define SPIDER_str_to_datetime(A,B,C,D,E) str_to_datetime_or_date(A,B,C,D,E)
|
|
#define SPIDER_get_linkage(A) A->get_linkage()
|
|
|
|
typedef start_new_trans *SPIDER_Open_tables_backup;
|
|
|
|
#define SPIDER_reset_n_backup_open_tables_state(A,B,C) do { \
|
|
if (!(*(B) = new start_new_trans(A))) \
|
|
{ \
|
|
DBUG_RETURN(C); \
|
|
} \
|
|
} while (0)
|
|
#define SPIDER_restore_backup_open_tables_state(A,B) do { \
|
|
(*(B))->restore_old_transaction(); \
|
|
delete *(B); \
|
|
} while (0)
|
|
#define SPIDER_sys_close_thread_tables(A) (A)->commit_whole_transaction_and_close_tables()
|
|
|
|
#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)))
|
|
|
|
/* Change status of the remote backend server link. */
|
|
/* 0 Doesn't change status. */
|
|
#define SPIDER_LINK_STATUS_NO_CHANGE 0
|
|
/* 1 Changes status to OK. */
|
|
#define SPIDER_LINK_STATUS_OK 1
|
|
/* 2 Changes status to RECOVERY. */
|
|
#define SPIDER_LINK_STATUS_RECOVERY 2
|
|
/* 3 Changes status to no more in group communication. */
|
|
#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 23
|
|
#define SPIDER_TMP_SHARE_UINT_COUNT SPIDER_TMP_SHARE_CHAR_PTR_COUNT
|
|
#define SPIDER_TMP_SHARE_LONG_COUNT 19
|
|
#define SPIDER_TMP_SHARE_LONGLONG_COUNT 3
|
|
|
|
#define SPIDER_MEM_CALC_LIST_NUM 314
|
|
#define SPIDER_CONN_META_BUF_LEN 64
|
|
|
|
/*
|
|
IDs for spider mem alloc functions, including
|
|
- spider_alloc_calc_mem_init()
|
|
- spider_string::init_calc_mem()
|
|
- spider_malloc()
|
|
- spider_bulk_alloc_mem()
|
|
- spider_bulk_malloc()
|
|
In the format of
|
|
SPD_MID_<CALLSITE_FUNC_NAME_SANS_SPIDER_PREFIX>_<NO>
|
|
*/
|
|
enum spider_malloc_id {
|
|
SPD_MID_CHECK_HS_PK_UPDATE_1,
|
|
SPD_MID_COPY_TABLES_BODY_1,
|
|
SPD_MID_COPY_TABLES_BODY_2,
|
|
SPD_MID_COPY_TABLES_BODY_3,
|
|
SPD_MID_COPY_TABLES_BODY_4,
|
|
SPD_MID_COPY_TABLES_BODY_5,
|
|
SPD_MID_CREATE_CONN_1,
|
|
SPD_MID_CREATE_CONN_2,
|
|
SPD_MID_CREATE_CONN_3,
|
|
SPD_MID_CREATE_CONN_4,
|
|
SPD_MID_CREATE_CONN_5,
|
|
SPD_MID_CREATE_CONN_6,
|
|
SPD_MID_CREATE_CONN_KEYS_1,
|
|
SPD_MID_CREATE_CONN_THREAD_1,
|
|
SPD_MID_CREATE_LONGLONG_LIST_1,
|
|
SPD_MID_CREATE_LONG_LIST_1,
|
|
SPD_MID_CREATE_MON_THREADS_1,
|
|
SPD_MID_CREATE_MON_THREADS_2,
|
|
SPD_MID_CREATE_SHARE_1,
|
|
SPD_MID_CREATE_SHARE_2,
|
|
SPD_MID_CREATE_SPIDER_OBJECT_FOR_SHARE_1,
|
|
SPD_MID_CREATE_SPIDER_OBJECT_FOR_SHARE_2,
|
|
SPD_MID_CREATE_STRING_1,
|
|
SPD_MID_CREATE_STRING_LIST_1,
|
|
SPD_MID_CREATE_TABLE_HOLDER_1,
|
|
SPD_MID_CREATE_TABLE_NAME_STRING_1,
|
|
SPD_MID_CREATE_TRX_ALTER_TABLE_1,
|
|
SPD_MID_CREATE_TRX_HA_1,
|
|
SPD_MID_DB_CONN_QUEUE_ACTION_1,
|
|
SPD_MID_DB_FETCH_FOR_ITEM_SUM_FUNC_1,
|
|
SPD_MID_DB_FETCH_FOR_ITEM_SUM_FUNC_2,
|
|
SPD_MID_DB_FETCH_FOR_ITEM_SUM_FUNC_3,
|
|
SPD_MID_DB_HANDLERSOCKET_APPEND_REQUEST_KEY_1,
|
|
SPD_MID_DB_HANDLERSOCKET_EXEC_QUERY_1,
|
|
SPD_MID_DB_HANDLERSOCKET_INIT_1,
|
|
SPD_MID_DB_HANDLERSOCKET_RESULT_FETCH_ROW_FROM_TMP_TABLE_1,
|
|
SPD_MID_DB_HANDLERSOCKET_RESULT_FETCH_ROW_FROM_TMP_TABLE_2,
|
|
SPD_MID_DB_HANDLERSOCKET_ROW_APPEND_ESCAPED_TO_STR_1,
|
|
SPD_MID_DB_HANDLERSOCKET_ROW_CLONE_1,
|
|
SPD_MID_DB_HANDLERSOCKET_ROW_STORE_TO_FIELD_1,
|
|
SPD_MID_DB_HANDLERSOCKET_UTIL_APPEND_COLUMN_VALUE_1,
|
|
SPD_MID_DB_HANDLERSOCKET_UTIL_OPEN_ITEM_FUNC_1,
|
|
SPD_MID_DB_HANDLERSOCKET_UTIL_OPEN_ITEM_FUNC_2,
|
|
SPD_MID_DB_HANDLERSOCKET_UTIL_OPEN_ITEM_FUNC_3,
|
|
SPD_MID_DB_HS_STRING_REF_BUFFER_INIT_1,
|
|
SPD_MID_DB_HS_STR_BUFFER_ADD_1,
|
|
SPD_MID_DB_HS_STR_BUFFER_ADD_2,
|
|
SPD_MID_DB_HS_STR_BUFFER_INIT_1,
|
|
SPD_MID_DB_INIT_1,
|
|
SPD_MID_DB_INIT_10,
|
|
SPD_MID_DB_INIT_11,
|
|
SPD_MID_DB_INIT_12,
|
|
SPD_MID_DB_INIT_2,
|
|
SPD_MID_DB_INIT_3,
|
|
SPD_MID_DB_INIT_4,
|
|
SPD_MID_DB_INIT_5,
|
|
SPD_MID_DB_INIT_6,
|
|
SPD_MID_DB_INIT_7,
|
|
SPD_MID_DB_INIT_8,
|
|
SPD_MID_DB_INIT_9,
|
|
SPD_MID_DB_MARIADB_UTIL_APPEND_COLUMN_VALUE_1,
|
|
SPD_MID_DB_MARIADB_UTIL_APPEND_COLUMN_VALUE_2,
|
|
SPD_MID_DB_MBASE_EXEC_QUERY_1,
|
|
SPD_MID_DB_MBASE_EXEC_QUERY_2,
|
|
SPD_MID_DB_MBASE_INIT_1,
|
|
SPD_MID_DB_MBASE_INIT_2,
|
|
SPD_MID_DB_MBASE_RESULT_FETCH_ROW_FROM_TMP_TABLE_1,
|
|
SPD_MID_DB_MBASE_RESULT_FETCH_ROW_FROM_TMP_TABLE_2,
|
|
SPD_MID_DB_MBASE_RESULT_FETCH_ROW_FROM_TMP_TABLE_3,
|
|
SPD_MID_DB_MBASE_ROW_APPEND_ESCAPED_TO_STR_1,
|
|
SPD_MID_DB_MBASE_ROW_CLONE_1,
|
|
SPD_MID_DB_MBASE_SET_SQL_MODE_1,
|
|
SPD_MID_DB_MBASE_SET_TIME_ZONE_1,
|
|
SPD_MID_DB_MBASE_SET_WAIT_TIMEOUT_1,
|
|
SPD_MID_DB_MBASE_UTIL_PRINT_ITEM_FUNC_1,
|
|
SPD_MID_DB_MBASE_UTIL_PRINT_ITEM_FUNC_2,
|
|
SPD_MID_DB_MBASE_UTIL_PRINT_ITEM_FUNC_3,
|
|
SPD_MID_DB_MBASE_XA_COMMIT_1,
|
|
SPD_MID_DB_MBASE_XA_END_1,
|
|
SPD_MID_DB_MBASE_XA_PREPARE_1,
|
|
SPD_MID_DB_MBASE_XA_ROLLBACK_1,
|
|
SPD_MID_DB_MYSQL_UTIL_APPEND_COLUMN_VALUE_1,
|
|
SPD_MID_DB_MYSQL_UTIL_APPEND_COLUMN_VALUE_2,
|
|
SPD_MID_DB_OPEN_ITEM_INT_1,
|
|
SPD_MID_DB_OPEN_ITEM_STRING_1,
|
|
SPD_MID_DB_ORACLE_EXEC_QUERY_1,
|
|
SPD_MID_DB_ORACLE_GET_ERROR_1,
|
|
SPD_MID_DB_ORACLE_INIT_1,
|
|
SPD_MID_DB_ORACLE_INIT_2,
|
|
SPD_MID_DB_ORACLE_RESULT_FETCH_ROW_FROM_TMP_TABLE_1,
|
|
SPD_MID_DB_ORACLE_RESULT_FETCH_ROW_FROM_TMP_TABLE_2,
|
|
SPD_MID_DB_ORACLE_RESULT_FETCH_ROW_FROM_TMP_TABLE_3,
|
|
SPD_MID_DB_ORACLE_ROW_APPEND_ESCAPED_TO_STR_1,
|
|
SPD_MID_DB_ORACLE_ROW_INIT_1,
|
|
SPD_MID_DB_ORACLE_ROW_INIT_2,
|
|
SPD_MID_DB_ORACLE_UTIL_APPEND_COLUMN_VALUE_1,
|
|
SPD_MID_DB_ORACLE_UTIL_APPEND_COLUMN_VALUE_2,
|
|
SPD_MID_DB_ORACLE_UTIL_OPEN_ITEM_FUNC_1,
|
|
SPD_MID_DB_ORACLE_UTIL_OPEN_ITEM_FUNC_2,
|
|
SPD_MID_DB_ORACLE_UTIL_OPEN_ITEM_FUNC_3,
|
|
SPD_MID_DB_QUERY_1,
|
|
SPD_MID_DB_STORE_RESULT_1,
|
|
SPD_MID_DB_STORE_RESULT_2,
|
|
SPD_MID_DB_STORE_RESULT_3,
|
|
SPD_MID_DB_STORE_RESULT_4,
|
|
SPD_MID_DB_STORE_RESULT_5,
|
|
SPD_MID_DB_STORE_RESULT_FOR_REUSE_CURSOR_1,
|
|
SPD_MID_DB_UDF_COPY_TABLES_1,
|
|
SPD_MID_DB_UDF_PING_TABLE_1,
|
|
SPD_MID_DB_UDF_PING_TABLE_2,
|
|
SPD_MID_DB_UDF_PING_TABLE_APPEND_MON_NEXT_1,
|
|
SPD_MID_DB_UDF_PING_TABLE_APPEND_MON_NEXT_2,
|
|
SPD_MID_DB_UDF_PING_TABLE_MON_NEXT_1,
|
|
SPD_MID_DIRECT_SQL_BODY_1,
|
|
SPD_MID_DIRECT_SQL_INIT_BODY_1,
|
|
SPD_MID_DISCOVER_TABLE_STRUCTURE_1,
|
|
SPD_MID_FIELDS_CREATE_CONN_HOLDER_1,
|
|
SPD_MID_FIELDS_CREATE_LINK_IDX_CHAIN_1,
|
|
SPD_MID_FIELDS_CREATE_LINK_IDX_HOLDER_1,
|
|
SPD_MID_GET_INIT_ERROR_TABLE_1,
|
|
SPD_MID_GET_LGTM_TBLHND_SHARE_1,
|
|
SPD_MID_GET_PING_TABLE_MON_1,
|
|
SPD_MID_GET_PING_TABLE_TGT_1,
|
|
SPD_MID_GET_PT_SHARE_1,
|
|
SPD_MID_GET_PT_SHARE_2,
|
|
SPD_MID_GET_SHARE_1,
|
|
SPD_MID_GET_SHARE_2,
|
|
SPD_MID_GET_TRX_1,
|
|
SPD_MID_GET_TRX_10,
|
|
SPD_MID_GET_TRX_2,
|
|
SPD_MID_GET_TRX_3,
|
|
SPD_MID_GET_TRX_4,
|
|
SPD_MID_GET_TRX_5,
|
|
SPD_MID_GET_TRX_6,
|
|
SPD_MID_GET_TRX_7,
|
|
SPD_MID_GET_TRX_8,
|
|
SPD_MID_GET_TRX_9,
|
|
SPD_MID_HANDLERSOCKET_HANDLER_INIT_1,
|
|
SPD_MID_HANDLERSOCKET_HANDLER_INIT_2,
|
|
SPD_MID_HANDLERSOCKET_HANDLER_SPIDER_HANDLERSOCKET_HANDLER_1,
|
|
SPD_MID_HANDLERSOCKET_SHARE_CREATE_COLUMN_NAME_STR_1,
|
|
SPD_MID_HANDLERSOCKET_SHARE_CREATE_TABLE_NAMES_STR_1,
|
|
SPD_MID_HANDLERSOCKET_SHARE_CREATE_TABLE_NAMES_STR_2,
|
|
SPD_MID_HANDLERSOCKET_SHARE_CREATE_TABLE_NAMES_STR_3,
|
|
SPD_MID_HANDLERSOCKET_SHARE_INIT_1,
|
|
SPD_MID_HANDLERSOCKET_SHARE_SPIDER_HANDLERSOCKET_SHARE_1,
|
|
SPD_MID_HA_SPIDER_COND_PUSH_1,
|
|
SPD_MID_HA_SPIDER_CREATE_1,
|
|
SPD_MID_HA_SPIDER_CREATE_2,
|
|
SPD_MID_HA_SPIDER_CREATE_BULK_ACCESS_LINK_1,
|
|
SPD_MID_HA_SPIDER_FT_INIT_EXT_1,
|
|
SPD_MID_HA_SPIDER_HA_SPIDER_1,
|
|
SPD_MID_HA_SPIDER_HA_SPIDER_2,
|
|
SPD_MID_HA_SPIDER_INFO_PUSH_1,
|
|
SPD_MID_HA_SPIDER_MULTI_RANGE_READ_NEXT_FIRST_1,
|
|
SPD_MID_HA_SPIDER_MULTI_RANGE_READ_NEXT_FIRST_2,
|
|
SPD_MID_HA_SPIDER_MULTI_RANGE_READ_NEXT_FIRST_3,
|
|
SPD_MID_HA_SPIDER_OPEN_1,
|
|
SPD_MID_HA_SPIDER_OPEN_2,
|
|
SPD_MID_HA_SPIDER_OPEN_3,
|
|
SPD_MID_HA_SPIDER_OPEN_4,
|
|
SPD_MID_HA_SPIDER_OPEN_5,
|
|
SPD_MID_HA_SPIDER_OPEN_6,
|
|
SPD_MID_HA_SPIDER_OPEN_7,
|
|
SPD_MID_INCREASE_LONGLONG_LIST_1,
|
|
SPD_MID_INCREASE_LONG_LIST_1,
|
|
SPD_MID_INCREASE_NULL_STRING_LIST_1,
|
|
SPD_MID_INCREASE_STRING_LIST_1,
|
|
SPD_MID_MBASE_COPY_TABLE_INIT_1,
|
|
SPD_MID_MBASE_HANDLER_APPEND_KEY_COLUMN_TYPES_1,
|
|
SPD_MID_MBASE_HANDLER_APPEND_MATCH_AGAINST_1,
|
|
SPD_MID_MBASE_HANDLER_APPEND_TMP_TABLE_AND_SQL_FOR_BKA_1,
|
|
SPD_MID_MBASE_HANDLER_APPEND_UNION_TABLE_AND_SQL_FOR_BKA_1,
|
|
SPD_MID_MBASE_HANDLER_INIT_1,
|
|
SPD_MID_MBASE_HANDLER_INIT_2,
|
|
SPD_MID_MBASE_HANDLER_INIT_3,
|
|
SPD_MID_MBASE_HANDLER_INIT_4,
|
|
SPD_MID_MBASE_HANDLER_INIT_5,
|
|
SPD_MID_MBASE_HANDLER_INIT_6,
|
|
SPD_MID_MBASE_HANDLER_INIT_7,
|
|
SPD_MID_MBASE_HANDLER_INIT_8,
|
|
SPD_MID_MBASE_HANDLER_INIT_9,
|
|
SPD_MID_MBASE_HANDLER_INIT_UNION_TABLE_NAME_POS_1,
|
|
SPD_MID_MBASE_HANDLER_SET_SQL_FOR_EXEC_1,
|
|
SPD_MID_MBASE_HANDLER_SET_UNION_TABLE_NAME_POS_1,
|
|
SPD_MID_MBASE_HANDLER_SPIDER_MBASE_HANDLER_1,
|
|
SPD_MID_MBASE_SHARE_APPEND_SHOW_INDEX_1,
|
|
SPD_MID_MBASE_SHARE_APPEND_SHOW_INDEX_2,
|
|
SPD_MID_MBASE_SHARE_APPEND_SHOW_RECORDS_1,
|
|
SPD_MID_MBASE_SHARE_APPEND_SHOW_TABLE_STATUS_1,
|
|
SPD_MID_MBASE_SHARE_APPEND_SHOW_TABLE_STATUS_2,
|
|
SPD_MID_MBASE_SHARE_CREATE_COLUMN_NAME_STR_1,
|
|
SPD_MID_MBASE_SHARE_CREATE_TABLE_NAMES_STR_1,
|
|
SPD_MID_MBASE_SHARE_CREATE_TABLE_NAMES_STR_2,
|
|
SPD_MID_MBASE_SHARE_CREATE_TABLE_NAMES_STR_3,
|
|
SPD_MID_MBASE_SHARE_DISCOVER_TABLE_STRUCTURE_1,
|
|
SPD_MID_MBASE_SHARE_INIT_1,
|
|
SPD_MID_MBASE_SHARE_INIT_2,
|
|
SPD_MID_MBASE_SHARE_INIT_3,
|
|
SPD_MID_MBASE_SHARE_INIT_4,
|
|
SPD_MID_MBASE_SHARE_SPIDER_MBASE_SHARE_1,
|
|
SPD_MID_OPEN_ALL_TABLES_1,
|
|
SPD_MID_OPEN_SYS_TABLE_1,
|
|
SPD_MID_ORACLE_COPY_TABLE_COPY_ROWS_1,
|
|
SPD_MID_ORACLE_COPY_TABLE_COPY_ROWS_2,
|
|
SPD_MID_ORACLE_COPY_TABLE_COPY_ROWS_3,
|
|
SPD_MID_ORACLE_COPY_TABLE_COPY_ROWS_4,
|
|
SPD_MID_ORACLE_COPY_TABLE_INIT_1,
|
|
SPD_MID_ORACLE_COPY_TABLE_INIT_2,
|
|
SPD_MID_ORACLE_HANDLER_APPEND_KEY_COLUMN_TYPES_1,
|
|
SPD_MID_ORACLE_HANDLER_APPEND_MATCH_AGAINST_1,
|
|
SPD_MID_ORACLE_HANDLER_APPEND_TMP_TABLE_AND_SQL_FOR_BKA_1,
|
|
SPD_MID_ORACLE_HANDLER_APPEND_UNION_TABLE_AND_SQL_FOR_BKA_1,
|
|
SPD_MID_ORACLE_HANDLER_INIT_1,
|
|
SPD_MID_ORACLE_HANDLER_INIT_2,
|
|
SPD_MID_ORACLE_HANDLER_INIT_3,
|
|
SPD_MID_ORACLE_HANDLER_INIT_4,
|
|
SPD_MID_ORACLE_HANDLER_INIT_5,
|
|
SPD_MID_ORACLE_HANDLER_INIT_6,
|
|
SPD_MID_ORACLE_HANDLER_INIT_7,
|
|
SPD_MID_ORACLE_HANDLER_INIT_8,
|
|
SPD_MID_ORACLE_HANDLER_INIT_9,
|
|
SPD_MID_ORACLE_HANDLER_INIT_UNION_TABLE_NAME_POS_1,
|
|
SPD_MID_ORACLE_HANDLER_SET_SQL_FOR_EXEC_1,
|
|
SPD_MID_ORACLE_HANDLER_SET_UNION_TABLE_NAME_POS_1,
|
|
SPD_MID_ORACLE_HANDLER_SPIDER_ORACLE_HANDLER_1,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_AUTOINC_1,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_INDEX_1,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_INDEX_2,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_LAST_INSERT_ID_1,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_LAST_INSERT_ID_2,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_RECORDS_1,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_TABLE_STATUS_1,
|
|
SPD_MID_ORACLE_SHARE_APPEND_SHOW_TABLE_STATUS_2,
|
|
SPD_MID_ORACLE_SHARE_CREATE_COLUMN_NAME_STR_1,
|
|
SPD_MID_ORACLE_SHARE_CREATE_TABLE_NAMES_STR_1,
|
|
SPD_MID_ORACLE_SHARE_CREATE_TABLE_NAMES_STR_2,
|
|
SPD_MID_ORACLE_SHARE_CREATE_TABLE_NAMES_STR_3,
|
|
SPD_MID_ORACLE_SHARE_INIT_1,
|
|
SPD_MID_ORACLE_SHARE_INIT_2,
|
|
SPD_MID_ORACLE_SHARE_INIT_3,
|
|
SPD_MID_ORACLE_SHARE_INIT_4,
|
|
SPD_MID_ORACLE_SHARE_SPIDER_ORACLE_SHARE_1,
|
|
SPD_MID_PARSE_CONNECT_INFO_1,
|
|
SPD_MID_PING_TABLE_BODY_1,
|
|
SPD_MID_PING_TABLE_BODY_2,
|
|
SPD_MID_PING_TABLE_INIT_BODY_1,
|
|
SPD_MID_PING_TABLE_MON_FROM_TABLE_1,
|
|
SPD_MID_RELEASE_PING_TABLE_MON_LIST_1,
|
|
SPD_MID_TRX_ANOTHER_LOCK_TABLES_1,
|
|
SPD_MID_UDF_COPY_TABLES_CREATE_TABLE_LIST_1,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_CONN_1,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_CONN_2,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_CONN_3,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_CONN_4,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_CONN_KEY_1,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_TABLE_LIST_1,
|
|
SPD_MID_UDF_DIRECT_SQL_CREATE_TABLE_LIST_2,
|
|
SPD_MID_UDF_GET_COPY_TGT_TABLES_1
|
|
};
|
|
|
|
#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_table_mon_list SPIDER_TABLE_MON_LIST;
|
|
typedef struct st_spider_ip_port_conn SPIDER_IP_PORT_CONN;
|
|
|
|
typedef struct st_spider_thread
|
|
{
|
|
uint thread_idx;
|
|
THD *thd;
|
|
volatile bool killed;
|
|
volatile bool thd_wait;
|
|
volatile bool first_free_wait;
|
|
volatile int error;
|
|
pthread_t thread;
|
|
pthread_cond_t cond;
|
|
pthread_mutex_t mutex;
|
|
pthread_cond_t sync_cond;
|
|
volatile SPIDER_SHARE *queue_first;
|
|
volatile SPIDER_SHARE *queue_last;
|
|
} SPIDER_THREAD;
|
|
|
|
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;
|
|
my_hash_value_type db_table_str_hash_value;
|
|
} 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;
|
|
my_hash_value_type table_name_hash_value;
|
|
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;
|
|
char **tmp_tgt_dsns;
|
|
char **tmp_tgt_filedsns;
|
|
char **tmp_tgt_drivers;
|
|
char **tmp_static_link_ids;
|
|
long *tmp_tgt_ports;
|
|
long *tmp_tgt_ssl_vscs;
|
|
long *tmp_monitoring_binlog_pos_at_failing;
|
|
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_tgt_dsns_lengths;
|
|
uint *tmp_tgt_filedsns_lengths;
|
|
uint *tmp_tgt_drivers_lengths;
|
|
uint *tmp_static_link_ids_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_tgt_dsns_charlen;
|
|
uint tmp_tgt_filedsns_charlen;
|
|
uint tmp_tgt_drivers_charlen;
|
|
uint tmp_static_link_ids_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_dsns_length;
|
|
uint tmp_tgt_filedsns_length;
|
|
uint tmp_tgt_drivers_length;
|
|
uint tmp_static_link_ids_length;
|
|
uint tmp_tgt_ports_length;
|
|
uint tmp_tgt_ssl_vscs_length;
|
|
uint tmp_monitoring_binlog_pos_at_failing_length;
|
|
uint tmp_link_statuses_length;
|
|
} SPIDER_ALTER_TABLE;
|
|
|
|
typedef struct st_spider_conn_loop_check SPIDER_CONN_LOOP_CHECK;
|
|
|
|
/* database connection */
|
|
typedef struct st_spider_conn
|
|
{
|
|
char *conn_key;
|
|
uint conn_key_length;
|
|
my_hash_value_type conn_key_hash_value;
|
|
int link_idx;
|
|
spider_db_conn *db_conn;
|
|
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;
|
|
int wait_timeout;
|
|
sql_mode_t sql_mode;
|
|
THD *thd;
|
|
void *another_ha_first;
|
|
void *another_ha_last;
|
|
/* Exactly one of p_small and p_big is not null */
|
|
/* The parent node in the binary tree ordered by priority with a
|
|
smaller or equal priority */
|
|
st_spider_conn *p_small;
|
|
/* The parent node in the binary tree ordered by priority with a
|
|
bigger priority */
|
|
st_spider_conn *p_big;
|
|
/* The child node in the binary tree ordered by priority with a
|
|
smaller priority */
|
|
st_spider_conn *c_small;
|
|
/* The child node in the binary tree ordered by priority with a
|
|
bigger or equal priority */
|
|
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_db; /* for not joinable tables on different db */
|
|
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 *tgt_dsn;
|
|
char *tgt_filedsn;
|
|
char *tgt_driver;
|
|
long tgt_port;
|
|
long tgt_ssl_vsc;
|
|
|
|
uint tgt_host_length;
|
|
uint tgt_username_length;
|
|
uint tgt_password_length;
|
|
uint tgt_socket_length;
|
|
uint tgt_wrapper_length;
|
|
uint tgt_db_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 tgt_dsn_length;
|
|
uint tgt_filedsn_length;
|
|
uint tgt_driver_length;
|
|
uint dbton_id;
|
|
|
|
volatile
|
|
void *quick_target;
|
|
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;
|
|
volatile
|
|
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_wait_timeout;
|
|
bool queued_autocommit;
|
|
bool queued_sql_log_off;
|
|
bool queued_sql_mode;
|
|
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;
|
|
int queued_wait_timeout_val;
|
|
bool queued_autocommit_val;
|
|
bool queued_sql_log_off_val;
|
|
sql_mode_t queued_sql_mode_val;
|
|
Time_zone *queued_time_zone_val;
|
|
XID *queued_xa_start_xid;
|
|
|
|
|
|
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_HOLDER *conn_holder_for_direct_join;
|
|
SPIDER_LINK_IDX_CHAIN *link_idx_chain;
|
|
SPIDER_IP_PORT_CONN *ip_port_conn;
|
|
|
|
pthread_mutex_t loop_check_mutex;
|
|
/*
|
|
A hash of SPIDER_CONN_LOOP_CHECK, indexed by
|
|
SPIDER_CONN_LOOP_CHECK::full_name
|
|
*/
|
|
HASH loop_checked;
|
|
uint loop_checked_id;
|
|
const char *loop_checked_func_name;
|
|
const char *loop_checked_file_name;
|
|
ulong loop_checked_line_no;
|
|
/*
|
|
A hash of SPIDER_CONN_LOOP_CHECK, indexed by
|
|
SPIDER_CONN_LOOP_CHECK::to_name
|
|
*/
|
|
HASH loop_check_queue;
|
|
uint loop_check_queue_id;
|
|
const char *loop_check_queue_func_name;
|
|
const char *loop_check_queue_file_name;
|
|
ulong loop_check_queue_line_no;
|
|
} SPIDER_CONN;
|
|
|
|
typedef struct st_spider_lgtm_tblhnd_share
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
my_hash_value_type table_path_hash_value;
|
|
pthread_mutex_t auto_increment_mutex;
|
|
volatile bool auto_increment_init;
|
|
volatile ulonglong auto_increment_lclval;
|
|
ulonglong auto_increment_value;
|
|
} SPIDER_LGTM_TBLHND_SHARE;
|
|
|
|
typedef struct st_spider_patition_handler
|
|
{
|
|
bool clone_bitmap_init;
|
|
query_id_t parallel_search_query_id;
|
|
uint no_parts;
|
|
TABLE *table;
|
|
ha_spider *owner;
|
|
ha_spider **handlers;
|
|
} SPIDER_PARTITION_HANDLER;
|
|
|
|
typedef struct st_spider_wide_share
|
|
{
|
|
char *table_name;
|
|
uint table_name_length;
|
|
my_hash_value_type table_path_hash_value;
|
|
uint use_count;
|
|
THR_LOCK lock;
|
|
pthread_mutex_t sts_mutex;
|
|
pthread_mutex_t crd_mutex;
|
|
|
|
volatile bool sts_init;
|
|
volatile bool crd_init;
|
|
volatile time_t sts_get_time;
|
|
volatile time_t crd_get_time;
|
|
ha_statistics stat;
|
|
|
|
longlong *cardinality;
|
|
} SPIDER_WIDE_SHARE;
|
|
|
|
enum spider_hnd_stage {
|
|
SPD_HND_STAGE_NONE,
|
|
SPD_HND_STAGE_STORE_LOCK,
|
|
SPD_HND_STAGE_EXTERNAL_LOCK,
|
|
SPD_HND_STAGE_START_STMT,
|
|
SPD_HND_STAGE_EXTRA,
|
|
SPD_HND_STAGE_COND_PUSH,
|
|
SPD_HND_STAGE_COND_POP,
|
|
SPD_HND_STAGE_INFO_PUSH,
|
|
SPD_HND_STAGE_SET_TOP_TABLE_AND_FIELDS,
|
|
SPD_HND_STAGE_CLEAR_TOP_TABLE_FIELDS
|
|
};
|
|
|
|
/*
|
|
A wide handler is shared among ha_spider of partitions of the same
|
|
table. It is owned by the last partition.
|
|
*/
|
|
typedef struct st_spider_wide_handler
|
|
{
|
|
spider_hnd_stage stage;
|
|
handler *stage_executor;
|
|
THR_LOCK_DATA lock;
|
|
SPIDER_TRX *trx;
|
|
uchar *searched_bitmap;
|
|
uchar *ft_discard_bitmap;
|
|
uchar *position_bitmap;
|
|
uchar *idx_read_bitmap;
|
|
uchar *idx_write_bitmap;
|
|
uchar *rnd_read_bitmap;
|
|
uchar *rnd_write_bitmap;
|
|
SPIDER_CONDITION *condition;
|
|
void *owner;
|
|
SPIDER_PARTITION_HANDLER *partition_handler;
|
|
List<Item> *direct_update_fields;
|
|
List<Item> *direct_update_values;
|
|
TABLE_SHARE *top_share;
|
|
enum thr_lock_type lock_type;
|
|
uchar lock_table_type;
|
|
int lock_mode;
|
|
int external_lock_type;
|
|
int cond_check_error;
|
|
uint sql_command;
|
|
uint top_table_fields;
|
|
#ifdef INFO_KIND_FORCE_LIMIT_BEGIN
|
|
longlong info_limit;
|
|
#endif
|
|
bool between_flg;
|
|
bool idx_bitmap_is_set;
|
|
bool rnd_bitmap_is_set;
|
|
bool position_bitmap_init;
|
|
bool semi_trx_isolation_chk;
|
|
bool semi_trx_chk;
|
|
bool low_priority;
|
|
bool high_priority;
|
|
bool consistent_snapshot;
|
|
bool quick_mode;
|
|
bool keyread;
|
|
bool update_request;
|
|
bool ignore_dup_key;
|
|
bool write_can_replace;
|
|
bool insert_with_update;
|
|
bool cond_check;
|
|
bool semi_table_lock;
|
|
} SPIDER_WIDE_HANDLER;
|
|
|
|
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;
|
|
|
|
bool updated_in_this_trx;
|
|
|
|
THD *thd;
|
|
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;
|
|
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;
|
|
uint locked_connections;
|
|
|
|
ulonglong direct_update_count;
|
|
ulonglong direct_delete_count;
|
|
ulonglong direct_order_limit_count;
|
|
ulonglong direct_aggregate_count;
|
|
ulonglong parallel_search_count;
|
|
|
|
|
|
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;
|
|
/**
|
|
Probably equals `active_link_count`. See also commit ddff602 of
|
|
https://github.com/nayuta-yanagisawa/spider-history
|
|
|
|
FIXME: consider removing it and using `active_link_count` instead.
|
|
*/
|
|
uint link_count;
|
|
/* Number of all links, i.e. all remote servers for the spider
|
|
table. */
|
|
uint all_link_count;
|
|
/*
|
|
The bitmap size of ha_spider::conn_can_fo, where the ha_spider
|
|
is the one `this' associates with (i.e. spider->share == this)
|
|
*/
|
|
uint link_bitmap_size;
|
|
pthread_mutex_t mutex;
|
|
pthread_mutex_t sts_mutex;
|
|
pthread_mutex_t crd_mutex;
|
|
TABLE_SHARE *table_share;
|
|
SPIDER_LGTM_TBLHND_SHARE *lgtm_tblhnd_share;
|
|
my_hash_value_type table_name_hash_value;
|
|
my_hash_value_type table_path_hash_value;
|
|
|
|
/* Whether the share has been initialised */
|
|
volatile bool init;
|
|
/* Whether an error occurred in initialisation of this share */
|
|
volatile bool init_error;
|
|
/* The time of the initialisation 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;
|
|
volatile time_t bg_sts_try_time;
|
|
volatile double bg_sts_interval;
|
|
volatile int bg_sts_mode;
|
|
volatile int bg_sts_sync;
|
|
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;
|
|
volatile time_t crd_get_time;
|
|
volatile time_t bg_crd_try_time;
|
|
volatile double bg_crd_interval;
|
|
volatile int bg_crd_mode;
|
|
volatile int bg_crd_sync;
|
|
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;
|
|
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;
|
|
/* static bg thread for sts and crd */
|
|
TABLE table;
|
|
ha_spider *sts_spider;
|
|
ha_spider *crd_spider;
|
|
SPIDER_THREAD *sts_thread;
|
|
SPIDER_THREAD *crd_thread;
|
|
volatile bool sts_spider_init;
|
|
volatile bool sts_working;
|
|
volatile bool sts_wait;
|
|
volatile bool crd_spider_init;
|
|
volatile bool crd_working;
|
|
volatile bool crd_wait;
|
|
volatile SPIDER_SHARE *sts_prev;
|
|
volatile SPIDER_SHARE *sts_next;
|
|
volatile SPIDER_SHARE *crd_prev;
|
|
volatile SPIDER_SHARE *crd_next;
|
|
|
|
MEM_ROOT mem_root;
|
|
|
|
ha_statistics stat;
|
|
|
|
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;
|
|
|
|
/** See `mysql_sysvar_sts_bg_mode` */
|
|
int sts_bg_mode;
|
|
/** See `mysql_sysvar_sts_interval` */
|
|
double sts_interval;
|
|
/** See `mysql_sysvar_sts_mode` */
|
|
int sts_mode;
|
|
/** See `mysql_sysvar_sts_sync` */
|
|
int sts_sync;
|
|
int store_last_sts;
|
|
/** See `mysql_sysvar_load_sts_at_startup` */
|
|
int load_sts_at_startup;
|
|
/** See `mysql_sysvar_crd_bg_mode` */
|
|
int crd_bg_mode;
|
|
/** See `mysql_sysvar_crd_interval` */
|
|
double crd_interval;
|
|
/** See `mysql_sysvar_crd_mode` */
|
|
int crd_mode;
|
|
/** See `mysql_sysvar_crd_sync` */
|
|
int crd_sync;
|
|
int store_last_crd;
|
|
/** See `mysql_sysvar_load_crd_at_startup` */
|
|
int load_crd_at_startup;
|
|
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 bulk_size;
|
|
int bulk_update_mode;
|
|
int bulk_update_size;
|
|
int buffer_size;
|
|
int internal_optimize;
|
|
int internal_optimize_local;
|
|
double scan_rate;
|
|
double read_rate;
|
|
longlong priority;
|
|
int quick_mode;
|
|
longlong quick_page_size;
|
|
longlong quick_page_byte;
|
|
int low_mem_read;
|
|
int table_count_mode;
|
|
int select_column_mode;
|
|
int bgs_mode;
|
|
longlong bgs_first_read;
|
|
longlong bgs_second_read;
|
|
longlong first_read;
|
|
longlong second_read;
|
|
/** See `mysql_sysvar_auto_increment_mode` */
|
|
int auto_increment_mode;
|
|
int use_table_charset;
|
|
int use_pushdown_udf;
|
|
int skip_default_condition;
|
|
int skip_parallel_search;
|
|
int direct_dup_insert;
|
|
longlong direct_order_limit;
|
|
int read_only_mode;
|
|
int error_read_mode;
|
|
int error_write_mode;
|
|
/* Number of active remote servers, for use in load balancing read
|
|
connections */
|
|
int active_link_count;
|
|
#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;
|
|
|
|
my_hash_value_type *conn_keys_hash_value;
|
|
char **server_names;
|
|
char **tgt_table_names;
|
|
char **tgt_dbs;
|
|
char **tgt_hosts;
|
|
char **tgt_usernames;
|
|
char **tgt_passwords;
|
|
char **tgt_sockets;
|
|
/** The wrapper of target servers, each element has the same
|
|
possible values as `SPIDER_DBTON::wrapper` */
|
|
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_dsns;
|
|
char **tgt_filedsns;
|
|
char **tgt_drivers;
|
|
char **static_link_ids;
|
|
char **tgt_pk_names;
|
|
char **tgt_sequence_names;
|
|
char **conn_keys;
|
|
long *tgt_ports;
|
|
long *tgt_ssl_vscs;
|
|
/* See SPIDER_LINK_STATUS_* in spd_include.h */
|
|
long *link_statuses;
|
|
long *monitoring_bg_flag;
|
|
long *monitoring_bg_kind;
|
|
long *monitoring_binlog_pos_at_failing;
|
|
long *monitoring_flag;
|
|
long *monitoring_kind;
|
|
longlong *monitoring_bg_interval;
|
|
longlong *monitoring_limit;
|
|
longlong *monitoring_sid;
|
|
long *connect_timeouts;
|
|
long *net_read_timeouts;
|
|
long *net_write_timeouts;
|
|
/* Connection load balancing integer weight */
|
|
long *access_balances;
|
|
long *bka_table_name_types;
|
|
long *strict_group_bys;
|
|
|
|
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_dsns_lengths;
|
|
uint *tgt_filedsns_lengths;
|
|
uint *tgt_drivers_lengths;
|
|
uint *static_link_ids_lengths;
|
|
uint *tgt_pk_names_lengths;
|
|
uint *tgt_sequence_names_lengths;
|
|
uint *conn_keys_lengths;
|
|
/* The index in `spider_dbton' of each data node link. */
|
|
uint *sql_dbton_ids;
|
|
|
|
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_dsns_charlen;
|
|
uint tgt_filedsns_charlen;
|
|
uint tgt_drivers_charlen;
|
|
uint static_link_ids_charlen;
|
|
uint tgt_pk_names_charlen;
|
|
uint tgt_sequence_names_charlen;
|
|
uint conn_keys_charlen;
|
|
|
|
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_dsns_length;
|
|
uint tgt_filedsns_length;
|
|
uint tgt_drivers_length;
|
|
uint static_link_ids_length;
|
|
uint tgt_pk_names_length;
|
|
uint tgt_sequence_names_length;
|
|
uint conn_keys_length;
|
|
uint tgt_ports_length;
|
|
uint tgt_ssl_vscs_length;
|
|
uint link_statuses_length;
|
|
uint monitoring_bg_flag_length;
|
|
uint monitoring_bg_kind_length;
|
|
uint monitoring_binlog_pos_at_failing_length;
|
|
uint monitoring_flag_length;
|
|
uint monitoring_kind_length;
|
|
uint monitoring_bg_interval_length;
|
|
uint monitoring_limit_length;
|
|
uint monitoring_sid_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;
|
|
uint strict_group_bys_length;
|
|
|
|
/*
|
|
For dbton. A `SPIDER_SHARE` uses all `SPIDER_DBTON`s with the same
|
|
wrappers as any its `tgt_wrappers`
|
|
*/
|
|
/* Specifies which dbtons of the `spider_dbton` to use */
|
|
uchar dbton_bitmap[spider_bitmap_size(SPIDER_DBTON_SIZE)];
|
|
spider_db_share *dbton_share[SPIDER_DBTON_SIZE];
|
|
/* Number of `SPIDER_DBTON`s used */
|
|
uint use_dbton_count;
|
|
/* Index of each `SPIDER_DBTON` in `spider_dbton` to use */
|
|
/* Actual size is `use_dbton_count'. Values are the indices of item
|
|
in `spider_dbton'. */
|
|
uint use_dbton_ids[SPIDER_DBTON_SIZE];
|
|
/* Inverse map of `use_dbton_ids'. */
|
|
uint dbton_id_to_seq[SPIDER_DBTON_SIZE];
|
|
uint use_sql_dbton_count;
|
|
/* Actual size is `use_sql_dbton_count'. Values are the indices of
|
|
item in `spider_dbton'. */
|
|
uint use_sql_dbton_ids[SPIDER_DBTON_SIZE];
|
|
/* Inverse map of `use_sql_dbton_ids'. */
|
|
uint sql_dbton_id_to_seq[SPIDER_DBTON_SIZE];
|
|
|
|
SPIDER_ALTER_TABLE alter_table;
|
|
SPIDER_WIDE_SHARE *wide_share;
|
|
} SPIDER_SHARE;
|
|
|
|
typedef struct st_spider_link_pack
|
|
{
|
|
SPIDER_SHARE *share;
|
|
int link_idx;
|
|
} SPIDER_LINK_PACK;
|
|
|
|
/** A struct storing the initialisation error of a table. All
|
|
instances are in `spider_init_error_tables` */
|
|
typedef struct st_spider_init_error_table
|
|
{
|
|
/* The associated table name */
|
|
char *table_name;
|
|
/* Length of the associated table name */
|
|
uint table_name_length;
|
|
/* Hash value of the associated table name for lookup */
|
|
my_hash_value_type table_name_hash_value;
|
|
/* Whether the error has a message */
|
|
bool init_error_with_message;
|
|
/* The error message */
|
|
char init_error_msg[MYSQL_ERRMSG_SIZE];
|
|
/* The error code */
|
|
volatile int init_error;
|
|
/* The error time */
|
|
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;
|
|
|
|
/* for using real table */
|
|
bool real_table_used;
|
|
TABLE_LIST *table_list_first;
|
|
TABLE_LIST *table_list;
|
|
uchar *real_table_bitmap;
|
|
SPIDER_Open_tables_backup open_tables_backup;
|
|
THD *open_tables_thd;
|
|
|
|
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;
|
|
int use_real_table;
|
|
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 *tgt_dsn;
|
|
char *tgt_filedsn;
|
|
char *tgt_driver;
|
|
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 tgt_dsn_length;
|
|
uint tgt_filedsn_length;
|
|
uint tgt_driver_length;
|
|
uint conn_key_length;
|
|
uint dbton_id;
|
|
my_hash_value_type conn_key_hash_value;
|
|
|
|
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_list *parent;
|
|
st_spider_table_mon *next;
|
|
} SPIDER_TABLE_MON;
|
|
|
|
/* List of `SPIDER_TABLE_MON's */
|
|
typedef struct st_spider_table_mon_list
|
|
{
|
|
char *key;
|
|
uint key_length;
|
|
my_hash_value_type key_hash_value;
|
|
|
|
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;
|
|
int bg_error_num;
|
|
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;
|
|
int bg_mode;
|
|
|
|
char *database;
|
|
|
|
int database_length;
|
|
} SPIDER_COPY_TABLES;
|
|
|
|
class SPIDER_SORT
|
|
{
|
|
public:
|
|
ulong sort;
|
|
};
|
|
|
|
/*
|
|
A SPIDER_TRX_HA contains the HA information of a spider table or
|
|
partition.
|
|
|
|
Each SPIDER_TRX_HA is stored in a hash belonging to a SPIDER_TRX
|
|
i.e. its trx_ha_hash field.
|
|
|
|
It thus may have a different lifespan from the ha_spider or
|
|
SPIDER_SHARE associated with the same spider table/partition.
|
|
*/
|
|
typedef struct st_spider_trx_ha
|
|
{
|
|
/*
|
|
A fully qualified table name, used as the key in
|
|
SPIDER_TRX::trx_ha_hash
|
|
*/
|
|
char *table_name;
|
|
uint table_name_length;
|
|
/*
|
|
The associated SPIDER_SHARE. Will be used to check against a
|
|
given SPIDER_SHARE
|
|
*/
|
|
SPIDER_SHARE *share;
|
|
/*
|
|
link_count and link_bitmap_size are read from and checked against
|
|
the corresponding fields of the associated SPIDER_SHARE.
|
|
*/
|
|
uint link_count;
|
|
uint link_bitmap_size;
|
|
/*
|
|
conn_link_idx and conn_can_fo are read from and written to the
|
|
corresponding fields of the associated ha_spider.
|
|
*/
|
|
uint *conn_link_idx;
|
|
uchar *conn_can_fo;
|
|
/* TODO: document */
|
|
bool wait_for_reusing;
|
|
} SPIDER_TRX_HA;
|
|
|
|
|
|
#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;
|
|
bool init_mem_root;
|
|
MEM_ROOT mem_root;
|
|
st_spider_item_hld *next;
|
|
} SPIDER_ITEM_HLD;
|
|
|
|
char *spider_create_string(
|
|
const char *str,
|
|
uint length
|
|
);
|
|
|
|
|
|
typedef struct st_spider_ip_port_conn {
|
|
char *key;
|
|
size_t key_len;
|
|
my_hash_value_type key_hash_value;
|
|
char *remote_ip_str;
|
|
long remote_port;
|
|
ulong ip_port_count;
|
|
volatile ulong waiting_count;
|
|
pthread_mutex_t mutex;
|
|
pthread_cond_t cond;
|
|
ulonglong conn_id; /* each conn has it's own conn_id */
|
|
} SPIDER_IP_PORT_CONN;
|