mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
a8caad316a
Made a some new buffers thread specific and changeable. Resize of key_buffer. AUTO_COMMIT -> AUTOCOMMIT Fixed mutex bug in DROP DATABASE Fixed bug when using auto_increment as second part of a key where first part could include NULL. Split handler->extra() to extra() and extra_opt() to be able to support thread specific buffers. Don't write message to error log when slave reconnects becasue of timeout. Fixed possible update problem when using DELETE/UPDATE on small tables (In some cases we used index even if table scanning would be better) A lot of minior code cleanups BitKeeper/deleted/.del-net.c~ef21d6402bb882f9: Delete: libmysql/net.c BitKeeper/etc/ignore: added libmysql/net.c Docs/manual.texi: New SET syntax & system variables. client/client_priv.h: moved order of include files client/mysql.cc: Removed compiler warning client/mysqladmin.c: Use new SHOW GLOBAL syntax (if server supports it) configure.in: version change include/Makefile.am: indentation cleanup include/my_getopt.h: Made some helper functions global include/my_sys.h: Removed not used code include/myisam.h: Added extra argument to ..._extra() include/myisammrg.h: Added extra argument to ..._extra() include/mysql_com.h: changed NET to be able to support changeable system variables include/mysql_embed.h: Added MYSQL_SERVER_SUFFIX include/mysql_version.h.in: Added check of multiple including (needed for embedded library) include/mysqld_error.h: New error messages innobase/dict/dict0dict.c: Remove compiler warnings innobase/include/ut0mem.h: Remove compiler warnings innobase/include/ut0mem.ic: Remove compiler warnings isam/isamchk.c: new init_key_cache() arguments isam/isamlog.c: new init_key_cache() arguments isam/test2.c: new init_key_cache() arguments isam/test3.c: new init_key_cache() arguments libmysql/Makefile.am: Removed net.c (Automaticly make it from net_serv.cc) libmysql/Makefile.shared: Removed net.c (Automaticly make it from net_serv.cc) libmysql/libmysql.c: Changeable system variables libmysqld/Makefile.am: Added set_var.cc file libmysqld/embedded_priv.h: Changed order of include fiels libmysqld/lib_sql.cc: merge with mysqld.cc (for changeable variables) libmysqld/libmysqld.c: New changeable system variables myisam/mi_check.c: Added extra argument to ..._extra() myisam/mi_extra.c: Added extra argument to ..._extra() myisam/mi_open.c: Removed not used variable myisam/mi_test1.c: Changed call to init_key_cache myisam/mi_test2.c: Added extra argument to ..._extra() myisam/mi_test3.c: Added extra argument to ..._extra() myisam/mi_write.c: Add cache size argument to bulk-insert-init myisam/myisamchk.c: Use new key cache myisam/myisamdef.h: new mi_init_bulk_insert() arguments myisam/myisamlog.c: Added extra argument to ..._extra() myisam/myisampack.c: Added extra argument to ..._extra() myisammrg/myrg_extra.c: Added extra argument to ..._extra() myisammrg/myrg_rrnd.c: Added extra argument to ..._extra() mysql-test/r/insert_select.result: New changeable system variables mysql-test/r/key.result: Test of bug in auto_increment mysql-test/r/query_cache.result: New changeable system variables mysql-test/r/rpl000001.result: New changeable system variables mysql-test/r/rpl000016.result: New changeable system variables mysql-test/r/union.result: New changeable system variables mysql-test/r/user_var.result: New changeable system variables mysql-test/r/variables.result: New changeable system variables mysql-test/t/key.test: Test of bug in auto_increment mysql-test/t/query_cache.test: New changeable system variables mysql-test/t/rpl000001.test: New changeable system variables mysql-test/t/rpl000009.test: New changeable system variables mysql-test/t/rpl000016.test: New changeable system variables mysql-test/t/rpl_compat.test: New changeable system variables mysql-test/t/union.test: New changeable system variables mysql-test/t/user_var.test: New changeable system variables mysql-test/t/variables.test: New changeable system variables mysys/default.c: Bigger default memory allocation mysys/mf_iocache.c: Removed compiler warning mysys/mf_keycache.c: Made key cache resizable on the fly Removed not needed extra argument to init_key_cache() mysys/my_getopt.c: Made some helper functions global sql/Makefile.am: Aded set_var.cc sql/convert.cc: Comment cleanup sql/field.cc: new changeable system variables sql/filesort.cc: new changeable system variables sql/ha_berkeley.cc: AUTO_COMMIT -> AUTOCOMMIT sql/ha_innodb.cc: new changeable system variables sql/ha_myisam.cc: Added extra argument to ..._extra() sql/ha_myisam.h: Added extra argument to ..._extra() sql/ha_myisammrg.cc: Added extra argument to ..._extra() sql/ha_myisammrg.h: Added extra argument to ..._extra() sql/handler.cc: Added extra argument to ..._extra() Added resize of key cache Change ha_table_typelib for use with new system variables sql/handler.h: Added extra argument to ..._extra() sql/item.cc: new changeable system variables sql/item.h: Added better support of Item_uint sql/item_func.cc: Added support for SET @@[global | session] system_variable sql/item_strfunc.cc: new changeable system variables sql/key.cc: Fixed bug in auto_increment on second part keys sql/lex.h: Removed not needed keywords sql/log.cc: new changeable system variables sql/log_event.cc: new changeable system variables sql/log_event.h: Removed not needed var reference sql/mini_client.cc: new changeable system variables code cleanup sql/mini_client.h: Indentation cleanup sql/mysql_priv.h: Changed order of include files & variables to make file more readable sql/mysqld.cc: Changed order of variables to make file more readable. Support for changeable variables Rename of system variables Moved init_vars to set_var.cc Changed output of --help sql/net_pkg.cc: Added my_net_local_init() to make it possible to set different defaults for network connection depending if you are a client, embedded library or server. sql/net_serv.cc: new changeable system variables To support this, some global variables had to be move to the NET structure. sql/records.cc: new changeable system variables use extra_opt() sql/repl_failsafe.cc: new changeable system variables minior code cleanups sql/repl_failsafe.h: removed not needed external var reference sql/share/czech/errmsg.txt: new changeable system variables sql/share/danish/errmsg.txt: new changeable system variables sql/share/dutch/errmsg.txt: new changeable system variables sql/share/english/errmsg.txt: new changeable system variables sql/share/estonian/errmsg.txt: new changeable system variables sql/share/french/errmsg.txt: new changeable system variables sql/share/german/errmsg.txt: new changeable system variables sql/share/greek/errmsg.txt: new changeable system variables sql/share/hungarian/errmsg.txt: new changeable system variables sql/share/italian/errmsg.txt: new changeable system variables sql/share/japanese/errmsg.txt: new changeable system variables sql/share/korean/errmsg.txt: new changeable system variables sql/share/norwegian-ny/errmsg.txt: new changeable system variables sql/share/norwegian/errmsg.txt: new changeable system variables sql/share/polish/errmsg.txt: new changeable system variables sql/share/portuguese/errmsg.txt: new changeable system variables sql/share/romanian/errmsg.txt: new changeable system variables sql/share/russian/errmsg.txt: new changeable system variables sql/share/slovak/errmsg.txt: new changeable system variables sql/share/spanish/errmsg.txt: new changeable system variables sql/share/swedish/errmsg.txt: new changeable system variables sql/share/ukrainian/errmsg.txt: new changeable system variables sql/slave.cc: new changeable system variables Added some suppression of error messages Initialize current_thd for all slave threads. sql/sql_acl.cc: Added checking of arguments for SET PASSWORD (for new SET defintion) sql/sql_acl.h: new prototypes sql/sql_base.cc: new changeable system variables sql/sql_cache.cc: new changeable system variables sql/sql_cache.h: Renamed some arguments to make code more readable sql/sql_class.cc: new changeable system variables sql/sql_class.h: New changeable system variables Code cleanup sql/sql_db.cc: Fixed bug in DROP DATABASE sql/sql_delete.cc: Usage of wrong define in test (possible speed problem) sql/sql_insert.cc: use extra_opt() Code cleanup sql/sql_lex.cc: Added support for SET @@[global | session] system_variable sql/sql_lex.h: Added support for SET @@[global | session] system_variable sql/sql_load.cc: Cleanup for embedded library Use extra_opt() sql/sql_parse.cc: Cleanup for embedded library New changeable system variables sql/sql_repl.cc: new changeable system variables sql/sql_repl.h: Fixed variable definitions sql/sql_select.cc: new changeable system variables sql/sql_show.cc: New changeable system variables sql/sql_table.cc: Fixed bug in DROP DATABASE sql/sql_union.cc: New changeable system variables sql/sql_update.cc: Usage of wrong define in test (possible speed problem) sql/sql_yacc.yy: New changeable system variables sql/structs.h: Added typedef for SHOW_VAR sql/table.cc: Fixed bug in auto_increment on second part keys sql/uniques.cc: Comment fix sql/unireg.h: A
679 lines
18 KiB
C++
679 lines
18 KiB
C++
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
|
|
|
|
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; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
|
|
#ifndef _log_event_h
|
|
#define _log_event_h
|
|
|
|
#ifdef __EMX__
|
|
#undef write // remove pthread.h macro definition, conflict with write() class member
|
|
#endif
|
|
|
|
#if defined(__GNUC__) && !defined(MYSQL_CLIENT)
|
|
#pragma interface /* gcc class implementation */
|
|
#endif
|
|
|
|
#define LOG_READ_EOF -1
|
|
#define LOG_READ_BOGUS -2
|
|
#define LOG_READ_IO -3
|
|
#define LOG_READ_MEM -5
|
|
#define LOG_READ_TRUNC -6
|
|
#define LOG_READ_TOO_LARGE -7
|
|
|
|
#define LOG_EVENT_OFFSET 4
|
|
#define BINLOG_VERSION 3
|
|
|
|
/*
|
|
We could have used SERVER_VERSION_LENGTH, but this introduces an
|
|
obscure dependency - if somebody decided to change SERVER_VERSION_LENGTH
|
|
this would have broke the replication protocol
|
|
*/
|
|
#define ST_SERVER_VER_LEN 50
|
|
|
|
#define DUMPFILE_FLAG 0x1
|
|
#define OPT_ENCLOSED_FLAG 0x2
|
|
#define REPLACE_FLAG 0x4
|
|
#define IGNORE_FLAG 0x8
|
|
|
|
#define FIELD_TERM_EMPTY 0x1
|
|
#define ENCLOSED_EMPTY 0x2
|
|
#define LINE_TERM_EMPTY 0x4
|
|
#define LINE_START_EMPTY 0x8
|
|
#define ESCAPED_EMPTY 0x10
|
|
|
|
struct old_sql_ex
|
|
{
|
|
char field_term;
|
|
char enclosed;
|
|
char line_term;
|
|
char line_start;
|
|
char escaped;
|
|
char opt_flags;
|
|
char empty_flags;
|
|
};
|
|
|
|
#define NUM_LOAD_DELIM_STRS 5
|
|
|
|
struct sql_ex_info
|
|
{
|
|
char* field_term;
|
|
char* enclosed;
|
|
char* line_term;
|
|
char* line_start;
|
|
char* escaped;
|
|
int cached_new_format;
|
|
uint8 field_term_len,enclosed_len,line_term_len,line_start_len, escaped_len;
|
|
char opt_flags;
|
|
char empty_flags;
|
|
|
|
// store in new format even if old is possible
|
|
void force_new_format() { cached_new_format = 1;}
|
|
int data_size()
|
|
{
|
|
return (new_format() ?
|
|
field_term_len + enclosed_len + line_term_len +
|
|
line_start_len + escaped_len + 6 : 7);
|
|
}
|
|
int write_data(IO_CACHE* file);
|
|
char* init(char* buf,char* buf_end,bool use_new_format);
|
|
bool new_format()
|
|
{
|
|
return ((cached_new_format != -1) ? cached_new_format :
|
|
(cached_new_format=(field_term_len > 1 ||
|
|
enclosed_len > 1 ||
|
|
line_term_len > 1 || line_start_len > 1 ||
|
|
escaped_len > 1)));
|
|
}
|
|
};
|
|
|
|
/*
|
|
Binary log consists of events. Each event has a fixed length header,
|
|
followed by possibly variable ( depending on the type of event) length
|
|
data body. The data body consists of an optional fixed length segment
|
|
(post-header), and an optional variable length segment. See #defines and
|
|
comments below for the format specifics
|
|
*/
|
|
|
|
/* event-specific post-header sizes */
|
|
#define LOG_EVENT_HEADER_LEN 19
|
|
#define OLD_HEADER_LEN 13
|
|
#define QUERY_HEADER_LEN (4 + 4 + 1 + 2)
|
|
#define LOAD_HEADER_LEN (4 + 4 + 4 + 1 +1 + 4)
|
|
#define START_HEADER_LEN (2 + ST_SERVER_VER_LEN + 4)
|
|
#define ROTATE_HEADER_LEN 8
|
|
#define CREATE_FILE_HEADER_LEN 4
|
|
#define APPEND_BLOCK_HEADER_LEN 4
|
|
#define EXEC_LOAD_HEADER_LEN 4
|
|
#define DELETE_FILE_HEADER_LEN 4
|
|
|
|
/* event header offsets */
|
|
|
|
#define EVENT_TYPE_OFFSET 4
|
|
#define SERVER_ID_OFFSET 5
|
|
#define EVENT_LEN_OFFSET 9
|
|
#define LOG_POS_OFFSET 13
|
|
#define FLAGS_OFFSET 17
|
|
|
|
/* start event post-header */
|
|
|
|
#define ST_BINLOG_VER_OFFSET 0
|
|
#define ST_SERVER_VER_OFFSET 2
|
|
#define ST_CREATED_OFFSET (ST_SERVER_VER_OFFSET + ST_SERVER_VER_LEN)
|
|
|
|
/* slave event post-header */
|
|
|
|
#define SL_MASTER_PORT_OFFSET 8
|
|
#define SL_MASTER_POS_OFFSET 0
|
|
#define SL_MASTER_HOST_OFFSET 10
|
|
|
|
/* query event post-header */
|
|
|
|
#define Q_THREAD_ID_OFFSET 0
|
|
#define Q_EXEC_TIME_OFFSET 4
|
|
#define Q_DB_LEN_OFFSET 8
|
|
#define Q_ERR_CODE_OFFSET 9
|
|
#define Q_DATA_OFFSET QUERY_HEADER_LEN
|
|
|
|
/* Intvar event post-header */
|
|
|
|
#define I_TYPE_OFFSET 0
|
|
#define I_VAL_OFFSET 1
|
|
|
|
/* Load event post-header */
|
|
|
|
#define L_THREAD_ID_OFFSET 0
|
|
#define L_EXEC_TIME_OFFSET 4
|
|
#define L_SKIP_LINES_OFFSET 8
|
|
#define L_TBL_LEN_OFFSET 12
|
|
#define L_DB_LEN_OFFSET 13
|
|
#define L_NUM_FIELDS_OFFSET 14
|
|
#define L_SQL_EX_OFFSET 18
|
|
#define L_DATA_OFFSET LOAD_HEADER_LEN
|
|
|
|
/* Rotate event post-header */
|
|
|
|
#define R_POS_OFFSET 0
|
|
#define R_IDENT_OFFSET 8
|
|
|
|
#define CF_FILE_ID_OFFSET 0
|
|
#define CF_DATA_OFFSET CREATE_FILE_HEADER_LEN
|
|
|
|
#define AB_FILE_ID_OFFSET 0
|
|
#define AB_DATA_OFFSET APPEND_BLOCK_HEADER_LEN
|
|
|
|
#define EL_FILE_ID_OFFSET 0
|
|
|
|
#define DF_FILE_ID_OFFSET 0
|
|
|
|
#define QUERY_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+QUERY_HEADER_LEN)
|
|
#define QUERY_DATA_OFFSET (LOG_EVENT_HEADER_LEN+QUERY_HEADER_LEN)
|
|
#define ROTATE_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+ROTATE_HEADER_LEN)
|
|
#define LOAD_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+LOAD_HEADER_LEN)
|
|
#define CREATE_FILE_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+\
|
|
+LOAD_HEADER_LEN+CREATE_FILE_HEADER_LEN)
|
|
#define DELETE_FILE_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+DELETE_FILE_HEADER_LEN)
|
|
#define EXEC_LOAD_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+EXEC_LOAD_HEADER_LEN)
|
|
#define APPEND_BLOCK_EVENT_OVERHEAD (LOG_EVENT_HEADER_LEN+APPEND_BLOCK_HEADER_LEN)
|
|
|
|
|
|
#define BINLOG_MAGIC "\xfe\x62\x69\x6e"
|
|
|
|
#define LOG_EVENT_TIME_F 0x1
|
|
#define LOG_EVENT_FORCED_ROTATE_F 0x2
|
|
|
|
enum Log_event_type
|
|
{
|
|
START_EVENT = 1, QUERY_EVENT =2, STOP_EVENT=3, ROTATE_EVENT = 4,
|
|
INTVAR_EVENT=5, LOAD_EVENT=6, SLAVE_EVENT=7, CREATE_FILE_EVENT=8,
|
|
APPEND_BLOCK_EVENT=9, EXEC_LOAD_EVENT=10, DELETE_FILE_EVENT=11,
|
|
NEW_LOAD_EVENT=12
|
|
};
|
|
|
|
enum Int_event_type
|
|
{
|
|
INVALID_INT_EVENT = 0, LAST_INSERT_ID_EVENT = 1, INSERT_ID_EVENT = 2
|
|
};
|
|
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
class String;
|
|
class MYSQL_LOG;
|
|
class THD;
|
|
#endif
|
|
|
|
struct st_relay_log_info;
|
|
|
|
class Log_event
|
|
{
|
|
public:
|
|
time_t when;
|
|
ulong exec_time;
|
|
uint32 server_id;
|
|
my_off_t log_pos;
|
|
uint16 flags;
|
|
int cached_event_len;
|
|
char* temp_buf;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
THD* thd;
|
|
|
|
Log_event(THD* thd_arg, uint16 flags_arg = 0);
|
|
// if mutex is 0, the read will proceed without mutex
|
|
static Log_event* read_log_event(IO_CACHE* file,
|
|
pthread_mutex_t* log_lock,
|
|
bool old_format);
|
|
static int read_log_event(IO_CACHE* file, String* packet,
|
|
pthread_mutex_t* log_lock);
|
|
void set_log_pos(MYSQL_LOG* log);
|
|
virtual void pack_info(String* packet);
|
|
int net_send(THD* thd, const char* log_name, my_off_t pos);
|
|
static void init_show_field_list(List<Item>* field_list);
|
|
virtual int exec_event(struct st_relay_log_info* rli);
|
|
virtual const char* get_db()
|
|
{
|
|
return thd ? thd->db : 0;
|
|
}
|
|
#else
|
|
// avoid having to link mysqlbinlog against libpthread
|
|
static Log_event* read_log_event(IO_CACHE* file, bool old_format);
|
|
virtual void print(FILE* file, bool short_form = 0, char* last_db = 0) = 0;
|
|
void print_timestamp(FILE* file, time_t *ts = 0);
|
|
void print_header(FILE* file);
|
|
#endif
|
|
|
|
static void *operator new(size_t size)
|
|
{
|
|
return (void*) my_malloc((uint)size, MYF(MY_WME|MY_FAE));
|
|
}
|
|
static void operator delete(void *ptr, size_t size)
|
|
{
|
|
my_free((gptr) ptr, MYF(MY_WME|MY_ALLOW_ZERO_PTR));
|
|
}
|
|
|
|
int write(IO_CACHE* file);
|
|
int write_header(IO_CACHE* file);
|
|
virtual int write_data(IO_CACHE* file)
|
|
{ return write_data_header(file) || write_data_body(file); }
|
|
virtual int write_data_header(IO_CACHE* file __attribute__((unused)))
|
|
{ return 0; }
|
|
virtual int write_data_body(IO_CACHE* file __attribute__((unused)))
|
|
{ return 0; }
|
|
virtual Log_event_type get_type_code() = 0;
|
|
virtual bool is_valid() = 0;
|
|
virtual bool get_cache_stmt() { return 0; }
|
|
Log_event(const char* buf, bool old_format);
|
|
virtual ~Log_event() { free_temp_buf();}
|
|
void register_temp_buf(char* buf) { temp_buf = buf; }
|
|
void free_temp_buf()
|
|
{
|
|
if (temp_buf)
|
|
{
|
|
my_free(temp_buf, MYF(0));
|
|
temp_buf = 0;
|
|
}
|
|
}
|
|
virtual int get_data_size() { return 0;}
|
|
virtual int get_data_body_offset() { return 0; }
|
|
int get_event_len()
|
|
{
|
|
return (cached_event_len ? cached_event_len :
|
|
(cached_event_len = LOG_EVENT_HEADER_LEN + get_data_size()));
|
|
}
|
|
static Log_event* read_log_event(const char* buf, int event_len,
|
|
const char **error, bool old_format);
|
|
const char* get_type_str();
|
|
};
|
|
|
|
|
|
class Query_log_event: public Log_event
|
|
{
|
|
protected:
|
|
char* data_buf;
|
|
public:
|
|
const char* query;
|
|
const char* db;
|
|
/*
|
|
If we already know the length of the query string
|
|
we pass it with q_len, so we would not have to call strlen()
|
|
otherwise, set it to 0, in which case, we compute it with strlen()
|
|
*/
|
|
uint32 q_len;
|
|
uint32 db_len;
|
|
uint16 error_code;
|
|
ulong thread_id;
|
|
#ifndef MYSQL_CLIENT
|
|
bool cache_stmt;
|
|
|
|
Query_log_event(THD* thd_arg, const char* query_arg,
|
|
bool using_trans=0);
|
|
const char* get_db() { return db; }
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
bool get_cache_stmt() { return cache_stmt; }
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Query_log_event(const char* buf, int event_len, bool old_format);
|
|
~Query_log_event()
|
|
{
|
|
if (data_buf)
|
|
{
|
|
my_free((gptr) data_buf, MYF(0));
|
|
}
|
|
}
|
|
Log_event_type get_type_code() { return QUERY_EVENT; }
|
|
int write(IO_CACHE* file);
|
|
int write_data(IO_CACHE* file); // returns 0 on success, -1 on error
|
|
bool is_valid() { return query != 0; }
|
|
int get_data_size()
|
|
{
|
|
return (q_len + db_len + 2
|
|
+ 4 // thread_id
|
|
+ 4 // exec_time
|
|
+ 2 // error_code
|
|
);
|
|
}
|
|
};
|
|
|
|
|
|
class Slave_log_event: public Log_event
|
|
{
|
|
protected:
|
|
char* mem_pool;
|
|
void init_from_mem_pool(int data_size);
|
|
public:
|
|
my_off_t master_pos;
|
|
char* master_host;
|
|
char* master_log;
|
|
int master_host_len;
|
|
int master_log_len;
|
|
uint16 master_port;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Slave_log_event(THD* thd_arg, struct st_relay_log_info* rli);
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Slave_log_event(const char* buf, int event_len);
|
|
~Slave_log_event();
|
|
int get_data_size();
|
|
bool is_valid() { return master_host != 0; }
|
|
Log_event_type get_type_code() { return SLAVE_EVENT; }
|
|
int write_data(IO_CACHE* file );
|
|
};
|
|
|
|
class Load_log_event: public Log_event
|
|
{
|
|
protected:
|
|
int copy_log_event(const char *buf, ulong event_len, bool old_format);
|
|
|
|
public:
|
|
ulong thread_id;
|
|
uint32 table_name_len;
|
|
uint32 db_len;
|
|
uint32 fname_len;
|
|
uint32 num_fields;
|
|
const char* fields;
|
|
const uchar* field_lens;
|
|
uint32 field_block_len;
|
|
|
|
const char* table_name;
|
|
const char* db;
|
|
const char* fname;
|
|
uint32 skip_lines;
|
|
sql_ex_info sql_ex;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
String field_lens_buf;
|
|
String fields_buf;
|
|
|
|
Load_log_event(THD* thd, sql_exchange* ex, const char* db_arg,
|
|
const char* table_name_arg,
|
|
List<Item>& fields_arg, enum enum_duplicates handle_dup);
|
|
void set_fields(List<Item> &fields_arg);
|
|
void pack_info(String* packet);
|
|
const char* get_db() { return db; }
|
|
int exec_event(struct st_relay_log_info* rli)
|
|
{
|
|
return exec_event(thd->slave_net,rli);
|
|
}
|
|
int exec_event(NET* net, struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Load_log_event(const char* buf, int event_len, bool old_format);
|
|
~Load_log_event()
|
|
{}
|
|
Log_event_type get_type_code() { return sql_ex.new_format() ?
|
|
NEW_LOAD_EVENT: LOAD_EVENT; }
|
|
int write_data_header(IO_CACHE* file);
|
|
int write_data_body(IO_CACHE* file);
|
|
bool is_valid() { return table_name != 0; }
|
|
int get_data_size()
|
|
{
|
|
return (table_name_len + 2 + db_len + 2 + fname_len
|
|
+ 4 // thread_id
|
|
+ 4 // exec_time
|
|
+ 4 // skip_lines
|
|
+ 4 // field block len
|
|
+ sql_ex.data_size() + field_block_len + num_fields);
|
|
}
|
|
int get_data_body_offset() { return LOAD_EVENT_OVERHEAD; }
|
|
};
|
|
|
|
extern char server_version[SERVER_VERSION_LENGTH];
|
|
|
|
class Start_log_event: public Log_event
|
|
{
|
|
public:
|
|
uint32 created;
|
|
uint16 binlog_version;
|
|
char server_version[ST_SERVER_VER_LEN];
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Start_log_event() :Log_event((THD*)0),binlog_version(BINLOG_VERSION)
|
|
{
|
|
created = (uint32) when;
|
|
memcpy(server_version, ::server_version, ST_SERVER_VER_LEN);
|
|
}
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Start_log_event(const char* buf, bool old_format);
|
|
~Start_log_event() {}
|
|
Log_event_type get_type_code() { return START_EVENT;}
|
|
int write_data(IO_CACHE* file);
|
|
bool is_valid() { return 1; }
|
|
int get_data_size()
|
|
{
|
|
return START_HEADER_LEN;
|
|
}
|
|
};
|
|
|
|
|
|
class Intvar_log_event: public Log_event
|
|
{
|
|
public:
|
|
ulonglong val;
|
|
uchar type;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Intvar_log_event(THD* thd_arg,uchar type_arg, ulonglong val_arg)
|
|
:Log_event(thd_arg),val(val_arg),type(type_arg)
|
|
{}
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Intvar_log_event(const char* buf, bool old_format);
|
|
~Intvar_log_event() {}
|
|
Log_event_type get_type_code() { return INTVAR_EVENT;}
|
|
const char* get_var_type_name();
|
|
int get_data_size() { return sizeof(type) + sizeof(val);}
|
|
int write_data(IO_CACHE* file);
|
|
bool is_valid() { return 1; }
|
|
};
|
|
|
|
|
|
class Stop_log_event: public Log_event
|
|
{
|
|
public:
|
|
#ifndef MYSQL_CLIENT
|
|
Stop_log_event() :Log_event((THD*)0)
|
|
{}
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Stop_log_event(const char* buf, bool old_format):
|
|
Log_event(buf, old_format)
|
|
{}
|
|
~Stop_log_event() {}
|
|
Log_event_type get_type_code() { return STOP_EVENT;}
|
|
bool is_valid() { return 1; }
|
|
};
|
|
|
|
|
|
class Rotate_log_event: public Log_event
|
|
{
|
|
public:
|
|
const char* new_log_ident;
|
|
uchar ident_len;
|
|
ulonglong pos;
|
|
bool alloced;
|
|
#ifndef MYSQL_CLIENT
|
|
Rotate_log_event(THD* thd_arg, const char* new_log_ident_arg,
|
|
uint ident_len_arg = 0,ulonglong pos_arg = 4)
|
|
: Log_event(thd_arg), new_log_ident(new_log_ident_arg),
|
|
ident_len(ident_len_arg ? ident_len_arg :
|
|
(uint) strlen(new_log_ident_arg)), pos(pos_arg),
|
|
alloced(0)
|
|
{}
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Rotate_log_event(const char* buf, int event_len, bool old_format);
|
|
~Rotate_log_event()
|
|
{
|
|
if (alloced)
|
|
my_free((gptr) new_log_ident, MYF(0));
|
|
}
|
|
Log_event_type get_type_code() { return ROTATE_EVENT;}
|
|
int get_data_size() { return ident_len + ROTATE_HEADER_LEN;}
|
|
bool is_valid() { return new_log_ident != 0; }
|
|
int write_data(IO_CACHE* file);
|
|
};
|
|
|
|
/* the classes below are for the new LOAD DATA INFILE logging */
|
|
|
|
class Create_file_log_event: public Load_log_event
|
|
{
|
|
protected:
|
|
/*
|
|
Pretend we are Load event, so we can write out just
|
|
our Load part - used on the slave when writing event out to
|
|
SQL_LOAD-*.info file
|
|
*/
|
|
bool fake_base;
|
|
public:
|
|
char* block;
|
|
uint block_len;
|
|
uint file_id;
|
|
bool inited_from_old;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Create_file_log_event(THD* thd, sql_exchange* ex, const char* db_arg,
|
|
const char* table_name_arg,
|
|
List<Item>& fields_arg,
|
|
enum enum_duplicates handle_dup,
|
|
char* block_arg, uint block_len_arg);
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Create_file_log_event(const char* buf, int event_len, bool old_format);
|
|
~Create_file_log_event() {}
|
|
|
|
Log_event_type get_type_code()
|
|
{
|
|
return fake_base ? Load_log_event::get_type_code() : CREATE_FILE_EVENT;
|
|
}
|
|
int get_data_size()
|
|
{
|
|
return (fake_base ? Load_log_event::get_data_size() :
|
|
Load_log_event::get_data_size() +
|
|
4 + 1 + block_len);
|
|
}
|
|
int get_data_body_offset()
|
|
{
|
|
return (fake_base ? LOAD_EVENT_OVERHEAD:
|
|
LOAD_EVENT_OVERHEAD + CREATE_FILE_HEADER_LEN);
|
|
}
|
|
bool is_valid() { return inited_from_old || block != 0; }
|
|
int write_data_header(IO_CACHE* file);
|
|
int write_data_body(IO_CACHE* file);
|
|
/*
|
|
Cut out Create_file extentions and
|
|
write it as Load event - used on the slave
|
|
*/
|
|
int write_base(IO_CACHE* file);
|
|
};
|
|
|
|
|
|
class Append_block_log_event: public Log_event
|
|
{
|
|
public:
|
|
char* block;
|
|
uint block_len;
|
|
uint file_id;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Append_block_log_event(THD* thd, char* block_arg,
|
|
uint block_len_arg);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
void pack_info(String* packet);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Append_block_log_event(const char* buf, int event_len);
|
|
~Append_block_log_event() {}
|
|
Log_event_type get_type_code() { return APPEND_BLOCK_EVENT;}
|
|
int get_data_size() { return block_len + APPEND_BLOCK_HEADER_LEN ;}
|
|
bool is_valid() { return block != 0; }
|
|
int write_data(IO_CACHE* file);
|
|
};
|
|
|
|
|
|
class Delete_file_log_event: public Log_event
|
|
{
|
|
public:
|
|
uint file_id;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Delete_file_log_event(THD* thd);
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Delete_file_log_event(const char* buf, int event_len);
|
|
~Delete_file_log_event() {}
|
|
Log_event_type get_type_code() { return DELETE_FILE_EVENT;}
|
|
int get_data_size() { return DELETE_FILE_HEADER_LEN ;}
|
|
bool is_valid() { return file_id != 0; }
|
|
int write_data(IO_CACHE* file);
|
|
};
|
|
|
|
class Execute_load_log_event: public Log_event
|
|
{
|
|
public:
|
|
uint file_id;
|
|
|
|
#ifndef MYSQL_CLIENT
|
|
Execute_load_log_event(THD* thd);
|
|
void pack_info(String* packet);
|
|
int exec_event(struct st_relay_log_info* rli);
|
|
#else
|
|
void print(FILE* file, bool short_form = 0, char* last_db = 0);
|
|
#endif
|
|
|
|
Execute_load_log_event(const char* buf, int event_len);
|
|
~Execute_load_log_event() {}
|
|
Log_event_type get_type_code() { return EXEC_LOAD_EVENT;}
|
|
int get_data_size() { return EXEC_LOAD_HEADER_LEN ;}
|
|
bool is_valid() { return file_id != 0; }
|
|
int write_data(IO_CACHE* file);
|
|
};
|
|
|
|
#endif /* _log_event_h */
|