summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--server-tools/instance-manager/angel.cc13
-rw-r--r--server-tools/instance-manager/manager.cc78
-rw-r--r--server-tools/instance-manager/manager.h1
-rw-r--r--server-tools/instance-manager/mysqlmanager.cc6
4 files changed, 59 insertions, 39 deletions
diff --git a/server-tools/instance-manager/angel.cc b/server-tools/instance-manager/angel.cc
index 37bbeaa8ce8..09d675b291d 100644
--- a/server-tools/instance-manager/angel.cc
+++ b/server-tools/instance-manager/angel.cc
@@ -17,19 +17,16 @@
#include "angel.h"
-#include <signal.h>
-#include <string.h>
-
-#include <sys/stat.h>
-#include <sys/types.h>
#include <sys/wait.h>
-
/*
- Include my_global.h right after system includes so that we can change
- system defines if needed.
+ sys/wait.h is needed for waitpid(). Unfortunately, there is no MySQL
+ include file, that can serve for this. Include it before MySQL system
+ headers so that we can change system defines if needed.
*/
#include "my_global.h"
+#include "my_alarm.h"
+#include "my_sys.h"
/* Include other IM files. */
diff --git a/server-tools/instance-manager/manager.cc b/server-tools/instance-manager/manager.cc
index 8c4c29d50cf..48dfa4c3571 100644
--- a/server-tools/instance-manager/manager.cc
+++ b/server-tools/instance-manager/manager.cc
@@ -185,6 +185,53 @@ void Manager::stop_all_threads()
/**
+ Initialize user map and load password file.
+
+ SYNOPSIS
+ init_user_map()
+
+ RETURN
+ FALSE on success
+ TRUE on failure
+*/
+
+bool Manager::init_user_map(User_map *user_map)
+{
+ int err_code;
+ const char *err_msg;
+
+ if (user_map->init())
+ {
+ log_error("Manager: can not initialize user list: out of memory.");
+ return TRUE;
+ }
+
+ err_code= user_map->load(Options::Main::password_file_name, &err_msg);
+
+ if (!err_code)
+ return FALSE;
+
+ if (err_code == ERR_PASSWORD_FILE_DOES_NOT_EXIST &&
+ Options::Main::mysqld_safe_compatible)
+ {
+ /*
+ The password file does not exist, but we are running in
+ mysqld_safe-compatible mode. Continue, but complain in log.
+ */
+
+ log_info("Warning: password file does not exist, "
+ "nobody will be able to connect to Instance Manager.");
+
+ return FALSE;
+ }
+
+ log_error("Manager: %s.", (const char *) err_msg);
+
+ return TRUE;
+}
+
+
+/**
Main manager function.
SYNOPSIS
@@ -201,9 +248,7 @@ void Manager::stop_all_threads()
int Manager::main()
{
- int err_code;
int rc= 1;
- const char *err_msg;
bool shutdown_complete= FALSE;
pid_t manager_pid= getpid();
@@ -258,33 +303,10 @@ int Manager::main()
return 1;
}
- /* Initialize user map and load password file. */
-
- if (user_map.init())
- {
- log_error("Manager: can not initialize user list: out of memory.");
- return 1;
- }
-
- if ((err_code= user_map.load(Options::Main::password_file_name, &err_msg)))
- {
- if (err_code == ERR_PASSWORD_FILE_DOES_NOT_EXIST &&
- Options::Main::mysqld_safe_compatible)
- {
- /*
- The password file does not exist, but we are running in
- mysqld_safe-compatible mode. Continue, but complain in log.
- */
+ /* Initialize user db. */
- log_info("Warning: password file does not exist, "
- "nobody will be able to connect to Instance Manager.");
- }
- else
- {
- log_error("Manager: %s.", (const char *) err_msg);
- return 1;
- }
- }
+ if (init_user_map(&user_map))
+ return 1; /* logging has been already done. */
/* Write Instance Manager pid file. */
diff --git a/server-tools/instance-manager/manager.h b/server-tools/instance-manager/manager.h
index a884ec114de..e6956884603 100644
--- a/server-tools/instance-manager/manager.h
+++ b/server-tools/instance-manager/manager.h
@@ -51,6 +51,7 @@ public:
private:
static void stop_all_threads();
+ static bool init_user_map(User_map *user_map);
private:
static Guardian *p_guardian;
diff --git a/server-tools/instance-manager/mysqlmanager.cc b/server-tools/instance-manager/mysqlmanager.cc
index f1382e067bb..75769af631a 100644
--- a/server-tools/instance-manager/mysqlmanager.cc
+++ b/server-tools/instance-manager/mysqlmanager.cc
@@ -62,7 +62,7 @@
mysql subsystem.
*/
-static int im_main(int argc, char *argv[]);
+static int main_impl(int argc, char *argv[]);
#ifndef __WIN__
static struct passwd *check_user();
@@ -90,7 +90,7 @@ int main(int argc, char *argv[])
log_info("IM: started.");
- return_value= im_main(argc, argv);
+ return_value= main_impl(argc, argv);
log_info("IM: finished.");
@@ -108,7 +108,7 @@ int main(int argc, char *argv[])
Instance Manager main functionality.
*************************************************************************/
-int im_main(int argc, char *argv[])
+int main_impl(int argc, char *argv[])
{
int rc;