diff options
author | unknown <reggie@fedora.(none)> | 2005-07-20 10:55:40 -0500 |
---|---|---|
committer | unknown <reggie@fedora.(none)> | 2005-07-20 10:55:40 -0500 |
commit | 875b0e6322df380b6fcd4bd4f66d0d3e0142039f (patch) | |
tree | fd59532b923e8ee6c5bb48afac93f8d93e48fec6 /server-tools/instance-manager/manager.cc | |
parent | 6ae060305541019882bcb60bf086458b010faa45 (diff) | |
download | mariadb-git-875b0e6322df380b6fcd4bd4f66d0d3e0142039f.tar.gz |
initial import of Windows port of IM.
server-tools/instance-manager/commands.cc:
type cleanups for compiling on Windows
now using Options::config_file for the location of the single
my.cnf file we are using
server-tools/instance-manager/guardian.cc:
pthread_mutex_lock and unlock do not return a value on Windows
so we return 0 in all cases
server-tools/instance-manager/instance.cc:
big changes here.
Had to implement Windows versions of launch_and_wait and kill()
server-tools/instance-manager/instance.h:
added some function defs
server-tools/instance-manager/instance_map.cc:
pthread_mutex_lock and unlock do not return a value on Windows
Also, now using only the file named as Options::config_file
server-tools/instance-manager/instance_options.h:
added reference to port.h
server-tools/instance-manager/listener.cc:
reworked and simplified the socket handling code.
Added windows versions of the code that sets the sockets to be
non-blocking and non-inheritable
server-tools/instance-manager/listener.h:
change Options to always be a struct. Really surprised GCC was
letting this go. Options was declared to be struct in some places
and class in other places.
server-tools/instance-manager/log.cc:
added reference to port.h
server-tools/instance-manager/manager.cc:
moved all the signal code inside some #ifndef __WIN__ blocks
server-tools/instance-manager/manager.h:
change Options to always be a struct. Really surprised GCC was
letting this go. Options was declared to be struct in some places
and class in other places.
server-tools/instance-manager/mysqlmanager.cc:
added in the Windows service code.
server-tools/instance-manager/options.cc:
Added in the windows options for running as a service and the code
for loading settings only from a single file
server-tools/instance-manager/options.h:
added definitions for the new Windows service vars and routines
server-tools/instance-manager/parse_output.cc:
added reference to port.h
server-tools/instance-manager/priv.cc:
added reference to port.h
server-tools/instance-manager/priv.h:
linuxthreads should not be visible on Windows
server-tools/instance-manager/thread_registry.cc:
more __WIN__ blocking
server-tools/instance-manager/user_map.cc:
fixed passwd file code to handle files with \r\n line endings
server-tools/instance-manager/IMService.cpp:
New BitKeeper file ``server-tools/instance-manager/IMService.cpp''
server-tools/instance-manager/IMService.h:
New BitKeeper file ``server-tools/instance-manager/IMService.h''
server-tools/instance-manager/WindowsService.cpp:
New BitKeeper file ``server-tools/instance-manager/WindowsService.cpp''
server-tools/instance-manager/WindowsService.h:
New BitKeeper file ``server-tools/instance-manager/WindowsService.h''
server-tools/instance-manager/mysqlmanager.vcproj:
New BitKeeper file ``server-tools/instance-manager/mysqlmanager.vcproj''
server-tools/instance-manager/port.h:
New BitKeeper file ``server-tools/instance-manager/port.h''
Diffstat (limited to 'server-tools/instance-manager/manager.cc')
-rw-r--r-- | server-tools/instance-manager/manager.cc | 95 |
1 files changed, 66 insertions, 29 deletions
diff --git a/server-tools/instance-manager/manager.cc b/server-tools/instance-manager/manager.cc index a4c81739b17..5f2d9d0b493 100644 --- a/server-tools/instance-manager/manager.cc +++ b/server-tools/instance-manager/manager.cc @@ -30,7 +30,9 @@ #include <m_string.h> #include <signal.h> #include <thr_alarm.h> +#ifndef __WIN__ #include <sys/wait.h> +#endif static int create_pid_file(const char *pid_file_name) @@ -50,6 +52,61 @@ static int create_pid_file(const char *pid_file_name) return 0; } +#ifndef __WIN__ +void set_signals(sigset_t *mask) +{ + /* block signals */ + sigemptyset(mask); + sigaddset(mask, SIGINT); + sigaddset(mask, SIGTERM); + sigaddset(mask, SIGPIPE); + sigaddset(mask, SIGHUP); + signal(SIGPIPE, SIG_IGN); + + /* + We want this signal to be blocked in all theads but the signal + one. It is needed for the thr_alarm subsystem to work. + */ + sigaddset(mask,THR_SERVER_ALARM); + + /* all new threads will inherite this signal mask */ + pthread_sigmask(SIG_BLOCK, mask, NULL); + + /* + In our case the signal thread also implements functions of alarm thread. + Here we init alarm thread functionality. We suppose that we won't have + more then 10 alarms at the same time. + */ + init_thr_alarm(10); +} +#else + +bool have_signal; + +void onsignal(int signo) +{ + have_signal = true; +} + +void set_signals(sigset_t *set) +{ + signal(SIGINT, onsignal); + signal(SIGTERM, onsignal); + have_signal = false; +} + +int my_sigwait(const sigset_t *set, int *sig) +{ +// MSG msg; + while (!have_signal) + { + Sleep(100); + } + return 0; +} + +#endif + /* manager - entry point to the main instance manager process: start @@ -98,21 +155,8 @@ void manager(const Options &options) if (create_pid_file(options.pid_file_name)) return; - /* block signals */ sigset_t mask; - sigemptyset(&mask); - sigaddset(&mask, SIGINT); - sigaddset(&mask, SIGTERM); - sigaddset(&mask, SIGPIPE); - sigaddset(&mask, SIGHUP); - /* - We want this signal to be blocked in all theads but the signal - one. It is needed for the thr_alarm subsystem to work. - */ - sigaddset(&mask,THR_SERVER_ALARM); - - /* all new threads will inherite this signal mask */ - pthread_sigmask(SIG_BLOCK, &mask, NULL); + set_signals(&mask); /* create the listener */ { @@ -166,12 +210,7 @@ void manager(const Options &options) bool shutdown_complete; shutdown_complete= FALSE; - /* - In our case the signal thread also implements functions of alarm thread. - Here we init alarm thread functionality. We suppose that we won't have - more then 10 alarms at the same time. - */ - init_thr_alarm(10); + /* init list of guarded instances */ guardian_thread.lock(); @@ -185,8 +224,6 @@ void manager(const Options &options) */ pthread_cond_signal(&guardian_thread.COND_guardian); - signal(SIGPIPE, SIG_IGN); - while (!shutdown_complete) { int status= 0; @@ -197,11 +234,11 @@ void manager(const Options &options) goto err; } - switch (signo) { - case THR_SERVER_ALARM: - process_alarm(signo); - break; - default: +#ifndef __WIN__ + if (THR_SERVER_ALARM == signo) + process_alarm(signo); + else +#endif { if (!guardian_thread.is_stopped()) { @@ -215,16 +252,16 @@ void manager(const Options &options) shutdown_complete= TRUE; } } - break; } - } err: /* delete the pid file */ my_delete(options.pid_file_name, MYF(0)); +#ifndef __WIN__ /* free alarm structures */ end_thr_alarm(1); /* don't pthread_exit to kill all threads who did not shut down in time */ +#endif } |