2011-01-14 09:40:18 +01:00
|
|
|
/*
|
2011-02-17 10:48:44 +01:00
|
|
|
Copyright (C) 2010, 2011 Oracle and/or its affiliates. All rights reserved.
|
2011-01-14 09:40:18 +01:00
|
|
|
|
|
|
|
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef THREAD_POOL_PRIV_INCLUDED
|
|
|
|
#define THREAD_POOL_PRIV_INCLUDED
|
|
|
|
|
2011-02-10 16:19:38 +01:00
|
|
|
/*
|
2011-02-17 10:48:44 +01:00
|
|
|
The thread pool requires access to some MySQL server error codes, this is
|
|
|
|
accessed from mysqld_error.h.
|
2011-02-17 10:57:57 +01:00
|
|
|
We need access to the struct that defines the thread pool plugin interface
|
|
|
|
which is accessed through scheduler.h.
|
2011-02-17 10:48:44 +01:00
|
|
|
All accesses to THD variables and functions are defined in this header file.
|
2011-02-10 16:19:38 +01:00
|
|
|
A thread pool can also use DEBUG_SYNC and must thus include
|
|
|
|
debug_sync.h
|
|
|
|
To handle definitions of Information Schema plugins it is also required
|
|
|
|
to include sql_profile.h and table.h.
|
|
|
|
*/
|
2011-02-17 10:48:44 +01:00
|
|
|
#include <mysqld_error.h> /* To get ER_ERROR_ON_READ */
|
2011-02-10 16:19:38 +01:00
|
|
|
#define MYSQL_SERVER 1
|
2011-02-17 10:50:51 +01:00
|
|
|
#include <scheduler.h>
|
2011-02-10 16:19:38 +01:00
|
|
|
#include <debug_sync.h>
|
|
|
|
#include <sql_profile.h>
|
|
|
|
#include <table.h>
|
|
|
|
|
2011-02-10 19:24:31 +01:00
|
|
|
/* Needed to get access to scheduler variables */
|
2011-02-16 19:30:02 +01:00
|
|
|
void* thd_get_scheduler_data(THD *thd);
|
|
|
|
void thd_set_scheduler_data(THD *thd, void *data);
|
2011-02-10 19:24:31 +01:00
|
|
|
PSI_thread* thd_get_psi(THD *thd);
|
2011-02-16 19:30:02 +01:00
|
|
|
void thd_set_psi(THD *thd, PSI_thread *psi);
|
|
|
|
|
|
|
|
/* Interface to THD variables and functions */
|
|
|
|
void thd_set_killed(THD *thd);
|
|
|
|
void thd_clear_errors(THD *thd);
|
|
|
|
void thd_set_thread_stack(THD *thd, char *stack_start);
|
|
|
|
void thd_lock_connection_data(THD *thd);
|
|
|
|
void thd_unlock_connection_data(THD *thd);
|
|
|
|
void thd_close_connection(THD *thd);
|
|
|
|
THD *thd_get_current_thd();
|
|
|
|
void thd_new_connection_setup(THD *thd, char *stack_start);
|
|
|
|
void thd_lock_data(THD *thd);
|
|
|
|
void thd_unlock_data(THD *thd);
|
|
|
|
bool thd_is_transaction_active(THD *thd);
|
|
|
|
int thd_connection_has_data(THD *thd);
|
|
|
|
void thd_set_net_read_write(THD *thd, uint val);
|
|
|
|
void thd_set_mysys_var(THD *thd, st_my_thread_var *mysys_var);
|
2011-02-16 20:38:35 +01:00
|
|
|
my_socket thd_get_fd(THD *thd);
|
2011-02-10 19:24:31 +01:00
|
|
|
|
2011-02-17 10:48:44 +01:00
|
|
|
/* Print to the MySQL error log */
|
|
|
|
void sql_print_error(const char *format, ...);
|
|
|
|
|
|
|
|
/* Store a table record */
|
|
|
|
bool schema_table_store_record(THD *thd, TABLE *table);
|
|
|
|
|
2011-01-14 09:40:18 +01:00
|
|
|
/*
|
2011-02-17 10:48:44 +01:00
|
|
|
The thread pool must be able to execute statements using the connection
|
2011-01-14 09:40:18 +01:00
|
|
|
state in THD object. This is the main objective of the thread pool to
|
|
|
|
schedule the start of these commands.
|
|
|
|
*/
|
|
|
|
bool do_command(THD *thd);
|
|
|
|
|
|
|
|
/*
|
|
|
|
The thread pool requires an interface to the connection logic in the
|
|
|
|
MySQL Server since the thread pool will maintain the event logic on
|
|
|
|
the TCP connection of the MySQL Server. Thus new connections, dropped
|
|
|
|
connections will be discovered by the thread pool and it needs to
|
|
|
|
ensure that the proper MySQL Server logic attached to these events is
|
|
|
|
executed.
|
|
|
|
*/
|
2011-02-17 10:48:44 +01:00
|
|
|
/* Initialise a new connection handler thread */
|
|
|
|
bool init_new_connection_handler_thread();
|
|
|
|
/* Set up connection thread before use as execution thread */
|
|
|
|
bool setup_connection_thread_globals(THD *thd);
|
|
|
|
/* Prepare connection as part of connection set-up */
|
2011-02-10 18:41:02 +01:00
|
|
|
bool thd_prepare_connection(THD *thd);
|
2011-02-17 10:48:44 +01:00
|
|
|
/* Release auditing before executing statement */
|
|
|
|
void mysql_audit_release(THD *thd);
|
|
|
|
/* Check if connection is still alive */
|
2011-02-10 18:41:02 +01:00
|
|
|
bool thd_is_connection_alive(THD *thd);
|
2011-02-17 10:48:44 +01:00
|
|
|
/* Close connection with possible error code */
|
|
|
|
void close_connection(THD *thd, uint errcode);
|
|
|
|
/* End the connection before closing it */
|
2011-01-14 09:40:18 +01:00
|
|
|
void end_connection(THD *thd);
|
2011-02-17 10:48:44 +01:00
|
|
|
/* Destroy THD object */
|
|
|
|
void unlink_thd(THD *thd);
|
2011-01-14 09:40:18 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
thread_created is maintained by thread pool when activated since
|
|
|
|
user threads are created by the thread pool (and also special
|
2011-02-16 20:38:35 +01:00
|
|
|
threads to maintain the thread pool). This is done through
|
|
|
|
inc_thread_created.
|
2011-02-17 10:48:44 +01:00
|
|
|
|
2011-01-14 09:40:18 +01:00
|
|
|
max_connections is needed to calculate the maximum number of threads
|
2011-02-16 20:38:35 +01:00
|
|
|
that is allowed to be started by the thread pool. The method
|
|
|
|
get_max_connections() gets reference to this variable.
|
2011-02-17 10:48:44 +01:00
|
|
|
|
2011-02-16 20:38:35 +01:00
|
|
|
connection_attrib is the thread attributes for connection threads,
|
|
|
|
the method get_connection_attrib provides a reference to these
|
|
|
|
attributes.
|
2011-01-14 09:40:18 +01:00
|
|
|
*/
|
2011-02-16 20:38:35 +01:00
|
|
|
void inc_thread_created(void);
|
|
|
|
ulong get_max_connections(void);
|
2011-02-17 10:48:44 +01:00
|
|
|
pthread_attr_t *get_connection_attrib(void);
|
2011-01-14 09:40:18 +01:00
|
|
|
#endif
|