diff options
author | unknown <tim@threads.polyesthetic.msg> | 2000-11-27 18:14:49 -0500 |
---|---|---|
committer | unknown <tim@threads.polyesthetic.msg> | 2000-11-27 18:14:49 -0500 |
commit | 8f3dfc8db53e24a92884dc1b42f4c2aec0cb96f6 (patch) | |
tree | 5a82ce2301298cea7af3131d25f107fee286c997 /sql/sql_manager.cc | |
parent | a453c30c6f7b5aaecc9482bfc09df677105aa005 (diff) | |
download | mariadb-git-8f3dfc8db53e24a92884dc1b42f4c2aec0cb96f6.tar.gz |
Generalize handle_flush thread to also handle various management
tasks for different handlers. Add a callback from berkeley db to
delete log files that are no longer needed.
configure.in:
enable berkeley dbugging when --with-debug is on
sql/Makefile.am:
change handle_flush to a general maintenance manager thread
sql/mysql_priv.h:
change handle_flush to a general maintenance manager thread
sql/mysqld.cc:
change handle_flush to a general maintenance manager thread
sql/ha_berkeley.cc:
add callback to delete unneeded log files
Diffstat (limited to 'sql/sql_manager.cc')
-rw-r--r-- | sql/sql_manager.cc | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/sql/sql_manager.cc b/sql/sql_manager.cc new file mode 100644 index 00000000000..13fef76d4ab --- /dev/null +++ b/sql/sql_manager.cc @@ -0,0 +1,101 @@ +/* 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 */ + +/* + * sql_manager.cc + * This thread manages various maintenance tasks. + * + * o Flushing the tables every flush_time seconds. + * o Berkeley DB: removing unneeded log files. + */ + +#include "mysql_priv.h" +#include "sql_manager.h" + +ulong manager_status; +bool volatile manager_thread_in_use; + +pthread_t manager_thread; +pthread_mutex_t LOCK_manager; +pthread_cond_t COND_manager; + +pthread_handler_decl(handle_manager,arg __attribute__((unused))) +{ + int error = 0; + ulong status; + struct timespec abstime; + bool reset_flush_time = TRUE; + my_thread_init(); + DBUG_ENTER("handle_manager"); + + pthread_detach_this_thread(); + manager_thread = pthread_self(); + manager_status = 0; + manager_thread_in_use = 1; + + for (;;) + { + pthread_mutex_lock(&LOCK_manager); + /* XXX: This will need to be made more general to handle different + * polling needs. */ + if (flush_time) + { + if (reset_flush_time) + { +#ifdef HAVE_TIMESPEC_TS_SEC + abstime.ts_sec = time(NULL)+flush_time; // Bsd 2.1 + abstime.ts_nsec = 0; +#else + abstime.tv_sec = time(NULL)+flush_time; // Linux or Solairs + abstime.tv_nsec = 0; +#endif + reset_flush_time = FALSE; + } + while (!manager_status && !error && !abort_loop) + error = pthread_cond_timedwait(&COND_manager, &LOCK_manager, &abstime); + } + else + while (!manager_status && !error && !abort_loop) + error = pthread_cond_wait(&COND_manager, &LOCK_manager); + status = manager_status; + manager_status = 0; + pthread_mutex_unlock(&LOCK_manager); + + if (abort_loop) + break; + + if (error) /* == ETIMEDOUT */ + { + flush_tables(); + error = 0; + reset_flush_time = TRUE; + } + +#ifdef HAVE_BERKELEY_DB + if (status & MANAGER_BERKELEY_LOG_CLEANUP) + { + berkeley_cleanup_log_files(); + status &= ~MANAGER_BERKELEY_LOG_CLEANUP; + } +#endif + + if (status) + DBUG_PRINT("error", ("manager did not handle something: %lx", status)); + } + manager_thread_in_use = 0; + my_thread_end(); + DBUG_RETURN(NULL); +} |