sql_repl.h
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:3k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB & Sasha
  2.    This program is free software; you can redistribute it and/or modify
  3.    it under the terms of the GNU General Public License as published by
  4.    the Free Software Foundation; either version 2 of the License, or
  5.    (at your option) any later version.
  6.    This program is distributed in the hope that it will be useful,
  7.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  8.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9.    GNU General Public License for more details.
  10.    You should have received a copy of the GNU General Public License
  11.    along with this program; if not, write to the Free Software
  12.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  13. #ifdef HAVE_REPLICATION
  14. #include "slave.h"
  15. typedef struct st_slave_info
  16. {
  17.   uint32 server_id;
  18.   uint32 rpl_recovery_rank, master_id;
  19.   char host[HOSTNAME_LENGTH+1];
  20.   char user[USERNAME_LENGTH+1];
  21.   char password[MAX_PASSWORD_LENGTH+1];
  22.   uint16 port;
  23.   THD* thd;
  24. } SLAVE_INFO;
  25. extern my_bool opt_show_slave_auth_info;
  26. extern char *master_host, *master_info_file;
  27. extern bool server_id_supplied;
  28. extern I_List<i_string> binlog_do_db, binlog_ignore_db;
  29. extern int max_binlog_dump_events;
  30. extern my_bool opt_sporadic_binlog_dump_fail;
  31. #define KICK_SLAVE(thd) { pthread_mutex_lock(&(thd)->LOCK_delete); (thd)->awake(0 /* do not prepare to die*/); pthread_mutex_unlock(&(thd)->LOCK_delete); }
  32. File open_binlog(IO_CACHE *log, const char *log_file_name,
  33.  const char **errmsg);
  34. int start_slave(THD* thd, MASTER_INFO* mi, bool net_report);
  35. int stop_slave(THD* thd, MASTER_INFO* mi, bool net_report);
  36. int change_master(THD* thd, MASTER_INFO* mi);
  37. int show_binlog_events(THD* thd);
  38. int cmp_master_pos(const char* log_file_name1, ulonglong log_pos1,
  39.    const char* log_file_name2, ulonglong log_pos2);
  40. int reset_slave(THD *thd, MASTER_INFO* mi);
  41. int reset_master(THD* thd);
  42. int purge_master_logs(THD* thd, const char* to_log);
  43. int purge_master_logs_before_date(THD* thd, time_t purge_time);
  44. bool log_in_use(const char* log_name);
  45. void adjust_linfo_offsets(my_off_t purge_offset);
  46. int show_binlogs(THD* thd);
  47. extern int init_master_info(MASTER_INFO* mi);
  48. void kill_zombie_dump_threads(uint32 slave_server_id);
  49. int check_binlog_magic(IO_CACHE* log, const char** errmsg);
  50. typedef struct st_load_file_info
  51. {
  52.   THD* thd;
  53.   my_off_t last_pos_in_file;
  54.   sql_exchange* ex;
  55.   List <Item> *fields;
  56.   enum enum_duplicates handle_dup;
  57.   char* db;
  58.   char* table_name;
  59.   bool wrote_create_file, log_delayed, ignore;
  60. } LOAD_FILE_INFO;
  61. int log_loaded_block(IO_CACHE* file);
  62. #endif /* HAVE_REPLICATION */