Commit 3b06415c authored by Marko Mäkelä's avatar Marko Mäkelä

Clean up log resizing

log_t::rename_resized(): Replaces create_log_file_rename()

delete_log_files(): Moved to a separate function. Also invoked
on a normal startup when the log is not being resized, to
remove any garbage log files.

create_log_file(): Remove the std::string& parameter.

os_file_delete_if_exists_func() [_WIN32]: Do not retry DeleteFile()
on ERROR_ACCESS_DENIED.
parent 73605d18
...@@ -6,6 +6,10 @@ source include/have_innodb.inc; ...@@ -6,6 +6,10 @@ source include/have_innodb.inc;
create table t1 (a int) engine=innodb; create table t1 (a int) engine=innodb;
insert t1 values (1),(2); insert t1 values (1),(2);
create database ib_logfile2; create database ib_logfile2;
--disable_query_log
call mtr.add_suppression("InnoDB: Operating system error number ");
call mtr.add_suppression("InnoDB: Error number .* means ");
--enable_query_log
source include/restart_mysqld.inc; source include/restart_mysqld.inc;
select * from t1; select * from t1;
drop table t1; drop table t1;
......
...@@ -289,6 +289,10 @@ struct log_t ...@@ -289,6 +289,10 @@ struct log_t
bool is_opened() const noexcept { return log.is_opened(); } bool is_opened() const noexcept { return log.is_opened(); }
/** Rename a log file after resizing.
@return whether an error occurred */
static bool rename_resized() noexcept;
void attach(log_file_t file, os_offset_t size); void attach(log_file_t file, os_offset_t size);
void close_file(); void close_file();
......
...@@ -2424,16 +2424,15 @@ os_file_delete_if_exists_func( ...@@ -2424,16 +2424,15 @@ os_file_delete_if_exists_func(
return(true); return(true);
} }
DWORD lasterr = GetLastError(); switch (GetLastError()) {
case ERROR_FILE_NOT_FOUND:
if (lasterr == ERROR_FILE_NOT_FOUND case ERROR_PATH_NOT_FOUND:
|| lasterr == ERROR_PATH_NOT_FOUND) {
/* the file does not exist, this not an error */ /* the file does not exist, this not an error */
if (exist != NULL) { if (exist != NULL) {
*exist = false; *exist = false;
} }
/* fall through */
case ERROR_ACCESS_DENIED:
return(true); return(true);
} }
......
...@@ -172,35 +172,33 @@ static PSI_stage_info* srv_stages[] = ...@@ -172,35 +172,33 @@ static PSI_stage_info* srv_stages[] =
}; };
#endif /* HAVE_PSI_STAGE_INTERFACE */ #endif /* HAVE_PSI_STAGE_INTERFACE */
/** Initial number of the redo log file */ /** Delete any garbage log files */
static const char INIT_LOG_FILE0[]= "101"; static void delete_log_files()
{
for (size_t i= 1; i < 102; i++)
delete_log_file(std::to_string(i).c_str());
}
/** Creates log file. /** Creates log file.
@param create_new_db whether the database is being initialized @param create_new_db whether the database is being initialized
@param lsn log sequence number @param lsn log sequence number
@param logfile0 name of the log file @param logfile0 name of the log file
@return DB_SUCCESS or error code */ @return DB_SUCCESS or error code */
static dberr_t create_log_file(bool create_new_db, lsn_t lsn, static dberr_t create_log_file(bool create_new_db, lsn_t lsn)
std::string& logfile0)
{ {
ut_ad(!srv_read_only_mode); ut_ad(!srv_read_only_mode);
/* We will retain ib_logfile0 until we have written a new logically /* We will retain ib_logfile0 until we have written a new logically
empty log as ib_logfile101 and atomically renamed it to empty log as ib_logfile101 and atomically renamed it to
ib_logfile0 in create_log_file_rename(). */ ib_logfile0 in log_t::rename_resized(). */
delete_log_files();
for (size_t i = 1; i < 102; i++) {
delete_log_file(std::to_string(i).c_str());
}
DBUG_ASSERT(!buf_pool.any_io_pending()); DBUG_ASSERT(!buf_pool.any_io_pending());
log_sys.latch.wr_lock(SRW_LOCK_CALL); log_sys.latch.wr_lock(SRW_LOCK_CALL);
log_sys.set_capacity(); log_sys.set_capacity();
logfile0 = get_log_file_path(LOG_FILE_NAME_PREFIX) std::string logfile0{get_log_file_path("ib_logfile101")};
.append(INIT_LOG_FILE0);
bool ret; bool ret;
pfs_os_file_t file = os_file_create( pfs_os_file_t file = os_file_create(
innodb_log_file_key, logfile0.c_str(), innodb_log_file_key, logfile0.c_str(),
...@@ -208,7 +206,8 @@ static dberr_t create_log_file(bool create_new_db, lsn_t lsn, ...@@ -208,7 +206,8 @@ static dberr_t create_log_file(bool create_new_db, lsn_t lsn,
OS_LOG_FILE, srv_read_only_mode, &ret); OS_LOG_FILE, srv_read_only_mode, &ret);
if (!ret) { if (!ret) {
sql_print_error("InnoDB: Cannot create %s", logfile0.c_str()); sql_print_error("InnoDB: Cannot create %.*s",
int(logfile0.size()), logfile0.data());
err_exit: err_exit:
log_sys.latch.wr_unlock(); log_sys.latch.wr_unlock();
return DB_ERROR; return DB_ERROR;
...@@ -250,31 +249,25 @@ static dberr_t create_log_file(bool create_new_db, lsn_t lsn, ...@@ -250,31 +249,25 @@ static dberr_t create_log_file(bool create_new_db, lsn_t lsn,
return DB_SUCCESS; return DB_SUCCESS;
} }
/** Rename the first redo log file. /** Rename the redo log file after resizing.
@param lsn log sequence number @return whether an error occurred */
@param logfile0 name of the log file bool log_t::rename_resized() noexcept
@return error code
@retval DB_SUCCESS on successful operation */
MY_ATTRIBUTE((warn_unused_result))
static dberr_t create_log_file_rename(lsn_t lsn, std::string &logfile0)
{ {
ut_ad(!srv_log_file_created); ut_ad(!srv_log_file_created);
ut_d(srv_log_file_created= true); ut_d(srv_log_file_created= true);
std::string old_name{get_log_file_path("ib_logfile101")};
std::string new_name{get_log_file_path()}; std::string new_name{get_log_file_path()};
ut_ad(logfile0.size() == 2 + new_name.size());
if (IF_WIN(!MoveFileEx(logfile0.c_str(), new_name.c_str(), if (IF_WIN(MoveFileEx(old_name.c_str(), new_name.c_str(),
MOVEFILE_REPLACE_EXISTING), MOVEFILE_REPLACE_EXISTING),
rename(logfile0.c_str(), new_name.c_str()))) !rename(old_name.c_str(), new_name.c_str())))
{ return false;
sql_print_error("InnoDB: Failed to rename log from %s to %s",
logfile0.c_str(), new_name.c_str());
return DB_ERROR;
}
logfile0= new_name; sql_print_error("InnoDB: Failed to rename log from %.*s to %.*s",
return DB_SUCCESS; int(old_name.size()), old_name.data(),
int(new_name.size()), new_name.data());
return true;
} }
/** Create an undo tablespace file /** Create an undo tablespace file
...@@ -1098,11 +1091,10 @@ dberr_t srv_start(bool create_new_db) ...@@ -1098,11 +1091,10 @@ dberr_t srv_start(bool create_new_db)
return srv_init_abort(DB_ERROR); return srv_init_abort(DB_ERROR);
} }
std::string logfile0;
if (create_new_db) { if (create_new_db) {
lsn_t flushed_lsn = log_sys.init_lsn(); lsn_t flushed_lsn = log_sys.init_lsn();
err = create_log_file(true, flushed_lsn, logfile0); err = create_log_file(true, flushed_lsn);
if (err != DB_SUCCESS) { if (err != DB_SUCCESS) {
for (const Datafile &file: srv_sys_space) { for (const Datafile &file: srv_sys_space) {
...@@ -1179,10 +1171,8 @@ dberr_t srv_start(bool create_new_db) ...@@ -1179,10 +1171,8 @@ dberr_t srv_start(bool create_new_db)
buf_flush_sync(); buf_flush_sync();
err = create_log_file_rename(log_sys.get_lsn(), logfile0); if (log_sys.rename_resized()) {
return(srv_init_abort(DB_ERROR));
if (err != DB_SUCCESS) {
return(srv_init_abort(err));
} }
} else { } else {
/* Suppress warnings in fil_space_t::create() for files /* Suppress warnings in fil_space_t::create() for files
...@@ -1361,6 +1351,7 @@ dberr_t srv_start(bool create_new_db) ...@@ -1361,6 +1351,7 @@ dberr_t srv_start(bool create_new_db)
: log_t::FORMAT_10_8)) { : log_t::FORMAT_10_8)) {
/* No need to add or remove encryption, /* No need to add or remove encryption,
upgrade, or resize. */ upgrade, or resize. */
delete_log_files();
} else { } else {
/* Prepare to delete the old redo log file */ /* Prepare to delete the old redo log file */
const lsn_t lsn{srv_prepare_to_delete_redo_log_file()}; const lsn_t lsn{srv_prepare_to_delete_redo_log_file()};
...@@ -1380,10 +1371,10 @@ dberr_t srv_start(bool create_new_db) ...@@ -1380,10 +1371,10 @@ dberr_t srv_start(bool create_new_db)
return(srv_init_abort(DB_ERROR));); return(srv_init_abort(DB_ERROR)););
DBUG_PRINT("ib_log", ("After innodb_log_abort_5")); DBUG_PRINT("ib_log", ("After innodb_log_abort_5"));
err = create_log_file(false, lsn, logfile0); err = create_log_file(false, lsn);
if (err == DB_SUCCESS) { if (err == DB_SUCCESS && log_sys.rename_resized()) {
err = create_log_file_rename(lsn, logfile0); err = DB_ERROR;
} }
if (err != DB_SUCCESS) { if (err != DB_SUCCESS) {
......
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