mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Intermediate commit - just to make new files visible to bk in the new
tree server-tools/instance-manager/Makefile.am: Fixed IM linking to avoid using both mysys and libmysql as the define the same symbols and therefore conflict server-tools/instance-manager/listener.cc: Added ability to listen network ports server-tools/instance-manager/listener.h: Various additions to the Listener_thread_args server-tools/instance-manager/log.cc: merge server-tools/instance-manager/log.h: merge server-tools/instance-manager/manager.cc: Fixes and additions to enable guardian functionality server-tools/instance-manager/manager.h: Changed manager() signature server-tools/instance-manager/mysqlmanager.cc: Various fixes server-tools/instance-manager/options.cc: Added handling of default values for new options in the Options struct. (such as default_user, default_password, monitoring_interval e.t.c) server-tools/instance-manager/options.h: Added new options to the Options struct sql/net_serv.cc: Added MYSQL_INSTANCE_MANAGER defines to enable alarm handling in the IM server-tools/instance-manager/buffer.cc: Simple implementation of variable-length buffer server-tools/instance-manager/command.cc: Abstract command. All commands are derived from Command class server-tools/instance-manager/commands.h: Interfaces for all commands we have server-tools/instance-manager/factory.cc: Commands factory. This class hides command instantiation. The idea is to handle various protocols this way. (different commands for different protocols server-tools/instance-manager/guardian.cc: Guardian thread implementation (monitor and restart instances in case of a failure server-tools/instance-manager/guardian.h: Guardian_thread and Guardian_thread_args class interface. The Guardian_thread is responsible for monitoring and restarting instances server-tools/instance-manager/instance.cc: Instance class contains methods and data to manage a single instance server-tools/instance-manager/instance.h: This file contains class an instance class interface. The class is responsible for starting/stopping an instance server-tools/instance-manager/instance_map.cc: The instance repository. This class is also responsible for initialization of Instance class objects. server-tools/instance-manager/instance_options.cc: The Instance_options class contains all methods to get and handle options of an instance server-tools/instance-manager/mysql_connection.cc: The class responsible for handling MySQL client/server protocol connections server-tools/instance-manager/mysql_manager_error.h: The list of Instance Manger-specific errors server-tools/instance-manager/parse.cc: Simple query parser server-tools/instance-manager/parse.h: Parser interface server-tools/instance-manager/protocol.cc: Here implemented functions used to handle mysql client/server protocol server-tools/instance-manager/protocol.h: Interface for MySQL client/server protocol server-tools/instance-manager/thread_registry.cc: Thread registry stores information about every thread. It's main function is to provide graceful shutdown for all threads. server-tools/instance-manager/user_map.h: User map contains hash with user names and passwords
This commit is contained in:
152
server-tools/instance-manager/instance.cc
Normal file
152
server-tools/instance-manager/instance.cc
Normal file
@ -0,0 +1,152 @@
|
||||
/* 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
|
||||
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 */
|
||||
|
||||
#ifdef __GNUC__
|
||||
#pragma implementation
|
||||
#endif
|
||||
|
||||
#include "instance.h"
|
||||
#include "mysql_manager_error.h"
|
||||
#include <my_sys.h>
|
||||
#include <signal.h>
|
||||
#include <m_string.h>
|
||||
|
||||
|
||||
/*
|
||||
The method starts an instance.
|
||||
|
||||
SYNOPSYS
|
||||
start()
|
||||
|
||||
RETURN
|
||||
0 ok
|
||||
ER_CANNOT_START_INSTANCE Cannot start instance
|
||||
ER_INSTANCE_ALREADY_STARTED The instance on the specified port/socket
|
||||
is already started
|
||||
*/
|
||||
|
||||
int Instance::start()
|
||||
{
|
||||
|
||||
if (!is_running())
|
||||
{
|
||||
switch (fork()) {
|
||||
case 0:
|
||||
if (fork()) /* zombie protection */
|
||||
exit(0); /* parent goes bye-bye */
|
||||
else
|
||||
{
|
||||
execv(options.mysqld_path, options.argv);
|
||||
exit(1);
|
||||
}
|
||||
case -1:
|
||||
return ER_CANNOT_START_INSTANCE;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
/* the instance is started already */
|
||||
return ER_INSTANCE_ALREADY_STARTED;
|
||||
}
|
||||
|
||||
int Instance::cleanup()
|
||||
{
|
||||
/*
|
||||
We cannot close connection in destructor, as mysql_close needs alarm
|
||||
services which are definitely unavailaible at the time of destructor
|
||||
call.
|
||||
*/
|
||||
if (is_connected)
|
||||
mysql_close(&mysql);
|
||||
return 0;
|
||||
}
|
||||
|
||||
Instance::~Instance()
|
||||
{
|
||||
pthread_mutex_destroy(&LOCK_instance);
|
||||
}
|
||||
|
||||
bool Instance::is_running()
|
||||
{
|
||||
pthread_mutex_lock(&LOCK_instance);
|
||||
if (!is_connected)
|
||||
{
|
||||
mysql_init(&mysql);
|
||||
if (mysql_real_connect(&mysql, LOCAL_HOST, options.mysqld_user,
|
||||
options.mysqld_password,
|
||||
NullS, atoi(strchr(options.mysqld_port, '=') + 1),
|
||||
strchr(options.mysqld_socket, '=') + 1, 0))
|
||||
{
|
||||
is_connected= TRUE;
|
||||
pthread_mutex_unlock(&LOCK_instance);
|
||||
return TRUE;
|
||||
}
|
||||
mysql_close(&mysql);
|
||||
pthread_mutex_unlock(&LOCK_instance);
|
||||
return FALSE;
|
||||
}
|
||||
else if (!mysql_ping(&mysql))
|
||||
{
|
||||
pthread_mutex_unlock(&LOCK_instance);
|
||||
return TRUE;
|
||||
}
|
||||
pthread_mutex_unlock(&LOCK_instance);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
Stop an instance.
|
||||
|
||||
SYNOPSYS
|
||||
stop()
|
||||
|
||||
RETURN:
|
||||
0 ok
|
||||
ER_INSTANCE_IS_NOT_STARTED Looks like the instance it is not started
|
||||
ER_STOP_INSTANCE mysql_shutdown reported an error
|
||||
*/
|
||||
|
||||
int Instance::stop()
|
||||
{
|
||||
if (is_running())
|
||||
{
|
||||
if (mysql_shutdown(&mysql, SHUTDOWN_DEFAULT))
|
||||
goto err;
|
||||
|
||||
mysql_close(&mysql);
|
||||
is_connected= FALSE;
|
||||
return 0;
|
||||
}
|
||||
|
||||
return ER_INSTANCE_IS_NOT_STARTED;
|
||||
err:
|
||||
return ER_STOP_INSTANCE;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
We execute this function to initialize instance parameters.
|
||||
Return value: 0 - ok. 1 - unable to init DYNAMIC_ARRAY.
|
||||
*/
|
||||
|
||||
int Instance::init(const char *name_arg)
|
||||
{
|
||||
pthread_mutex_init(&LOCK_instance, 0);
|
||||
|
||||
return options.init(name_arg);
|
||||
}
|
Reference in New Issue
Block a user