mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
128 lines
4.7 KiB
C
128 lines
4.7 KiB
C
|
/*****************************************************************************
|
||
|
|
||
|
Copyright (c) 2012, 2013, Oracle and/or its affiliates. All Rights Reserved.
|
||
|
|
||
|
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; version 2 of the License.
|
||
|
|
||
|
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.,
|
||
|
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA
|
||
|
|
||
|
*****************************************************************************/
|
||
|
|
||
|
/**************************************************//**
|
||
|
@file include/dict0stats_bg.h
|
||
|
Code used for background table and index stats gathering.
|
||
|
|
||
|
Created Apr 26, 2012 Vasil Dimov
|
||
|
*******************************************************/
|
||
|
|
||
|
#ifndef dict0stats_bg_h
|
||
|
#define dict0stats_bg_h
|
||
|
|
||
|
#include "univ.i"
|
||
|
|
||
|
#include "dict0types.h" /* dict_table_t, table_id_t */
|
||
|
#include "os0sync.h" /* os_event_t */
|
||
|
#include "os0thread.h" /* DECLARE_THREAD */
|
||
|
|
||
|
/** Event to wake up the stats thread */
|
||
|
extern os_event_t dict_stats_event;
|
||
|
|
||
|
/*****************************************************************//**
|
||
|
Add a table to the recalc pool, which is processed by the
|
||
|
background stats gathering thread. Only the table id is added to the
|
||
|
list, so the table can be closed after being enqueued and it will be
|
||
|
opened when needed. If the table does not exist later (has been DROPped),
|
||
|
then it will be removed from the pool and skipped. */
|
||
|
UNIV_INTERN
|
||
|
void
|
||
|
dict_stats_recalc_pool_add(
|
||
|
/*=======================*/
|
||
|
const dict_table_t* table); /*!< in: table to add */
|
||
|
|
||
|
/*****************************************************************//**
|
||
|
Delete a given table from the auto recalc pool.
|
||
|
dict_stats_recalc_pool_del() */
|
||
|
UNIV_INTERN
|
||
|
void
|
||
|
dict_stats_recalc_pool_del(
|
||
|
/*=======================*/
|
||
|
const dict_table_t* table); /*!< in: table to remove */
|
||
|
|
||
|
/** Yield the data dictionary latch when waiting
|
||
|
for the background thread to stop accessing a table.
|
||
|
@param trx transaction holding the data dictionary locks */
|
||
|
#define DICT_STATS_BG_YIELD(trx) do { \
|
||
|
row_mysql_unlock_data_dictionary(trx); \
|
||
|
os_thread_sleep(250000); \
|
||
|
row_mysql_lock_data_dictionary(trx); \
|
||
|
} while (0)
|
||
|
|
||
|
/*****************************************************************//**
|
||
|
Request the background collection of statistics to stop for a table.
|
||
|
@retval true when no background process is active
|
||
|
@retval false when it is not safe to modify the table definition */
|
||
|
UNIV_INLINE
|
||
|
bool
|
||
|
dict_stats_stop_bg(
|
||
|
/*===============*/
|
||
|
dict_table_t* table) /*!< in/out: table */
|
||
|
__attribute__((warn_unused_result));
|
||
|
|
||
|
/*****************************************************************//**
|
||
|
Wait until background stats thread has stopped using the specified table.
|
||
|
The caller must have locked the data dictionary using
|
||
|
row_mysql_lock_data_dictionary() and this function may unlock it temporarily
|
||
|
and restore the lock before it exits.
|
||
|
The background stats thread is guaranteed not to start using the specified
|
||
|
table after this function returns and before the caller unlocks the data
|
||
|
dictionary because it sets the BG_STAT_IN_PROGRESS bit in table->stats_bg_flag
|
||
|
under dict_sys->mutex. */
|
||
|
UNIV_INTERN
|
||
|
void
|
||
|
dict_stats_wait_bg_to_stop_using_table(
|
||
|
/*===================================*/
|
||
|
dict_table_t* table, /*!< in/out: table */
|
||
|
trx_t* trx); /*!< in/out: transaction to use for
|
||
|
unlocking/locking the data dict */
|
||
|
/*****************************************************************//**
|
||
|
Initialize global variables needed for the operation of dict_stats_thread().
|
||
|
Must be called before dict_stats_thread() is started. */
|
||
|
UNIV_INTERN
|
||
|
void
|
||
|
dict_stats_thread_init();
|
||
|
/*====================*/
|
||
|
|
||
|
/*****************************************************************//**
|
||
|
Free resources allocated by dict_stats_thread_init(), must be called
|
||
|
after dict_stats_thread() has exited. */
|
||
|
UNIV_INTERN
|
||
|
void
|
||
|
dict_stats_thread_deinit();
|
||
|
/*======================*/
|
||
|
|
||
|
/*****************************************************************//**
|
||
|
This is the thread for background stats gathering. It pops tables, from
|
||
|
the auto recalc list and proceeds them, eventually recalculating their
|
||
|
statistics.
|
||
|
@return this function does not return, it calls os_thread_exit() */
|
||
|
extern "C" UNIV_INTERN
|
||
|
os_thread_ret_t
|
||
|
DECLARE_THREAD(dict_stats_thread)(
|
||
|
/*==============================*/
|
||
|
void* arg); /*!< in: a dummy parameter
|
||
|
required by os_thread_create */
|
||
|
|
||
|
# ifndef UNIV_NONINL
|
||
|
# include "dict0stats_bg.ic"
|
||
|
# endif
|
||
|
|
||
|
#endif /* dict0stats_bg_h */
|