Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
08e12cad
Commit
08e12cad
authored
Feb 01, 2006
by
mikron@c-4d08e253.1238-1-64736c10.cust.bredbandsbolaget.se
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
WL 2826: First step in error handling of ALTER TABLE for partitioning
parent
86a15e5e
Changes
15
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
307 additions
and
138 deletions
+307
-138
BUILD/SETUP.sh
BUILD/SETUP.sh
+1
-0
BUILD/compile-pentium-debug-max
BUILD/compile-pentium-debug-max
+1
-1
configure.in
configure.in
+13
-0
sql/ha_ndbcluster.cc
sql/ha_ndbcluster.cc
+7
-1
sql/ha_ndbcluster.h
sql/ha_ndbcluster.h
+2
-1
sql/ha_partition.cc
sql/ha_partition.cc
+23
-4
sql/ha_partition.h
sql/ha_partition.h
+2
-1
sql/handler.h
sql/handler.h
+5
-1
sql/mysql_priv.h
sql/mysql_priv.h
+27
-3
sql/mysqld.cc
sql/mysqld.cc
+6
-0
sql/set_var.cc
sql/set_var.cc
+10
-0
sql/sql_class.h
sql/sql_class.h
+4
-0
sql/sql_partition.cc
sql/sql_partition.cc
+109
-54
sql/sql_table.cc
sql/sql_table.cc
+96
-71
sql/unireg.cc
sql/unireg.cc
+1
-1
No files found.
BUILD/SETUP.sh
View file @
08e12cad
...
...
@@ -71,6 +71,7 @@ pentium_cflags="$check_cpu_cflags"
pentium64_cflags
=
"
$check_cpu_cflags
-m64"
ppc_cflags
=
"
$check_cpu_cflags
"
sparc_cflags
=
""
error_inject_flag
=
"--with-error-inject "
# be as fast as we can be without losing our ability to backtrace
fast_cflags
=
"-O3 -fno-omit-frame-pointer"
...
...
BUILD/compile-pentium-debug-max
View file @
08e12cad
...
...
@@ -3,7 +3,7 @@
path
=
`
dirname
$0
`
.
"
$path
/SETUP.sh"
$@
--with-debug
=
full
extra_flags
=
"
$pentium_cflags
$debug_cflags
$max_cflags
"
extra_flags
=
"
$pentium_cflags
$debug_cflags
$max_cflags
$error_inject_flag
"
c_warnings
=
"
$c_warnings
$debug_extra_warnings
"
cxx_warnings
=
"
$cxx_warnings
$debug_extra_warnings
"
extra_configs
=
"
$pentium_configs
$debug_configs
$max_configs
"
...
...
configure.in
View file @
08e12cad
...
...
@@ -654,6 +654,7 @@ else
AC_MSG_RESULT
([
no]
)
fi
MYSQL_SYS_LARGEFILE
# Types that must be checked AFTER large file support is checked
...
...
@@ -1554,6 +1555,18 @@ then
DEBUG_OPTIMIZE_CXX
=
""
fi
# If we should allow error injection tests
AC_ARG_WITH
(
error-inject,
[
--with-error-inject
Enable error injection
in
MySQL Server],
[
with_error_inject
=
$withval
]
,
[
with_error_inject
=
no
])
if
test
"
$with_error_inject
"
=
"yes"
then
CFLAGS
=
"-DERROR_INJECT_SUPPORT
$CFLAGS
"
CXXFLAGS
=
"-DERROR_INJECT_SUPPORT
$CXXFLAGS
"
fi
AC_ARG_WITH
(
debug,
[
--without-debug
Build a production version without debugging code],
[
with_debug
=
$withval
]
,
...
...
sql/ha_ndbcluster.cc
View file @
08e12cad
...
...
@@ -4399,7 +4399,9 @@ int ha_ndbcluster::create(const char *name,
DBUG_RETURN
(
my_errno
);
}
int
ha_ndbcluster
::
create_handler_files
(
const
char
*
file
)
int
ha_ndbcluster
::
create_handler_files
(
const
char
*
file
,
const
char
*
old_name
,
bool
rename_flag
)
{
const
char
*
name
;
Ndb
*
ndb
;
...
...
@@ -4410,6 +4412,10 @@ int ha_ndbcluster::create_handler_files(const char *file)
DBUG_ENTER
(
"create_handler_files"
);
if
(
rename_flag
)
{
DBUG_RETURN
(
FALSE
);
}
if
(
!
(
ndb
=
get_ndb
()))
DBUG_RETURN
(
HA_ERR_NO_CONNECTION
);
...
...
sql/ha_ndbcluster.h
View file @
08e12cad
...
...
@@ -588,7 +588,8 @@ class ha_ndbcluster: public handler
int
rename_table
(
const
char
*
from
,
const
char
*
to
);
int
delete_table
(
const
char
*
name
);
int
create
(
const
char
*
name
,
TABLE
*
form
,
HA_CREATE_INFO
*
info
);
int
create_handler_files
(
const
char
*
file
);
int
create_handler_files
(
const
char
*
file
,
const
char
*
old_name
,
bool
rename_flag
);
int
get_default_no_partitions
(
ulonglong
max_rows
);
bool
get_no_parts
(
const
char
*
name
,
uint
*
no_parts
);
void
set_auto_partitions
(
partition_info
*
part_info
);
...
...
sql/ha_partition.cc
View file @
08e12cad
...
...
@@ -563,7 +563,9 @@ int ha_partition::rename_table(const char *from, const char *to)
and types of engines in the partitions.
*/
int
ha_partition
::
create_handler_files
(
const
char
*
name
)
int
ha_partition
::
create_handler_files
(
const
char
*
path
,
const
char
*
old_path
,
bool
rename_flag
)
{
DBUG_ENTER
(
"ha_partition::create_handler_files()"
);
...
...
@@ -571,11 +573,28 @@ int ha_partition::create_handler_files(const char *name)
We need to update total number of parts since we might write the handler
file as part of a partition management command
*/
if
(
create_handler_file
(
name
))
if
(
rename_flag
)
{
char
name
[
FN_REFLEN
];
char
old_name
[
FN_REFLEN
];
char
*
par_str
=
".par"
;
strxmov
(
name
,
path
,
par_str
,
NullS
);
strxmov
(
old_name
,
old_path
,
par_str
,
NullS
);
if
(
my_delete
(
name
,
MYF
(
MY_WME
))
||
my_rename
(
old_name
,
name
,
MYF
(
MY_WME
)))
{
DBUG_RETURN
(
TRUE
);
}
}
else
{
if
(
create_handler_file
(
path
))
{
my_error
(
ER_CANT_CREATE_HANDLER_FILE
,
MYF
(
0
));
DBUG_RETURN
(
1
);
}
}
DBUG_RETURN
(
0
);
}
...
...
sql/ha_partition.h
View file @
08e12cad
...
...
@@ -179,7 +179,8 @@ public:
virtual
int
rename_table
(
const
char
*
from
,
const
char
*
to
);
virtual
int
create
(
const
char
*
name
,
TABLE
*
form
,
HA_CREATE_INFO
*
create_info
);
virtual
int
create_handler_files
(
const
char
*
name
);
virtual
int
create_handler_files
(
const
char
*
name
,
const
char
*
old_name
,
bool
rename_flag
);
virtual
void
update_create_info
(
HA_CREATE_INFO
*
create_info
);
virtual
char
*
update_table_comment
(
const
char
*
comment
);
virtual
int
change_partitions
(
HA_CREATE_INFO
*
create_info
,
...
...
sql/handler.h
View file @
08e12cad
...
...
@@ -1779,7 +1779,11 @@ public:
virtual
void
drop_table
(
const
char
*
name
);
virtual
int
create
(
const
char
*
name
,
TABLE
*
form
,
HA_CREATE_INFO
*
info
)
=
0
;
virtual
int
create_handler_files
(
const
char
*
name
)
{
return
FALSE
;}
virtual
int
create_handler_files
(
const
char
*
name
,
const
char
*
old_name
,
bool
rename_flag
)
{
return
FALSE
;
}
virtual
int
change_partitions
(
HA_CREATE_INFO
*
create_info
,
const
char
*
path
,
...
...
sql/mysql_priv.h
View file @
08e12cad
...
...
@@ -603,6 +603,29 @@ struct Query_cache_query_flags
#define query_cache_invalidate_by_MyISAM_filename_ref NULL
#endif
/*HAVE_QUERY_CACHE*/
/*
Error injector Macros to enable easy testing of recovery after failures
in various error cases.
*/
#ifndef ERROR_INJECT_SUPPORT
#define ERROR_INJECTOR(x)
#define ERROR_INJECTOR_ACTION(x)
#define ERROR_INJECTOR_CRASH(x)
#else
inline
bool
my_error_inject
(
int
error
)
{
return
(
current_thd
->
variables
.
error_inject_code
==
error
)
?
1
:
0
;
}
#define ERROR_INJECTOR_CRASH(code) \
(my_error_inject((code)) ? ((DBUG_ASSERT(0)), 0) : 0
#define ERROR_INJECTOR_ACTION(code, action) \
(my_error_inject((code)) ? ((action), 0) : 0
#define ERROR_INJECT(code) \
(my_error_inject((code)) ? 1 : 0)
#endif
uint
build_table_path
(
char
*
buff
,
size_t
bufflen
,
const
char
*
db
,
const
char
*
table
,
const
char
*
ext
);
void
write_bin_log
(
THD
*
thd
,
bool
clear_error
,
...
...
@@ -1099,9 +1122,10 @@ typedef struct st_lock_param_type
}
ALTER_PARTITION_PARAM_TYPE
;
void
mem_alloc_error
(
size_t
size
);
#define WFRM_INITIAL_WRITE 1
#define WFRM_CREATE_HANDLER_FILES 2
#define WFRM_PACK_FRM 4
bool
write_table_log
(
ALTER_PARTITION_PARAM_TYPE
*
lpt
);
#define WFRM_WRITE_SHADOW 1
#define WFRM_INSTALL_SHADOW 2
#define WFRM_PACK_FRM
bool
mysql_write_frm
(
ALTER_PARTITION_PARAM_TYPE
*
lpt
,
uint
flags
);
bool
abort_and_upgrade_lock
(
ALTER_PARTITION_PARAM_TYPE
*
lpt
);
void
close_open_tables_and_downgrade
(
ALTER_PARTITION_PARAM_TYPE
*
lpt
);
...
...
sql/mysqld.cc
View file @
08e12cad
...
...
@@ -7055,6 +7055,12 @@ static void mysql_init_variables(void)
max_system_variables
.
max_join_size
=
(
ulonglong
)
HA_POS_ERROR
;
global_system_variables
.
old_passwords
=
0
;
global_system_variables
.
old_alter_table
=
0
;
#ifdef ERROR_INJECT_SUPPORT
global_system_variables
.
error_inject_code
=
0
;
global_system_variables
.
error_inject_value
=
0
;
max_system_variables
.
error_inject_code
=
~
0
;
max_system_variables
.
error_inject_value
=
~
0
;
#endif
/*
Default behavior for 4.1 and 5.0 is to treat NULL values as unequal
...
...
sql/set_var.cc
View file @
08e12cad
...
...
@@ -215,6 +215,12 @@ sys_var_long_ptr sys_delayed_insert_timeout("delayed_insert_timeout",
&
delayed_insert_timeout
);
sys_var_long_ptr
sys_delayed_queue_size
(
"delayed_queue_size"
,
&
delayed_queue_size
);
#ifdef ERROR_INJECT_SUPPORT
sys_var_long_ptr
sys_error_inject_code
(
"error_inject_code"
,
&
error_inject_code
);
sys_var_long_ptr
sys_error_inject_value
(
"error_inject_value"
,
&
error_inject_value
);
#endif
sys_var_event_executor
sys_event_executor
(
"event_scheduler"
,
&
event_executor_running_global_var
);
sys_var_long_ptr
sys_expire_logs_days
(
"expire_logs_days"
,
...
...
@@ -729,6 +735,10 @@ SHOW_VAR init_vars[]= {
{
sys_div_precincrement
.
name
,(
char
*
)
&
sys_div_precincrement
,
SHOW_SYS
},
{
sys_engine_condition_pushdown
.
name
,
(
char
*
)
&
sys_engine_condition_pushdown
,
SHOW_SYS
},
#ifdef ERROR_INJECT_SUPPORT
{
sys_error_inject_code
.
name
,(
char
*
)
&
sys_error_inject_code
,
SHOW_SYS
},
{
sys_error_inject_value
.
name
,(
char
*
)
&
sys_error_inject_value
,
SHOW_SYS
},
#endif
{
sys_event_executor
.
name
,
(
char
*
)
&
sys_event_executor
,
SHOW_SYS
},
{
sys_expire_logs_days
.
name
,
(
char
*
)
&
sys_expire_logs_days
,
SHOW_SYS
},
{
sys_flush
.
name
,
(
char
*
)
&
sys_flush
,
SHOW_SYS
},
...
...
sql/sql_class.h
View file @
08e12cad
...
...
@@ -186,6 +186,10 @@ struct system_variables
ha_rows
max_join_size
;
ulong
auto_increment_increment
,
auto_increment_offset
;
ulong
bulk_insert_buff_size
;
#ifdef ERROR_INJECT_SUPPORT
ulong
error_inject_code
;
ulong
error_inject_value
;
#endif
ulong
join_buff_size
;
ulong
long_query_time
;
ulong
max_allowed_packet
;
...
...
sql/sql_partition.cc
View file @
08e12cad
This diff is collapsed.
Click to expand it.
sql/sql_table.cc
View file @
08e12cad
...
...
@@ -245,6 +245,28 @@ static int mysql_copy_key_list(List<Key> *orig_key,
}
/*
SYNOPSIS
write_table_log()
lpt Struct carrying parameters to the function
RETURN VALUES
TRUE Failure in writing the log
FALSE Success
DESCRIPTION
A careful write of the table log is performed to ensure that we can
handle crashes occurring during CREATE and ALTER TABLE processing.
*/
bool
write_table_log
(
ALTER_PARTITION_PARAM_TYPE
*
lpt
)
{
DBUG_ENTER
(
"write_table_log"
);
DBUG_RETURN
(
FALSE
);
}
/*
SYNOPSIS
mysql_write_frm()
...
...
@@ -277,27 +299,32 @@ bool mysql_write_frm(ALTER_PARTITION_PARAM_TYPE *lpt, uint flags)
*/
int
error
=
0
;
char
path
[
FN_REFLEN
+
1
];
char
shadow_path
[
FN_REFLEN
+
1
];
char
shadow_frm_name
[
FN_REFLEN
+
1
];
char
frm_name
[
FN_REFLEN
+
1
];
DBUG_ENTER
(
"mysql_write_frm"
);
if
(
flags
&
WFRM_INITIAL_WRITE
)
{
error
=
mysql_copy_create_list
(
lpt
->
create_list
,
&
lpt
->
new_create_list
);
error
+=
mysql_copy_key_list
(
lpt
->
key_list
,
&
lpt
->
new_key_list
);
if
(
error
)
{
DBUG_RETURN
(
TRUE
);
}
}
build_table_filename
(
path
,
sizeof
(
path
),
lpt
->
db
,
lpt
->
table_name
,
""
);
strxmov
(
frm_name
,
path
,
reg_ext
,
NullS
);
if
((
flags
&
WFRM_INITIAL_WRITE
)
&&
(
mysql_prepare_table
(
lpt
->
thd
,
lpt
->
create_info
,
&
lpt
->
new_create_list
,
&
lpt
->
new_key_list
,
/*tmp_table*/
1
,
&
lpt
->
db_options
,
lpt
->
table
->
file
,
&
lpt
->
key_info_buffer
,
&
lpt
->
key_count
,
/*select_field_count*/
0
)))
/*
Build shadow frm file name
*/
build_table_filename
(
shadow_path
,
sizeof
(
path
),
lpt
->
db
,
lpt
->
table_name
,
"#"
);
strxmov
(
shadow_frm_name
,
path
,
reg_ext
,
NullS
);
if
(
flags
&
WFRM_WRITE_SHADOW
)
{
if
(
mysql_copy_create_list
(
lpt
->
create_list
,
&
lpt
->
new_create_list
)
||
mysql_copy_key_list
(
lpt
->
key_list
,
&
lpt
->
new_key_list
)
||
mysql_prepare_table
(
lpt
->
thd
,
lpt
->
create_info
,
&
lpt
->
new_create_list
,
&
lpt
->
new_key_list
,
/*tmp_table*/
1
,
&
lpt
->
db_options
,
lpt
->
table
->
file
,
&
lpt
->
key_info_buffer
,
&
lpt
->
key_count
,
/*select_field_count*/
0
)))
{
DBUG_RETURN
(
TRUE
);
}
...
...
@@ -305,56 +332,34 @@ bool mysql_write_frm(ALTER_PARTITION_PARAM_TYPE *lpt, uint flags)
{
partition_info
*
part_info
=
lpt
->
table
->
part_info
;
char
*
part_syntax_buf
;
uint
syntax_len
,
i
;
bool
any_unnormal_state
=
FALSE
;
uint
syntax_len
;
if
(
part_info
)
{
uint
max_part_state_len
=
part_info
->
partitions
.
elements
+
part_info
->
temp_partitions
.
elements
;
if
(
!
(
part_info
->
part_state
=
(
uchar
*
)
sql_alloc
(
max_part_state_len
)))
{
DBUG_RETURN
(
TRUE
);
}
part_info
->
part_state_len
=
0
;
if
(
!
(
part_syntax_buf
=
generate_partition_syntax
(
part_info
,
&
syntax_len
,
TRUE
,
FALSE
)))
{
DBUG_RETURN
(
TRUE
);
}
for
(
i
=
0
;
i
<
part_info
->
part_state_len
;
i
++
)
{
enum
partition_state
part_state
=
(
enum
partition_state
)
part_info
->
part_state
[
i
];
if
(
part_state
!=
PART_NORMAL
&&
part_state
!=
PART_IS_ADDED
)
any_unnormal_state
=
TRUE
;
}
if
(
!
any_unnormal_state
)
{
part_info
->
part_state
=
NULL
;
part_info
->
part_state_len
=
0
;
}
part_info
->
part_info_string
=
part_syntax_buf
;
part_info
->
part_info_len
=
syntax_len
;
}
}
#endif
/*
We write the frm file with the LOCK_open mutex since otherwise we could
overwrite the frm file as another is reading it in open_table.
*/
/* Write shadow frm file */
lpt
->
create_info
->
table_options
=
lpt
->
db_options
;
VOID
(
pthread_mutex_lock
(
&
LOCK_open
));
if
((
mysql_create_frm
(
lpt
->
thd
,
frm_name
,
lpt
->
db
,
lpt
->
table_name
,
lpt
->
create_info
,
lpt
->
new_create_list
,
lpt
->
key_count
,
if
((
mysql_create_frm
(
lpt
->
thd
,
shadow_frm_name
,
lpt
->
db
,
lpt
->
table_name
,
lpt
->
create_info
,
lpt
->
new_create_list
,
lpt
->
key_count
,
lpt
->
key_info_buffer
,
lpt
->
table
->
file
))
||
((
flags
&
WFRM_CREATE_HANDLER_FILES
)
&&
lpt
->
table
->
file
->
create_handler_files
(
path
)))
lpt
->
table
->
file
->
create_handler_files
(
shadow_path
,
NULL
,
FALSE
))
{
my_delete
(
shadow_frm_name
,
MYF
(
0
));
error
=
1
;
goto
end
;
}
}
if
(
flags
&
WFRM_PACK_FRM
)
{
/*
...
...
@@ -365,7 +370,7 @@ bool mysql_write_frm(ALTER_PARTITION_PARAM_TYPE *lpt, uint flags)
*/
const
void
*
data
=
0
;
uint
length
=
0
;
if
(
readfrm
(
path
,
&
data
,
&
length
)
||
if
(
readfrm
(
shadow_
path
,
&
data
,
&
length
)
||
packfrm
(
data
,
length
,
&
lpt
->
pack_frm_data
,
&
lpt
->
pack_frm_len
))
{
my_free
((
char
*
)
data
,
MYF
(
MY_ALLOW_ZERO_PTR
));
...
...
@@ -374,11 +379,31 @@ bool mysql_write_frm(ALTER_PARTITION_PARAM_TYPE *lpt, uint flags)
error
=
1
;
goto
end
;
}
error
=
my_delete
(
frm_name
,
MYF
(
MY_WME
));
error
=
my_delete
(
shadow_frm_name
,
MYF
(
MY_WME
));
}
if
(
flags
&
WFRM_INSTALL_SHADOW
)
{
/*
Build frm file name
*/
build_table_filename
(
path
,
sizeof
(
path
),
lpt
->
db
,
lpt
->
table_name
,
""
);
strxmov
(
frm_name
,
path
,
reg_ext
,
NullS
);
/*
When we are changing to use new frm file we need to ensure that we
don't collide with another thread in process to open the frm file.
*/
VOID
(
pthread_mutex_lock
(
&
LOCK_open
));
if
(
my_delete
(
frm_name
,
MYF
(
MY_WME
))
||
my_rename
(
shadow_frm_name
,
frm_name
,
MYF
(
MY_WME
))
||
lpt
->
table
->
file
->
create_handler_files
(
path
,
shadow_path
,
TRUE
))
{
error
=
1
;
}
/* Frm file have been updated to reflect the change about to happen. */
end:
VOID
(
pthread_mutex_unlock
(
&
LOCK_open
));
}
end:
DBUG_RETURN
(
error
);
}
...
...
@@ -4631,7 +4656,7 @@ bool mysql_alter_table(THD *thd,char *new_db, char *new_name,
error
=
(
mysql_create_frm
(
thd
,
reg_path
,
db
,
table_name
,
create_info
,
prepared_create_list
,
key_count
,
key_info_buffer
,
table
->
file
)
||
table
->
file
->
create_handler_files
(
reg_path
));
table
->
file
->
create_handler_files
(
reg_path
,
NULL
,
FALSE
));
VOID
(
pthread_mutex_unlock
(
&
LOCK_open
));
if
(
error
)
goto
err
;
...
...
@@ -4677,7 +4702,7 @@ bool mysql_alter_table(THD *thd,char *new_db, char *new_name,
error
=
(
mysql_create_frm
(
thd
,
reg_path
,
db
,
table_name
,
create_info
,
prepared_create_list
,
key_count
,
key_info_buffer
,
table
->
file
)
||
table
->
file
->
create_handler_files
(
reg_path
));
table
->
file
->
create_handler_files
(
reg_path
,
NULL
,
FALSE
));
VOID
(
pthread_mutex_unlock
(
&
LOCK_open
));
if
(
error
)
goto
err
;
...
...
@@ -4900,7 +4925,7 @@ bool mysql_alter_table(THD *thd,char *new_db, char *new_name,
VOID
(
pthread_mutex_lock
(
&
LOCK_open
));
}
/* Tell the handler that a new frm file is in place. */
if
(
table
->
file
->
create_handler_files
(
reg_path
))
if
(
table
->
file
->
create_handler_files
(
reg_path
,
NULL
,
FALSE
))
{
VOID
(
pthread_mutex_unlock
(
&
LOCK_open
));
goto
err
;
...
...
sql/unireg.cc
View file @
08e12cad
...
...
@@ -330,7 +330,7 @@ int rea_create_table(THD *thd, const char *path,
// Make sure mysql_create_frm din't remove extension
DBUG_ASSERT
(
*
fn_rext
(
frm_name
));
if
(
file
->
create_handler_files
(
path
))
if
(
file
->
create_handler_files
(
path
,
NULL
,
FALSE
))
goto
err_handler
;
if
(
!
create_info
->
frm_only
&&
ha_create_table
(
thd
,
path
,
db
,
table_name
,
create_info
,
0
))
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment