2004-10-23 11:32:52 +04:00
|
|
|
#ifndef INCLUDES_MYSQL_INSTANCE_MANAGER_INSTANCE_MAP_H
|
|
|
|
#define INCLUDES_MYSQL_INSTANCE_MANAGER_INSTANCE_MAP_H
|
|
|
|
/* Copyright (C) 2004 MySQL 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
|
2006-12-23 20:17:15 +01:00
|
|
|
the Free Software Foundation; version 2 of the License.
|
2004-10-23 11:32:52 +04:00
|
|
|
|
|
|
|
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 */
|
|
|
|
|
|
|
|
#include <my_global.h>
|
|
|
|
#include <my_sys.h>
|
2006-05-19 04:51:23 +04:00
|
|
|
#include <m_string.h>
|
2004-10-23 11:32:52 +04:00
|
|
|
#include <hash.h>
|
|
|
|
|
2005-09-23 21:28:56 +03:00
|
|
|
#if defined(__GNUC__) && defined(USE_PRAGMA_INTERFACE)
|
2004-10-23 11:32:52 +04:00
|
|
|
#pragma interface
|
|
|
|
#endif
|
|
|
|
|
2006-11-16 23:36:20 +03:00
|
|
|
class Guardian;
|
2004-10-23 11:32:52 +04:00
|
|
|
class Instance;
|
2006-05-18 18:57:50 +04:00
|
|
|
class Named_value_arr;
|
2006-10-24 18:23:16 +04:00
|
|
|
class Thread_registry;
|
2006-05-18 18:57:50 +04:00
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
extern int load_all_groups(char ***groups, const char *filename);
|
|
|
|
extern void free_groups(char **groups);
|
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
extern int create_instance_in_file(const LEX_STRING *instance_name,
|
|
|
|
const Named_value_arr *options);
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
Instance_map - stores all existing instances
|
|
|
|
*/
|
|
|
|
|
|
|
|
class Instance_map
|
|
|
|
{
|
2004-10-27 10:21:48 +04:00
|
|
|
public:
|
|
|
|
/* Instance_map iterator */
|
|
|
|
class Iterator
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
uint current_instance;
|
|
|
|
Instance_map *instance_map;
|
|
|
|
public:
|
|
|
|
Iterator(Instance_map *instance_map_arg) :
|
2004-11-02 10:11:03 +03:00
|
|
|
current_instance(0), instance_map(instance_map_arg)
|
2004-10-27 10:21:48 +04:00
|
|
|
{}
|
|
|
|
|
|
|
|
void go_to_first();
|
|
|
|
Instance *next();
|
|
|
|
};
|
2004-12-12 20:59:15 +03:00
|
|
|
friend class Iterator;
|
2004-10-23 11:32:52 +04:00
|
|
|
public:
|
2006-05-18 18:57:50 +04:00
|
|
|
/*
|
|
|
|
Return a pointer to the instance or NULL, if there is no such instance.
|
|
|
|
MT-NOTE: must be called under acquired lock.
|
|
|
|
*/
|
|
|
|
Instance *find(const LEX_STRING *name);
|
2004-10-23 11:32:52 +04:00
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
/* Clear the configuration cache and reload the configuration file. */
|
2004-10-23 11:32:52 +04:00
|
|
|
int flush_instances();
|
2006-05-18 18:57:50 +04:00
|
|
|
|
|
|
|
/* The operation is used to check if there is an active instance or not. */
|
|
|
|
bool is_there_active_instance();
|
|
|
|
|
2005-08-05 14:35:30 +04:00
|
|
|
void lock();
|
|
|
|
void unlock();
|
2006-05-18 18:57:50 +04:00
|
|
|
|
2006-11-18 01:34:44 +03:00
|
|
|
bool init();
|
2006-05-18 18:57:50 +04:00
|
|
|
|
2006-02-21 15:57:56 +03:00
|
|
|
/*
|
|
|
|
Process a given option and assign it to appropricate instance. This is
|
|
|
|
required for the option handler, passed to my_search_option_files().
|
|
|
|
*/
|
2006-05-18 18:57:50 +04:00
|
|
|
int process_one_option(const LEX_STRING *group, const char *option);
|
|
|
|
|
|
|
|
/*
|
|
|
|
Add an instance into the internal hash.
|
|
|
|
|
|
|
|
MT-NOTE: the operation must be called under acquired lock.
|
|
|
|
*/
|
|
|
|
int add_instance(Instance *instance);
|
|
|
|
|
|
|
|
/*
|
|
|
|
Remove instance from the internal hash.
|
|
|
|
|
|
|
|
MT-NOTE: the operation must be called under acquired lock.
|
|
|
|
*/
|
|
|
|
int remove_instance(Instance *instance);
|
|
|
|
|
|
|
|
/*
|
|
|
|
Create a new instance and register it in the internal hash.
|
|
|
|
|
|
|
|
MT-NOTE: the operation must be called under acquired lock.
|
|
|
|
*/
|
|
|
|
int create_instance(const LEX_STRING *instance_name,
|
|
|
|
const Named_value_arr *options);
|
2004-10-23 11:32:52 +04:00
|
|
|
|
2006-11-18 01:34:44 +03:00
|
|
|
Instance_map();
|
2004-10-23 11:32:52 +04:00
|
|
|
~Instance_map();
|
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
/*
|
|
|
|
Retrieve client state name of the given instance.
|
|
|
|
|
|
|
|
MT-NOTE: the options must be called under acquired locks of the following
|
|
|
|
objects:
|
|
|
|
- Instance_map;
|
2006-11-16 23:36:20 +03:00
|
|
|
- Guardian;
|
2006-05-18 18:57:50 +04:00
|
|
|
*/
|
|
|
|
const char *get_instance_state_name(Instance *instance);
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
public:
|
|
|
|
const char *mysqld_path;
|
2006-11-16 23:36:20 +03:00
|
|
|
Guardian *guardian;
|
2004-10-23 11:32:52 +04:00
|
|
|
|
2006-02-21 15:57:56 +03:00
|
|
|
private:
|
|
|
|
/* loads options from config files */
|
|
|
|
int load();
|
|
|
|
/* inits instances argv's after all options have been loaded */
|
2006-05-18 18:57:50 +04:00
|
|
|
bool complete_initialization();
|
2004-10-23 11:32:52 +04:00
|
|
|
private:
|
|
|
|
enum { START_HASH_SIZE = 16 };
|
|
|
|
pthread_mutex_t LOCK_instance_map;
|
|
|
|
HASH hash;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* INCLUDES_MYSQL_INSTANCE_MANAGER_INSTANCE_MAP_H */
|