summaryrefslogtreecommitdiff
path: root/server-tools/instance-manager/mysqlmanager.cc
diff options
context:
space:
mode:
authorunknown <anozdrin@mysql.com>2006-05-22 14:22:58 +0400
committerunknown <anozdrin@mysql.com>2006-05-22 14:22:58 +0400
commit089595c55fd01821985864c74cd4dc9945938ece (patch)
treed756402e41acccf5656b880df10ab31c4e9a8ca5 /server-tools/instance-manager/mysqlmanager.cc
parent57b60b14ab6f7222e380303feecbd3616b1a4389 (diff)
parent0276916b155e8230e17285dec3cd78206e180c80 (diff)
downloadmariadb-git-089595c55fd01821985864c74cd4dc9945938ece.tar.gz
Merge bk-internal.mysql.com:/home/bk/mysql-5.1-new
into mysql.com:/mnt/raid/MySQL/devel/5.1-rt-wl3158-merged BitKeeper/deleted/.del-im_options_set.result~59278f56be61d921: Auto merged include/my_sys.h: Auto merged mysql-test/mysql-test-run.pl: Auto merged BitKeeper/deleted/.del-im_options_unset.result~20a4790cd3c70a4f: Auto merged mysql-test/r/im_daemon_life_cycle.result: Auto merged mysql-test/r/im_life_cycle.result: Auto merged server-tools/instance-manager/Makefile.am: Auto merged server-tools/instance-manager/mysqlmanager.cc: Auto merged sql/sp.cc: Auto merged sql/sp_head.cc: Auto merged sql/structs.h: Auto merged mysql-test/r/im_utils.result: Auto merged server-tools/instance-manager/instance_options.cc: Manually merged. server-tools/instance-manager/instance_options.h: Manually merged. server-tools/instance-manager/manager.cc: Manually merged. server-tools/instance-manager/manager.h: Manually merged. server-tools/instance-manager/options.cc: Manually merged. server-tools/instance-manager/options.h: Manually merged.
Diffstat (limited to 'server-tools/instance-manager/mysqlmanager.cc')
-rw-r--r--server-tools/instance-manager/mysqlmanager.cc80
1 files changed, 52 insertions, 28 deletions
diff --git a/server-tools/instance-manager/mysqlmanager.cc b/server-tools/instance-manager/mysqlmanager.cc
index ef714099de7..7dac7bcc994 100644
--- a/server-tools/instance-manager/mysqlmanager.cc
+++ b/server-tools/instance-manager/mysqlmanager.cc
@@ -15,25 +15,30 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#include <my_global.h>
-#include "manager.h"
-
-#include "options.h"
-#include "log.h"
-
#include <my_sys.h>
+
#include <string.h>
#include <signal.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+
#ifndef __WIN__
#include <pwd.h>
#include <grp.h>
#include <sys/wait.h>
#endif
-#include <sys/types.h>
-#include <sys/stat.h>
+
+#include "log.h"
+#include "manager.h"
+#include "options.h"
+#include "user_management_commands.h"
+
#ifdef __WIN__
-#include "windowsservice.h"
+#include "IMService.h"
+#include "WindowsService.h"
#endif
+
/*
Few notes about Instance Manager architecture:
Instance Manager consisits of two processes: the angel process, and the
@@ -59,13 +64,12 @@
*/
static void init_environment(char *progname);
+
#ifndef __WIN__
static void daemonize(const char *log_file_name);
-static void angel(const Options &options);
+static void angel();
static struct passwd *check_user(const char *user);
static int set_user(const char *user, struct passwd *user_info);
-#else
-int HandleServiceOptions(Options options);
#endif
@@ -81,41 +85,61 @@ int main(int argc, char *argv[])
{
int return_value= 1;
init_environment(argv[0]);
- Options options;
- if (options.load(argc, argv))
- goto err;
+ if ((return_value= Options::load(argc, argv)))
+ goto main_end;
+
+ if (Options::User_management::cmd)
+ {
+ return_value= Options::User_management::cmd->execute();
+
+ goto main_end;
+ }
#ifndef __WIN__
+
struct passwd *user_info;
- if ((user_info= check_user(options.user)))
+ if ((user_info= check_user(Options::Daemon::user)))
{
- if (set_user(options.user, user_info))
- goto err;
+ if (set_user(Options::Daemon::user, user_info))
+ {
+ return_value= 1;
+ goto main_end;
+ }
}
- if (options.run_as_service)
+ if (Options::Daemon::run_as_service)
{
/* forks, and returns only in child */
- daemonize(options.log_file_name);
+ daemonize(Options::Daemon::log_file_name);
/* forks again, and returns only in child: parent becomes angel */
- angel(options);
+ angel();
}
+
+ manager();
+
#else
- if (!options.stand_alone)
+
+ if (!Options::Service::stand_alone)
{
- if (HandleServiceOptions(options))
- goto err;
+ if (HandleServiceOptions())
+ {
+ return_value= 1;
+ goto main_end;
+ }
}
else
+ {
+ manager();
+ }
+
#endif
- manager(options);
return_value= 0;
-err:
- options.cleanup();
+main_end:
+ Options::cleanup();
my_end(0);
return return_value;
}
@@ -200,7 +224,7 @@ static void init_environment(char *progname)
MY_INIT(progname);
log_init();
umask(0117);
- srand(time(0));
+ srand((unsigned int) time(0));
}
@@ -298,7 +322,7 @@ void terminate(int signo)
Angel process will exit silently if mysqlmanager exits normally.
*/
-static void angel(const Options &options)
+static void angel()
{
/* install signal handlers */
sigset_t zeromask; // to sigsuspend in parent