diff options
author | petr@mysql.com <> | 2006-04-18 08:47:22 +0400 |
---|---|---|
committer | petr@mysql.com <> | 2006-04-18 08:47:22 +0400 |
commit | 423119d21463ffdd38b1775d25a9e590d4f18b6b (patch) | |
tree | a44c13fabdb0798717f5dcb15b5cafad04e978c8 | |
parent | ac6450b85895c360b19fd50f68abe75d01a91f38 (diff) | |
parent | de97f94a49ce139b630b344c39958ea3b92ceeea (diff) | |
download | mariadb-git-423119d21463ffdd38b1775d25a9e590d4f18b6b.tar.gz |
Merge pchardin@bk-internal.mysql.com:/home/bk/mysql-5.1-new
into mysql.com:/home/cps/mysql/trees/mysql-5.1-virgin
-rw-r--r-- | sql/log.cc | 38 |
1 files changed, 27 insertions, 11 deletions
diff --git a/sql/log.cc b/sql/log.cc index 3f6e3108a0b..818abe89e02 100644 --- a/sql/log.cc +++ b/sql/log.cc @@ -676,20 +676,36 @@ bool LOGGER::flush_logs(THD *thd) /* reopen log files */ file_log_handler->flush(); - /* - this will lock and wait for all but the logger thread to release the - tables. Then we could reopen log tables. Then release the name locks. - */ - lock_and_wait_for_table_name(thd, &close_slow_log); - lock_and_wait_for_table_name(thd, &close_general_log); + /* flush tables, in the case they are enabled */ + if (logger.is_log_tables_initialized) + { + /* + This will lock and wait for all but the logger thread to release the + tables. Then we could reopen log tables. Then release the name locks. + + NOTE: in fact, the first parameter used in lock_and_wait_for_table_name() + and table_log_handler->flush() could be any non-NULL THD, as the + underlying code makes certain assumptions about this. + Here we use one of the logger handler THD's. Simply because it + seems appropriate. + */ + lock_and_wait_for_table_name(table_log_handler->general_log_thd, + &close_slow_log); + lock_and_wait_for_table_name(table_log_handler->general_log_thd, + &close_general_log); - /* deny others from logging to general and slow log, while reopening tables */ - logger.lock(); + /* + Deny others from logging to general and slow log, + while reopening tables. + */ + logger.lock(); - table_log_handler->flush(thd, &close_slow_log, &close_general_log); + table_log_handler->flush(table_log_handler->general_log_thd, + &close_slow_log, &close_general_log); - /* end of log tables flush */ - logger.unlock(); + /* end of log tables flush */ + logger.unlock(); + } return FALSE; } |