diff options
4 files changed, 23 insertions, 5 deletions
| diff --git a/xlators/features/marker/utils/syncdaemon/gsyncd.py b/xlators/features/marker/utils/syncdaemon/gsyncd.py index 196ed7ab6d4..9ac32ce4267 100644 --- a/xlators/features/marker/utils/syncdaemon/gsyncd.py +++ b/xlators/features/marker/utils/syncdaemon/gsyncd.py @@ -17,7 +17,7 @@ from ipaddr import IPAddress, IPNetwork  from gconf import gconf  from syncdutils import FreeObject, norm, grabpidfile, finalize, log_raise_exception -from syncdutils import GsyncdError, select +from syncdutils import GsyncdError, select, set_term_handler  from configinterface import GConffile  import resource  from monitor import monitor @@ -107,7 +107,8 @@ def startup(**kw):  def main():      """main routine, signal/exception handling boilerplates""" -    signal.signal(signal.SIGTERM, lambda *a: finalize(*a, **{'exval': 1})) +    gconf.starttime = time.time() +    set_term_handler()      GLogger.setup()      excont = FreeObject(exval = 0)      try: diff --git a/xlators/features/marker/utils/syncdaemon/monitor.py b/xlators/features/marker/utils/syncdaemon/monitor.py index 981643ec0a5..b8956dcc2b9 100644 --- a/xlators/features/marker/utils/syncdaemon/monitor.py +++ b/xlators/features/marker/utils/syncdaemon/monitor.py @@ -4,7 +4,7 @@ import time  import signal  import logging  from gconf import gconf -from syncdutils import update_file, select, waitpid +from syncdutils import update_file, select, waitpid, set_term_handler  class Monitor(object):      """class which spawns and manages gsyncd workers""" @@ -103,6 +103,12 @@ class Monitor(object):              else:                  logging.debug("worker not confirmed in %d sec, aborting it" % \                                conn_timeout) +                # relax one SIGTERM by setting a handler that sets back +                # standard handler +                set_term_handler(lambda *a: set_term_handler()) +                # give a chance to graceful exit +                os.kill(-os.getpid(), signal.SIGTERM) +                time.sleep(1)                  os.kill(cpid, signal.SIGKILL)                  ret = nwait(cpid)              if ret == None: diff --git a/xlators/features/marker/utils/syncdaemon/resource.py b/xlators/features/marker/utils/syncdaemon/resource.py index de271bd3939..c4cd19c9fb7 100644 --- a/xlators/features/marker/utils/syncdaemon/resource.py +++ b/xlators/features/marker/utils/syncdaemon/resource.py @@ -692,7 +692,15 @@ class GLUSTER(AbstractUrl, SlaveLocal, SlaveRemote):                      d = self.mntpt                      os.write(mpo, d + '\0')                  os.write(mpo, 'M') -                os.chdir(d) +                t = syncdutils.Thread(target=lambda: os.chdir(d)) +                t.start() +                tlim = gconf.starttime + int(gconf.connection_timeout) +                while True: +                    if not t.isAlive(): +                        break +                    if time.time() >= tlim: +                        syncdutils.finalize(exval = 1) +                    time.sleep(1)                  os.close(mpo)                  _, rv = syncdutils.waitpid(mh, 0)                  if rv: diff --git a/xlators/features/marker/utils/syncdaemon/syncdutils.py b/xlators/features/marker/utils/syncdaemon/syncdutils.py index b29936d596d..f786bc34326 100644 --- a/xlators/features/marker/utils/syncdaemon/syncdutils.py +++ b/xlators/features/marker/utils/syncdaemon/syncdutils.py @@ -7,7 +7,7 @@ import shutil  import logging  from threading import Lock, Thread as baseThread  from errno import EACCES, EAGAIN, EPIPE, ENOTCONN, ECONNABORTED, EINTR, errorcode -from signal import SIGTERM, SIGKILL +from signal import signal, SIGTERM, SIGKILL  from time import sleep  import select as oselect  from os import waitpid as owaitpid @@ -271,3 +271,6 @@ def select(*a):  def waitpid (*a):      return eintr_wrap(owaitpid, OSError, *a) + +def set_term_handler(hook=lambda *a: finalize(*a, **{'exval': 1})): +    signal(SIGTERM, hook) | 
