2004-10-23 11:32:52 +04:00
|
|
|
#ifndef INCLUDES_MYSQL_INSTANCE_MANAGER_INSTANCE_H
|
|
|
|
#define INCLUDES_MYSQL_INSTANCE_MANAGER_INSTANCE_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>
|
2006-05-18 18:57:50 +04:00
|
|
|
#include <m_string.h>
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
#include "instance_options.h"
|
2006-05-18 18:57:50 +04:00
|
|
|
#include "priv.h"
|
2004-10-23 11:32:52 +04:00
|
|
|
|
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
|
|
|
|
|
2005-01-25 13:54:56 +03:00
|
|
|
class Instance_map;
|
2006-10-24 18:23:16 +04:00
|
|
|
class Thread_registry;
|
2005-01-25 13:54:56 +03:00
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
2006-05-18 18:57:50 +04:00
|
|
|
Instance_name -- the class represents instance name -- a string of length
|
|
|
|
less than MAX_INSTANCE_NAME_SIZE.
|
|
|
|
|
|
|
|
Generally, this is just a string with self-memory-management and should be
|
|
|
|
eliminated in the future.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class Instance_name
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Instance_name(const LEX_STRING *name);
|
|
|
|
|
|
|
|
public:
|
|
|
|
inline const LEX_STRING *get_str() const
|
|
|
|
{
|
|
|
|
return &str;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline const char *get_c_str() const
|
|
|
|
{
|
|
|
|
return str.str;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline uint get_length() const
|
|
|
|
{
|
|
|
|
return str.length;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
LEX_STRING str;
|
|
|
|
char str_buffer[MAX_INSTANCE_NAME_SIZE];
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
class Instance
|
|
|
|
{
|
2006-05-18 18:57:50 +04:00
|
|
|
public:
|
2006-11-30 12:23:55 +03:00
|
|
|
/* States of an instance. */
|
|
|
|
enum enum_instance_state
|
|
|
|
{
|
|
|
|
STOPPED,
|
|
|
|
NOT_STARTED,
|
|
|
|
STARTING,
|
|
|
|
STARTED,
|
|
|
|
JUST_CRASHED,
|
|
|
|
CRASHED,
|
|
|
|
CRASHED_AND_ABANDONED,
|
|
|
|
STOPPING
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
The constant defines name of the default mysqld-instance ("mysqld").
|
2006-05-18 18:57:50 +04:00
|
|
|
*/
|
|
|
|
static const LEX_STRING DFLT_INSTANCE_NAME;
|
|
|
|
|
|
|
|
public:
|
|
|
|
static bool is_name_valid(const LEX_STRING *name);
|
|
|
|
static bool is_mysqld_compatible_name(const LEX_STRING *name);
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
public:
|
Port cleanups, trivial refactoring and code rearrangements from
Alik's patch for BUG#22306: STOP INSTANCE can not be applied for
instances in Crashed, Failed and Abandoned" to ease review process.
Evaluate global variable linuxthreads before starting threads to avoid
a race.
server-tools/instance-manager/buffer.cc:
Fix spelling.
server-tools/instance-manager/command.h:
Fix spelling.
server-tools/instance-manager/commands.cc:
Fix spelling.
server-tools/instance-manager/commands.h:
Fix spelling, tidy up.
server-tools/instance-manager/guardian.cc:
Cleanup logging, options.get_shutdown_delay() is a method, tidy up.
server-tools/instance-manager/instance.cc:
Rearrange methods to be the same as in Alik's patch, fix spelling errors,
clean up logging texts, port comments from Alik's patch,
implement some basic renames from his patch.
No real changes.
server-tools/instance-manager/instance.h:
Tidy up, renames.
server-tools/instance-manager/instance_map.cc:
Fix spellings, port some refactoring from Alik's patch.
server-tools/instance-manager/instance_map.h:
Cleanup.
server-tools/instance-manager/instance_options.cc:
Cleanup. Implement Instance_options::get_shutdown_delay() and
Instance_options::get_mysqld_port().
server-tools/instance-manager/instance_options.h:
Cleanup.
server-tools/instance-manager/listener.cc:
Cleanup.
server-tools/instance-manager/log.cc:
Fix spelling.
server-tools/instance-manager/manager.cc:
Cleanup.
server-tools/instance-manager/manager.h:
Add getters for Manager members.
server-tools/instance-manager/mysqlmanager.cc:
Evaluate linuxthreads before starting threads to avoid a race.
server-tools/instance-manager/parse_output.cc:
Fix spelling.
server-tools/instance-manager/priv.cc:
Cleanup.
server-tools/instance-manager/priv.h:
Cleanup.
server-tools/instance-manager/user_management_commands.cc:
Fix spelling.
server-tools/instance-manager/user_management_commands.h:
Fix spelling.
server-tools/instance-manager/user_map.cc:
Fix spelling.
2006-11-18 01:34:44 +03:00
|
|
|
Instance();
|
2004-10-23 11:32:52 +04:00
|
|
|
~Instance();
|
2006-11-30 12:23:55 +03:00
|
|
|
|
Port cleanups, trivial refactoring and code rearrangements from
Alik's patch for BUG#22306: STOP INSTANCE can not be applied for
instances in Crashed, Failed and Abandoned" to ease review process.
Evaluate global variable linuxthreads before starting threads to avoid
a race.
server-tools/instance-manager/buffer.cc:
Fix spelling.
server-tools/instance-manager/command.h:
Fix spelling.
server-tools/instance-manager/commands.cc:
Fix spelling.
server-tools/instance-manager/commands.h:
Fix spelling, tidy up.
server-tools/instance-manager/guardian.cc:
Cleanup logging, options.get_shutdown_delay() is a method, tidy up.
server-tools/instance-manager/instance.cc:
Rearrange methods to be the same as in Alik's patch, fix spelling errors,
clean up logging texts, port comments from Alik's patch,
implement some basic renames from his patch.
No real changes.
server-tools/instance-manager/instance.h:
Tidy up, renames.
server-tools/instance-manager/instance_map.cc:
Fix spellings, port some refactoring from Alik's patch.
server-tools/instance-manager/instance_map.h:
Cleanup.
server-tools/instance-manager/instance_options.cc:
Cleanup. Implement Instance_options::get_shutdown_delay() and
Instance_options::get_mysqld_port().
server-tools/instance-manager/instance_options.h:
Cleanup.
server-tools/instance-manager/listener.cc:
Cleanup.
server-tools/instance-manager/log.cc:
Fix spelling.
server-tools/instance-manager/manager.cc:
Cleanup.
server-tools/instance-manager/manager.h:
Add getters for Manager members.
server-tools/instance-manager/mysqlmanager.cc:
Evaluate linuxthreads before starting threads to avoid a race.
server-tools/instance-manager/parse_output.cc:
Fix spelling.
server-tools/instance-manager/priv.cc:
Cleanup.
server-tools/instance-manager/priv.h:
Cleanup.
server-tools/instance-manager/user_management_commands.cc:
Fix spelling.
server-tools/instance-manager/user_management_commands.h:
Fix spelling.
server-tools/instance-manager/user_map.cc:
Fix spelling.
2006-11-18 01:34:44 +03:00
|
|
|
bool init(const LEX_STRING *name_arg);
|
|
|
|
bool complete_initialization();
|
2004-10-23 11:32:52 +04:00
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
public:
|
|
|
|
bool is_active();
|
|
|
|
|
Port cleanups, trivial refactoring and code rearrangements from
Alik's patch for BUG#22306: STOP INSTANCE can not be applied for
instances in Crashed, Failed and Abandoned" to ease review process.
Evaluate global variable linuxthreads before starting threads to avoid
a race.
server-tools/instance-manager/buffer.cc:
Fix spelling.
server-tools/instance-manager/command.h:
Fix spelling.
server-tools/instance-manager/commands.cc:
Fix spelling.
server-tools/instance-manager/commands.h:
Fix spelling, tidy up.
server-tools/instance-manager/guardian.cc:
Cleanup logging, options.get_shutdown_delay() is a method, tidy up.
server-tools/instance-manager/instance.cc:
Rearrange methods to be the same as in Alik's patch, fix spelling errors,
clean up logging texts, port comments from Alik's patch,
implement some basic renames from his patch.
No real changes.
server-tools/instance-manager/instance.h:
Tidy up, renames.
server-tools/instance-manager/instance_map.cc:
Fix spellings, port some refactoring from Alik's patch.
server-tools/instance-manager/instance_map.h:
Cleanup.
server-tools/instance-manager/instance_options.cc:
Cleanup. Implement Instance_options::get_shutdown_delay() and
Instance_options::get_mysqld_port().
server-tools/instance-manager/instance_options.h:
Cleanup.
server-tools/instance-manager/listener.cc:
Cleanup.
server-tools/instance-manager/log.cc:
Fix spelling.
server-tools/instance-manager/manager.cc:
Cleanup.
server-tools/instance-manager/manager.h:
Add getters for Manager members.
server-tools/instance-manager/mysqlmanager.cc:
Evaluate linuxthreads before starting threads to avoid a race.
server-tools/instance-manager/parse_output.cc:
Fix spelling.
server-tools/instance-manager/priv.cc:
Cleanup.
server-tools/instance-manager/priv.h:
Cleanup.
server-tools/instance-manager/user_management_commands.cc:
Fix spelling.
server-tools/instance-manager/user_management_commands.h:
Fix spelling.
server-tools/instance-manager/user_map.cc:
Fix spelling.
2006-11-18 01:34:44 +03:00
|
|
|
bool is_mysqld_running();
|
2006-11-30 12:23:55 +03:00
|
|
|
|
|
|
|
bool start_mysqld();
|
|
|
|
bool stop_mysqld();
|
Port cleanups, trivial refactoring and code rearrangements from
Alik's patch for BUG#22306: STOP INSTANCE can not be applied for
instances in Crashed, Failed and Abandoned" to ease review process.
Evaluate global variable linuxthreads before starting threads to avoid
a race.
server-tools/instance-manager/buffer.cc:
Fix spelling.
server-tools/instance-manager/command.h:
Fix spelling.
server-tools/instance-manager/commands.cc:
Fix spelling.
server-tools/instance-manager/commands.h:
Fix spelling, tidy up.
server-tools/instance-manager/guardian.cc:
Cleanup logging, options.get_shutdown_delay() is a method, tidy up.
server-tools/instance-manager/instance.cc:
Rearrange methods to be the same as in Alik's patch, fix spelling errors,
clean up logging texts, port comments from Alik's patch,
implement some basic renames from his patch.
No real changes.
server-tools/instance-manager/instance.h:
Tidy up, renames.
server-tools/instance-manager/instance_map.cc:
Fix spellings, port some refactoring from Alik's patch.
server-tools/instance-manager/instance_map.h:
Cleanup.
server-tools/instance-manager/instance_options.cc:
Cleanup. Implement Instance_options::get_shutdown_delay() and
Instance_options::get_mysqld_port().
server-tools/instance-manager/instance_options.h:
Cleanup.
server-tools/instance-manager/listener.cc:
Cleanup.
server-tools/instance-manager/log.cc:
Fix spelling.
server-tools/instance-manager/manager.cc:
Cleanup.
server-tools/instance-manager/manager.h:
Add getters for Manager members.
server-tools/instance-manager/mysqlmanager.cc:
Evaluate linuxthreads before starting threads to avoid a race.
server-tools/instance-manager/parse_output.cc:
Fix spelling.
server-tools/instance-manager/priv.cc:
Cleanup.
server-tools/instance-manager/priv.h:
Cleanup.
server-tools/instance-manager/user_management_commands.cc:
Fix spelling.
server-tools/instance-manager/user_management_commands.h:
Fix spelling.
server-tools/instance-manager/user_map.cc:
Fix spelling.
2006-11-18 01:34:44 +03:00
|
|
|
void kill_mysqld(int signo);
|
2004-10-23 11:32:52 +04:00
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
void lock();
|
|
|
|
void unlock();
|
|
|
|
|
|
|
|
const char *get_state_name();
|
|
|
|
|
|
|
|
void reset_stat();
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
2006-05-18 18:57:50 +04:00
|
|
|
The operation is intended to check if the instance is mysqld-compatible
|
|
|
|
or not.
|
|
|
|
*/
|
|
|
|
inline bool is_mysqld_compatible() const;
|
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
2006-05-18 18:57:50 +04:00
|
|
|
The operation is intended to check if the instance is configured properly
|
|
|
|
or not. Misconfigured instances are not managed.
|
|
|
|
*/
|
|
|
|
inline bool is_configured() const;
|
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
|
|
|
The operation returns TRUE if the instance is guarded and FALSE otherwise.
|
|
|
|
*/
|
|
|
|
inline bool is_guarded() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
The operation returns name of the instance.
|
|
|
|
*/
|
2006-05-18 18:57:50 +04:00
|
|
|
inline const LEX_STRING *get_name() const;
|
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
|
|
|
The operation returns the current state of the instance.
|
|
|
|
|
|
|
|
NOTE: At the moment should be used only for guarded instances.
|
|
|
|
*/
|
|
|
|
inline enum_instance_state get_state() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
The operation changes the state of the instance.
|
|
|
|
|
|
|
|
NOTE: At the moment should be used only for guarded instances.
|
|
|
|
TODO: Make private.
|
|
|
|
*/
|
|
|
|
inline void set_state(enum_instance_state new_state);
|
|
|
|
|
|
|
|
/**
|
|
|
|
The operation returns crashed flag.
|
|
|
|
*/
|
|
|
|
inline bool is_crashed();
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
public:
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
|
|
|
This attributes contains instance options.
|
|
|
|
|
|
|
|
TODO: Make private.
|
|
|
|
*/
|
2004-10-23 11:32:52 +04:00
|
|
|
Instance_options options;
|
|
|
|
|
|
|
|
private:
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
|
|
|
monitoring_thread_active is TRUE if there is a thread that monitors the
|
|
|
|
corresponding mysqld-process.
|
|
|
|
*/
|
|
|
|
bool monitoring_thread_active;
|
|
|
|
|
|
|
|
/**
|
|
|
|
crashed is TRUE when corresponding mysqld-process has been died after
|
|
|
|
start.
|
|
|
|
*/
|
2006-05-18 18:57:50 +04:00
|
|
|
bool crashed;
|
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
/**
|
|
|
|
configured is TRUE when the instance is configured and FALSE otherwise.
|
2006-05-18 18:57:50 +04:00
|
|
|
Misconfigured instances are not managed.
|
|
|
|
*/
|
|
|
|
bool configured;
|
|
|
|
|
|
|
|
/*
|
2006-11-30 12:23:55 +03:00
|
|
|
mysqld_compatible specifies whether the instance is mysqld-compatible
|
|
|
|
or not. Mysqld-compatible instances can contain only mysqld-specific
|
|
|
|
options. At the moment an instance is mysqld-compatible if its name is
|
|
|
|
"mysqld".
|
2006-05-18 18:57:50 +04:00
|
|
|
|
|
|
|
The idea is that [mysqld] section should contain only mysqld-specific
|
|
|
|
options (no Instance Manager-specific options) to be readable by mysqld
|
|
|
|
program.
|
|
|
|
*/
|
|
|
|
bool mysqld_compatible;
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
/*
|
2006-11-30 12:23:55 +03:00
|
|
|
Mutex protecting the instance.
|
2004-10-23 11:32:52 +04:00
|
|
|
*/
|
|
|
|
pthread_mutex_t LOCK_instance;
|
2005-07-20 10:55:40 -05:00
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
private:
|
|
|
|
/* Guarded-instance attributes. */
|
|
|
|
|
|
|
|
/* state of an instance (i.e. STARTED, CRASHED, etc.) */
|
|
|
|
enum_instance_state state;
|
|
|
|
|
|
|
|
public:
|
|
|
|
/* the amount of attemts to restart instance (cleaned up at success) */
|
|
|
|
int restart_counter;
|
|
|
|
|
|
|
|
/* triggered at a crash */
|
|
|
|
time_t crash_moment;
|
|
|
|
|
|
|
|
/* General time field. Used to provide timeouts (at shutdown and restart) */
|
|
|
|
time_t last_checked;
|
|
|
|
|
|
|
|
private:
|
|
|
|
static const char *get_instance_state_name(enum_instance_state state);
|
|
|
|
|
|
|
|
private:
|
|
|
|
void remove_pid();
|
|
|
|
|
|
|
|
bool wait_for_stop();
|
|
|
|
|
|
|
|
private:
|
|
|
|
friend class Instance_monitor;
|
2004-10-23 11:32:52 +04:00
|
|
|
};
|
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
|
|
|
|
inline bool Instance::is_mysqld_compatible() const
|
|
|
|
{
|
|
|
|
return mysqld_compatible;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline bool Instance::is_configured() const
|
|
|
|
{
|
|
|
|
return configured;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
inline bool Instance::is_guarded() const
|
|
|
|
{
|
|
|
|
return !options.nonguarded;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
inline const LEX_STRING *Instance::get_name() const
|
|
|
|
{
|
|
|
|
return &options.instance_name;
|
|
|
|
}
|
|
|
|
|
2006-11-30 12:23:55 +03:00
|
|
|
|
|
|
|
inline Instance::enum_instance_state Instance::get_state() const
|
|
|
|
{
|
|
|
|
return state;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline void Instance::set_state(enum_instance_state new_state)
|
|
|
|
{
|
|
|
|
state= new_state;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline bool Instance::is_crashed()
|
|
|
|
{
|
|
|
|
return crashed;
|
|
|
|
}
|
|
|
|
|
2004-10-23 11:32:52 +04:00
|
|
|
#endif /* INCLUDES_MYSQL_INSTANCE_MANAGER_INSTANCE_H */
|