mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 09:14:17 +01:00
550 lines
11 KiB
C++
550 lines
11 KiB
C++
/* Copyright (C) 2008-2019 Kentoku Shiba
|
|
Copyright (C) 2019 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_SYS_XA_TABLE_NAME_STR "spider_xa"
|
|
#define SPIDER_SYS_XA_TABLE_NAME_LEN 9
|
|
#define SPIDER_SYS_XA_MEMBER_TABLE_NAME_STR "spider_xa_member"
|
|
#define SPIDER_SYS_XA_MEMBER_TABLE_NAME_LEN 16
|
|
#define SPIDER_SYS_TABLES_TABLE_NAME_STR "spider_tables"
|
|
#define SPIDER_SYS_TABLES_TABLE_NAME_LEN 13
|
|
#define SPIDER_SYS_LINK_MON_TABLE_NAME_STR "spider_link_mon_servers"
|
|
#define SPIDER_SYS_LINK_MON_TABLE_NAME_LEN 23
|
|
#define SPIDER_SYS_LINK_FAILED_TABLE_NAME_STR "spider_link_failed_log"
|
|
#define SPIDER_SYS_LINK_FAILED_TABLE_NAME_LEN 22
|
|
#define SPIDER_SYS_XA_FAILED_TABLE_NAME_STR "spider_xa_failed_log"
|
|
#define SPIDER_SYS_XA_FAILED_TABLE_NAME_LEN 20
|
|
#define SPIDER_SYS_POS_FOR_RECOVERY_TABLE_NAME_STR "spider_table_position_for_recovery"
|
|
#define SPIDER_SYS_POS_FOR_RECOVERY_TABLE_NAME_LEN 34
|
|
|
|
#define SPIDER_SYS_XA_PREPARED_STR "PREPARED"
|
|
#define SPIDER_SYS_XA_NOT_YET_STR "NOT YET"
|
|
#define SPIDER_SYS_XA_COMMIT_STR "COMMIT"
|
|
#define SPIDER_SYS_XA_ROLLBACK_STR "ROLLBACK"
|
|
|
|
#define SPIDER_SYS_XA_COL_CNT 5
|
|
#define SPIDER_SYS_XA_PK_COL_CNT 3
|
|
#define SPIDER_SYS_XA_IDX1_COL_CNT 1
|
|
#define SPIDER_SYS_XA_MEMBER_COL_CNT 19
|
|
#define SPIDER_SYS_XA_MEMBER_PK_COL_CNT 6
|
|
#define SPIDER_SYS_TABLES_COL_CNT 26
|
|
#define SPIDER_SYS_TABLES_PK_COL_CNT 3
|
|
#define SPIDER_SYS_TABLES_IDX1_COL_CNT 1
|
|
#define SPIDER_SYS_TABLES_UIDX1_COL_CNT 3
|
|
#define SPIDER_SYS_LINK_MON_TABLE_COL_CNT 20
|
|
#define SPIDER_SYS_LINK_FAILED_TABLE_COL_CNT 4
|
|
#define SPIDER_SYS_XA_FAILED_TABLE_COL_CNT 22
|
|
#define SPIDER_SYS_POS_FOR_RECOVERY_TABLE_COL_CNT 7
|
|
#define SPIDER_SYS_TABLE_STS_COL_CNT 11
|
|
#define SPIDER_SYS_TABLE_STS_PK_COL_CNT 2
|
|
#define SPIDER_SYS_TABLE_CRD_COL_CNT 4
|
|
#define SPIDER_SYS_TABLE_CRD_PK_COL_CNT 3
|
|
|
|
#define SPIDER_SYS_LINK_MON_TABLE_DB_NAME_SIZE 64
|
|
#define SPIDER_SYS_LINK_MON_TABLE_TABLE_NAME_SIZE 64
|
|
#define SPIDER_SYS_LINK_MON_TABLE_LINK_ID_SIZE 64
|
|
|
|
/* For insertion into `spider_mon_table_cache'. */
|
|
class SPIDER_MON_KEY: public SPIDER_SORT
|
|
{
|
|
public:
|
|
char db_name[SPIDER_SYS_LINK_MON_TABLE_DB_NAME_SIZE + 1];
|
|
char table_name[SPIDER_SYS_LINK_MON_TABLE_TABLE_NAME_SIZE + 1];
|
|
char link_id[SPIDER_SYS_LINK_MON_TABLE_LINK_ID_SIZE + 1];
|
|
uint db_name_length;
|
|
uint table_name_length;
|
|
uint link_id_length;
|
|
};
|
|
|
|
TABLE *spider_open_sys_table(
|
|
THD *thd,
|
|
const char *table_name,
|
|
int table_name_length,
|
|
bool write,
|
|
SPIDER_Open_tables_backup *open_tables_backup,
|
|
bool need_lock,
|
|
int *error_num
|
|
);
|
|
|
|
void spider_close_sys_table(
|
|
THD *thd,
|
|
TABLE *table,
|
|
SPIDER_Open_tables_backup *open_tables_backup,
|
|
bool need_lock
|
|
);
|
|
|
|
bool spider_sys_open_and_lock_tables(
|
|
THD *thd,
|
|
TABLE_LIST **tables,
|
|
SPIDER_Open_tables_backup *open_tables_backup
|
|
);
|
|
|
|
TABLE *spider_sys_open_table(
|
|
THD *thd,
|
|
TABLE_LIST *tables,
|
|
SPIDER_Open_tables_backup *open_tables_backup
|
|
);
|
|
|
|
void spider_sys_close_table(
|
|
THD *thd,
|
|
SPIDER_Open_tables_backup *open_tables_backup
|
|
);
|
|
|
|
int spider_sys_index_init(
|
|
TABLE *table,
|
|
uint idx,
|
|
bool sorted
|
|
);
|
|
|
|
int spider_sys_index_end(
|
|
TABLE *table
|
|
);
|
|
|
|
int spider_sys_rnd_init(
|
|
TABLE *table,
|
|
bool scan
|
|
);
|
|
|
|
int spider_sys_rnd_end(
|
|
TABLE *table
|
|
);
|
|
|
|
int spider_check_sys_table(
|
|
TABLE *table,
|
|
char *table_key
|
|
);
|
|
|
|
int spider_check_sys_table_with_find_flag(
|
|
TABLE *table,
|
|
char *table_key,
|
|
enum ha_rkey_function find_flag
|
|
);
|
|
|
|
int spider_check_sys_table_for_update_all_columns(
|
|
TABLE *table,
|
|
char *table_key
|
|
);
|
|
|
|
int spider_get_sys_table_by_idx(
|
|
TABLE *table,
|
|
char *table_key,
|
|
const int idx,
|
|
const int col_count
|
|
);
|
|
|
|
int spider_sys_index_next_same(
|
|
TABLE *table,
|
|
char *table_key
|
|
);
|
|
|
|
int spider_sys_index_first(
|
|
TABLE *table,
|
|
const int idx
|
|
);
|
|
|
|
int spider_sys_index_last(
|
|
TABLE *table,
|
|
const int idx
|
|
);
|
|
|
|
int spider_sys_index_next(
|
|
TABLE *table
|
|
);
|
|
|
|
void spider_store_xa_pk(
|
|
TABLE *table,
|
|
XID *xid
|
|
);
|
|
|
|
void spider_store_xa_bqual_length(
|
|
TABLE *table,
|
|
XID *xid
|
|
);
|
|
|
|
void spider_store_xa_status(
|
|
TABLE *table,
|
|
const char *status
|
|
);
|
|
|
|
void spider_store_xa_member_pk(
|
|
TABLE *table,
|
|
XID *xid,
|
|
SPIDER_CONN *conn
|
|
);
|
|
|
|
void spider_store_xa_member_info(
|
|
TABLE *table,
|
|
XID *xid,
|
|
SPIDER_CONN *conn
|
|
);
|
|
|
|
void spider_store_tables_name(
|
|
TABLE *table,
|
|
const char *name,
|
|
const uint name_length
|
|
);
|
|
|
|
void spider_store_db_and_table_name(
|
|
TABLE *table,
|
|
const char *db_name,
|
|
const uint db_name_length,
|
|
const char *table_name,
|
|
const uint table_name_length
|
|
);
|
|
|
|
void spider_store_tables_link_idx(
|
|
TABLE *table,
|
|
int link_idx
|
|
);
|
|
|
|
void spider_store_tables_link_idx_str(
|
|
TABLE *table,
|
|
const char *link_idx,
|
|
const uint link_idx_length
|
|
);
|
|
|
|
void spider_store_tables_static_link_id(
|
|
TABLE *table,
|
|
const char *static_link_id,
|
|
const uint static_link_id_length
|
|
);
|
|
|
|
void spider_store_tables_priority(
|
|
TABLE *table,
|
|
longlong priority
|
|
);
|
|
|
|
void spider_store_tables_connect_info(
|
|
TABLE *table,
|
|
SPIDER_ALTER_TABLE *alter_table,
|
|
int link_idx
|
|
);
|
|
|
|
void spider_store_tables_link_status(
|
|
TABLE *table,
|
|
long link_status
|
|
);
|
|
|
|
void spider_store_binlog_pos_failed_link_idx(
|
|
TABLE *table,
|
|
int failed_link_idx
|
|
);
|
|
|
|
void spider_store_binlog_pos_source_link_idx(
|
|
TABLE *table,
|
|
int source_link_idx
|
|
);
|
|
|
|
void spider_store_binlog_pos_binlog_file(
|
|
TABLE *table,
|
|
const char *file_name,
|
|
int file_name_length,
|
|
const char *position,
|
|
int position_length,
|
|
CHARSET_INFO *binlog_pos_cs
|
|
);
|
|
|
|
void spider_store_binlog_pos_gtid(
|
|
TABLE *table,
|
|
const char *gtid,
|
|
int gtid_length,
|
|
CHARSET_INFO *binlog_pos_cs
|
|
);
|
|
|
|
void spider_store_table_sts_info(
|
|
TABLE *table,
|
|
ha_statistics *stat
|
|
);
|
|
|
|
void spider_store_table_crd_info(
|
|
TABLE *table,
|
|
uint *seq,
|
|
longlong *cardinality
|
|
);
|
|
|
|
int spider_insert_xa(
|
|
TABLE *table,
|
|
XID *xid,
|
|
const char *status
|
|
);
|
|
|
|
int spider_insert_xa_member(
|
|
TABLE *table,
|
|
XID *xid,
|
|
SPIDER_CONN *conn
|
|
);
|
|
|
|
int spider_insert_tables(
|
|
TABLE *table,
|
|
SPIDER_SHARE *share
|
|
);
|
|
|
|
int spider_insert_sys_table(
|
|
TABLE *table
|
|
);
|
|
|
|
int spider_log_tables_link_failed(
|
|
TABLE *table,
|
|
char *name,
|
|
uint name_length,
|
|
int link_idx
|
|
);
|
|
|
|
int spider_log_xa_failed(
|
|
THD *thd,
|
|
TABLE *table,
|
|
XID *xid,
|
|
SPIDER_CONN *conn,
|
|
const char *status
|
|
);
|
|
|
|
int spider_update_xa(
|
|
TABLE *table,
|
|
XID *xid,
|
|
const char *status
|
|
);
|
|
|
|
int spider_update_tables_name(
|
|
TABLE *table,
|
|
const char *from,
|
|
const char *to,
|
|
int *old_link_count
|
|
);
|
|
|
|
int spider_update_tables_priority(
|
|
TABLE *table,
|
|
SPIDER_ALTER_TABLE *alter_table,
|
|
const char *name,
|
|
int *old_link_count
|
|
);
|
|
|
|
int spider_update_tables_link_status(
|
|
TABLE *table,
|
|
char *name,
|
|
uint name_length,
|
|
int link_idx,
|
|
long link_status
|
|
);
|
|
|
|
int spider_update_sys_table(
|
|
TABLE *table
|
|
);
|
|
|
|
int spider_delete_xa(
|
|
TABLE *table,
|
|
XID *xid
|
|
);
|
|
|
|
int spider_delete_xa_member(
|
|
TABLE *table,
|
|
XID *xid
|
|
);
|
|
|
|
int spider_delete_tables(
|
|
TABLE *table,
|
|
const char *name,
|
|
int *old_link_count
|
|
);
|
|
|
|
int spider_delete_table_sts(
|
|
TABLE *table,
|
|
const char *name,
|
|
uint name_length
|
|
);
|
|
|
|
int spider_delete_table_crd(
|
|
TABLE *table,
|
|
const char *name,
|
|
uint name_length
|
|
);
|
|
|
|
int spider_get_sys_xid(
|
|
TABLE *table,
|
|
XID *xid,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_server_info(
|
|
TABLE *table,
|
|
SPIDER_SHARE *share,
|
|
int link_idx,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_check_sys_xa_status(
|
|
TABLE *table,
|
|
const char *status1,
|
|
const char *status2,
|
|
const char *status3,
|
|
const int check_error_num,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables(
|
|
TABLE *table,
|
|
char **db_name,
|
|
char **table_name,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables_connect_info(
|
|
TABLE *table,
|
|
SPIDER_SHARE *share,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables_monitoring_binlog_pos_at_failing(
|
|
TABLE *table,
|
|
long *monitoring_binlog_pos_at_failing,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables_link_status(
|
|
TABLE *table,
|
|
SPIDER_SHARE *share,
|
|
int link_idx,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables_link_status(
|
|
TABLE *table,
|
|
long *link_status,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables_link_idx(
|
|
TABLE *table,
|
|
int *link_idx,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_tables_static_link_id(
|
|
TABLE *table,
|
|
char **static_link_id,
|
|
uint *static_link_id_length,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_sys_update_tables_link_status(
|
|
THD *thd,
|
|
char *name,
|
|
uint name_length,
|
|
int link_idx,
|
|
long link_status,
|
|
bool need_lock
|
|
);
|
|
|
|
int spider_sys_log_tables_link_failed(
|
|
THD *thd,
|
|
char *name,
|
|
uint name_length,
|
|
int link_idx,
|
|
bool need_lock
|
|
);
|
|
|
|
int spider_sys_log_xa_failed(
|
|
THD *thd,
|
|
XID *xid,
|
|
SPIDER_CONN *conn,
|
|
const char *status,
|
|
bool need_lock
|
|
);
|
|
|
|
int spider_get_sys_link_mon_key(
|
|
TABLE *table,
|
|
SPIDER_MON_KEY *mon_key,
|
|
MEM_ROOT *mem_root,
|
|
int *same
|
|
);
|
|
|
|
int spider_get_sys_link_mon_server_id(
|
|
TABLE *table,
|
|
uint32 *server_id,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_sys_link_mon_connect_info(
|
|
TABLE *table,
|
|
SPIDER_SHARE *share,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_get_link_statuses(
|
|
TABLE *table,
|
|
SPIDER_SHARE *share,
|
|
MEM_ROOT *mem_root
|
|
);
|
|
|
|
int spider_sys_replace(
|
|
TABLE *table,
|
|
bool *modified_non_trans_table
|
|
);
|
|
|
|
#ifdef SPIDER_use_LEX_CSTRING_for_Field_blob_constructor
|
|
TABLE *spider_mk_sys_tmp_table(
|
|
THD *thd,
|
|
TABLE *table,
|
|
TMP_TABLE_PARAM *tmp_tbl_prm,
|
|
const LEX_CSTRING *field_name,
|
|
CHARSET_INFO *cs
|
|
);
|
|
#else
|
|
TABLE *spider_mk_sys_tmp_table(
|
|
THD *thd,
|
|
TABLE *table,
|
|
TMP_TABLE_PARAM *tmp_tbl_prm,
|
|
const char *field_name,
|
|
CHARSET_INFO *cs
|
|
);
|
|
#endif
|
|
|
|
void spider_rm_sys_tmp_table(
|
|
THD *thd,
|
|
TABLE *tmp_table,
|
|
TMP_TABLE_PARAM *tmp_tbl_prm
|
|
);
|
|
|
|
#ifdef SPIDER_use_LEX_CSTRING_for_Field_blob_constructor
|
|
TABLE *spider_mk_sys_tmp_table_for_result(
|
|
THD *thd,
|
|
TABLE *table,
|
|
TMP_TABLE_PARAM *tmp_tbl_prm,
|
|
const LEX_CSTRING *field_name1,
|
|
const LEX_CSTRING *field_name2,
|
|
const LEX_CSTRING *field_name3,
|
|
CHARSET_INFO *cs
|
|
);
|
|
#else
|
|
TABLE *spider_mk_sys_tmp_table_for_result(
|
|
THD *thd,
|
|
TABLE *table,
|
|
TMP_TABLE_PARAM *tmp_tbl_prm,
|
|
const char *field_name1,
|
|
const char *field_name2,
|
|
const char *field_name3,
|
|
CHARSET_INFO *cs
|
|
);
|
|
#endif
|
|
|
|
void spider_rm_sys_tmp_table_for_result(
|
|
THD *thd,
|
|
TABLE *tmp_table,
|
|
TMP_TABLE_PARAM *tmp_tbl_prm
|
|
);
|
|
|
|
TABLE *spider_find_temporary_table(
|
|
THD *thd,
|
|
TABLE_LIST *table_list
|
|
);
|