Commit 5c5ea59b authored by Vlad Lesin's avatar Vlad Lesin

MDEV-19867: fix mysqldump to by default not copy S3 tables

There are two options when coping S3 tables with mysqldump
(there is startup option --copy_s3_tables, boolean, default no)
1) Ignore all tables with engine S3, as the data is already safe in S3 and any
computer where you restore the backup will automatically discover the S3 table.
2) Copy the table as a normal table with the following 2 changes:
- Change ENGINE=S3 to ENGINE=ARIA;
- After copy add to log 'ALTER TABLE table_name ENGINE=S3'
parent 878ad986
...@@ -101,6 +101,7 @@ enum options_client ...@@ -101,6 +101,7 @@ enum options_client
OPT_SSL_CRL, OPT_SSL_CRLPATH, OPT_SSL_CRL, OPT_SSL_CRLPATH,
OPT_PRINT_ROW_COUNT, OPT_PRINT_ROW_EVENT_POSITIONS, OPT_PRINT_ROW_COUNT, OPT_PRINT_ROW_EVENT_POSITIONS,
OPT_SHUTDOWN_WAIT_FOR_SLAVES, OPT_SHUTDOWN_WAIT_FOR_SLAVES,
OPT_COPY_S3_TABLES,
OPT_MAX_CLIENT_OPTION /* should be always the last */ OPT_MAX_CLIENT_OPTION /* should be always the last */
}; };
......
...@@ -83,6 +83,7 @@ ...@@ -83,6 +83,7 @@
#define IGNORE_NONE 0x00 /* no ignore */ #define IGNORE_NONE 0x00 /* no ignore */
#define IGNORE_DATA 0x01 /* don't dump data for this table */ #define IGNORE_DATA 0x01 /* don't dump data for this table */
#define IGNORE_INSERT_DELAYED 0x02 /* table doesn't support INSERT DELAYED */ #define IGNORE_INSERT_DELAYED 0x02 /* table doesn't support INSERT DELAYED */
#define IGNORE_S3_TABLE 0x04
/* Chars needed to store LONGLONG, excluding trailing '\0'. */ /* Chars needed to store LONGLONG, excluding trailing '\0'. */
#define LONGLONG_LEN 20 #define LONGLONG_LEN 20
...@@ -100,6 +101,7 @@ static my_bool verbose= 0, opt_no_create_info= 0, opt_no_data= 0, opt_no_data_m ...@@ -100,6 +101,7 @@ static my_bool verbose= 0, opt_no_create_info= 0, opt_no_data= 0, opt_no_data_m
quick= 1, extended_insert= 1, quick= 1, extended_insert= 1,
lock_tables=1,ignore_errors=0,flush_logs=0,flush_privileges=0, lock_tables=1,ignore_errors=0,flush_logs=0,flush_privileges=0,
opt_drop=1,opt_keywords=0,opt_lock=1,opt_compress=0, opt_drop=1,opt_keywords=0,opt_lock=1,opt_compress=0,
opt_copy_s3_tables=0,
opt_delayed=0,create_options=1,opt_quoted=0,opt_databases=0, opt_delayed=0,create_options=1,opt_quoted=0,opt_databases=0,
opt_alldbs=0,opt_create_db=0,opt_lock_all_tables=0, opt_alldbs=0,opt_create_db=0,opt_lock_all_tables=0,
opt_set_charset=0, opt_dump_date=1, opt_set_charset=0, opt_dump_date=1,
...@@ -273,6 +275,11 @@ static struct my_option my_long_options[] = ...@@ -273,6 +275,11 @@ static struct my_option my_long_options[] =
{"compress", 'C', "Use compression in server/client protocol.", {"compress", 'C', "Use compression in server/client protocol.",
&opt_compress, &opt_compress, 0, GET_BOOL, NO_ARG, 0, 0, 0, &opt_compress, &opt_compress, 0, GET_BOOL, NO_ARG, 0, 0, 0,
0, 0, 0}, 0, 0, 0},
{"copy_s3_tables", OPT_COPY_S3_TABLES,
"If 'no' S3 tables will be ignored, otherwise S3 tables will be copied as "
" Aria tables and then altered to S3",
&opt_copy_s3_tables, &opt_copy_s3_tables, 0, GET_BOOL, NO_ARG, 0, 0, 0,
0, 0, 0},
{"create-options", 'a', {"create-options", 'a',
"Include all MariaDB specific create options.", "Include all MariaDB specific create options.",
&create_options, &create_options, 0, GET_BOOL, NO_ARG, 1, &create_options, &create_options, 0, GET_BOOL, NO_ARG, 1,
...@@ -2143,7 +2150,12 @@ static void print_xml_row(FILE *xml_file, const char *row_name, ...@@ -2143,7 +2150,12 @@ static void print_xml_row(FILE *xml_file, const char *row_name,
fputc(' ', xml_file); fputc(' ', xml_file);
print_quoted_xml(xml_file, field->name, field->name_length, 1); print_quoted_xml(xml_file, field->name, field->name_length, 1);
fputs("=\"", xml_file); fputs("=\"", xml_file);
print_quoted_xml(xml_file, (*row)[i], lengths[i], 0); if (opt_copy_s3_tables &&
!strcmp(field->name, "Engine") &&
!strcmp((*row)[i], "S3"))
print_quoted_xml(xml_file, "Aria", sizeof("Aria") - 1, 0);
else
print_quoted_xml(xml_file, (*row)[i], lengths[i], 0);
fputc('"', xml_file); fputc('"', xml_file);
check_io(xml_file); check_io(xml_file);
} }
...@@ -2737,11 +2749,18 @@ static uint get_table_structure(char *table, char *db, char *table_type, ...@@ -2737,11 +2749,18 @@ static uint get_table_structure(char *table, char *db, char *table_type,
my_bool is_log_table; my_bool is_log_table;
MYSQL_RES *result; MYSQL_RES *result;
MYSQL_ROW row; MYSQL_ROW row;
const char *s3_engine_ptr;
DYNAMIC_STRING create_table_str;
static const char s3_engine_token[]= " ENGINE=S3 ";
static const char aria_engine_token[]= " ENGINE=Aria ";
DBUG_ENTER("get_table_structure"); DBUG_ENTER("get_table_structure");
DBUG_PRINT("enter", ("db: %s table: %s", db, table)); DBUG_PRINT("enter", ("db: %s table: %s", db, table));
*ignore_flag= check_if_ignore_table(table, table_type); *ignore_flag= check_if_ignore_table(table, table_type);
if (!opt_copy_s3_tables && *ignore_flag == IGNORE_S3_TABLE)
DBUG_RETURN(0);
delayed= opt_delayed; delayed= opt_delayed;
if (delayed && (*ignore_flag & IGNORE_INSERT_DELAYED)) if (delayed && (*ignore_flag & IGNORE_INSERT_DELAYED))
{ {
...@@ -2975,11 +2994,22 @@ static uint get_table_structure(char *table, char *db, char *table_type, ...@@ -2975,11 +2994,22 @@ static uint get_table_structure(char *table, char *db, char *table_type,
is_log_table= general_log_or_slow_log_tables(db, table); is_log_table= general_log_or_slow_log_tables(db, table);
if (is_log_table) if (is_log_table)
row[1]+= 13; /* strlen("CREATE TABLE ")= 13 */ row[1]+= 13; /* strlen("CREATE TABLE ")= 13 */
create_table_str.str= row[1];
if (opt_copy_s3_tables && (*ignore_flag & IGNORE_S3_TABLE) &&
(s3_engine_ptr= strstr(row[1], s3_engine_token)))
{
init_dynamic_string_checked(&create_table_str, "", 1024, 1024);
dynstr_append_mem_checked(&create_table_str, row[1],
(uint)(s3_engine_ptr - row[1]));
dynstr_append_checked(&create_table_str, aria_engine_token);
dynstr_append_checked(&create_table_str,
s3_engine_ptr + sizeof(s3_engine_token) - 1);
}
if (opt_compatible_mode & 3) if (opt_compatible_mode & 3)
{ {
fprintf(sql_file, fprintf(sql_file,
is_log_table ? "CREATE TABLE IF NOT EXISTS %s;\n" : "%s;\n", is_log_table ? "CREATE TABLE IF NOT EXISTS %s;\n" : "%s;\n",
row[1]); create_table_str.str);
} }
else else
{ {
...@@ -2989,10 +3019,12 @@ static uint get_table_structure(char *table, char *db, char *table_type, ...@@ -2989,10 +3019,12 @@ static uint get_table_structure(char *table, char *db, char *table_type,
"%s%s;\n" "%s%s;\n"
"/*!40101 SET character_set_client = @saved_cs_client */;\n", "/*!40101 SET character_set_client = @saved_cs_client */;\n",
is_log_table ? "CREATE TABLE IF NOT EXISTS " : "", is_log_table ? "CREATE TABLE IF NOT EXISTS " : "",
row[1]); create_table_str.str);
} }
check_io(sql_file); check_io(sql_file);
if (create_table_str.str != row[1])
dynstr_free(&create_table_str);
mysql_free_result(result); mysql_free_result(result);
} }
my_snprintf(query_buff, sizeof(query_buff), "show fields from %s", my_snprintf(query_buff, sizeof(query_buff), "show fields from %s",
...@@ -3691,6 +3723,14 @@ static void dump_table(char *table, char *db) ...@@ -3691,6 +3723,14 @@ static void dump_table(char *table, char *db)
if (strcmp(table_type, "VIEW") == 0) if (strcmp(table_type, "VIEW") == 0)
DBUG_VOID_RETURN; DBUG_VOID_RETURN;
if (!opt_copy_s3_tables && (ignore_flag & IGNORE_S3_TABLE))
{
verbose_msg("-- Skipping dump data for table '%s', "
" this is S3 table and --copy-s3-tables=0\n",
table);
DBUG_VOID_RETURN;
}
/* Check --no-data flag */ /* Check --no-data flag */
if (opt_no_data) if (opt_no_data)
{ {
...@@ -4118,6 +4158,15 @@ static void dump_table(char *table, char *db) ...@@ -4118,6 +4158,15 @@ static void dump_table(char *table, char *db)
fputs("\t</table_data>\n", md_result_file); fputs("\t</table_data>\n", md_result_file);
else if (extended_insert && row_break) else if (extended_insert && row_break)
fputs(";\n", md_result_file); /* If not empty table */ fputs(";\n", md_result_file); /* If not empty table */
if (!opt_xml && opt_copy_s3_tables && (ignore_flag & IGNORE_S3_TABLE))
{
DYNAMIC_STRING alter_string;
init_dynamic_string_checked(&alter_string, "ATER TABLE ", 1024, 1024);
dynstr_append_checked(&alter_string, opt_quoted_table);
dynstr_append_checked(&alter_string, " ENGINE=S3;\n");
fputs(alter_string.str, md_result_file);
dynstr_free(&alter_string);
}
fflush(md_result_file); fflush(md_result_file);
check_io(md_result_file); check_io(md_result_file);
if (mysql_errno(mysql)) if (mysql_errno(mysql))
...@@ -5684,6 +5733,9 @@ char check_if_ignore_table(const char *table_name, char *table_type) ...@@ -5684,6 +5733,9 @@ char check_if_ignore_table(const char *table_name, char *table_type)
result= IGNORE_INSERT_DELAYED; result= IGNORE_INSERT_DELAYED;
} }
if (!strcmp(table_type, "S3"))
result|= IGNORE_S3_TABLE;
/* /*
If these two types, we do want to skip dumping the table If these two types, we do want to skip dumping the table
*/ */
......
create table t1 (pk int primary key, a int);
insert into t1 values (1,1),(2,2),(3,3),(4,4);
alter table t1 engine=S3;
#####
# mysqldump with --copy-s3-tables=0 (by default)
###
#####
# mysqldump with --copy-s3-tables=0 (by default) XML
###
<?xml version="1.0"?>
<mysqldump xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<database name="database">
</database>
</mysqldump>
#####
# mysqldump with --copy-s3-tables=1
###
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `t1` (
`pk` int(11) NOT NULL,
`a` int(11) DEFAULT NULL,
PRIMARY KEY (`pk`)
) ENGINE=Aria DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1;
/*!40101 SET character_set_client = @saved_cs_client */;
INSERT INTO `t1` VALUES (1,1),(2,2),(3,3),(4,4);
ATER TABLE `t1` ENGINE=S3;
#####
# mysqldump with --copy-s3-tables=1 XML
###
<?xml version="1.0"?>
<mysqldump xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<database name="database">
<table_structure name="t1">
<field Field="pk" Type="int(11)" Null="NO" Key="PRI" Extra="" Comment="" />
<field Field="a" Type="int(11)" Null="YES" Key="" Default="NULL" Extra="" Comment="" />
<key Table="t1" Non_unique="0" Key_name="PRIMARY" Seq_in_index="1" Column_name="pk" Collation="A" Cardinality="4" Null="" Index_type="BTREE" Comment="" Index_comment="" />
<options Name="t1" Engine="Aria" Version="10" Row_format="Page" Rows="4" Avg_row_length="4096" Data_length="16384" Max_data_length="17592186011648" Index_length="16384" Data_free="0" Create_time="--TIME--" Collation="latin1_swedish_ci" Create_options="" Comment="" Max_index_length="9007199254732800" Temporary="N" />
</table_structure>
<table_data name="t1">
<row>
<field name="pk">1</field>
<field name="a">1</field>
</row>
<row>
<field name="pk">2</field>
<field name="a">2</field>
</row>
<row>
<field name="pk">3</field>
<field name="a">3</field>
</row>
<row>
<field name="pk">4</field>
<field name="a">4</field>
</row>
</table_data>
</database>
</mysqldump>
drop table t1;
--source include/have_s3.inc
--source create_database.inc
create table t1 (pk int primary key, a int);
insert into t1 values (1,1),(2,2),(3,3),(4,4);
alter table t1 engine=S3;
--echo #####
--echo # mysqldump with --copy-s3-tables=0 (by default)
--echo ###
--exec $MYSQL_DUMP --compact $database
--echo #####
--echo # mysqldump with --copy-s3-tables=0 (by default) XML
--echo ###
--replace_regex /[0-9]{4}-[0-9]{2}-[0-9]{2} [0-9]{2}:[0-9]{2}:[0-9]{2}(.[0-9]{2})*/--TIME--/
--replace_result $database database
--exec $MYSQL_DUMP --compact -X $database
--echo #####
--echo # mysqldump with --copy-s3-tables=1
--echo ###
--exec $MYSQL_DUMP --compact --copy-s3-tables=1 $database
--echo #####
--echo # mysqldump with --copy-s3-tables=1 XML
--echo ###
--replace_regex /[0-9]{4}-[0-9]{2}-[0-9]{2} [0-9]{2}:[0-9]{2}:[0-9]{2}(.[0-9]{2})*/--TIME--/
--replace_result $database database
--exec $MYSQL_DUMP --compact --copy-s3-tables=1 -X $database
drop table t1;
#
# clean up
#
--source drop_database.inc
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment