X-Git-Url: https://git.llucax.com/software/pymin.git/blobdiff_plain/181a88a2328b4b5fab52508eeaa5795d7d4d5d3c..7c760d8e7832391621b67cabe629f46e6b5959d1:/pymin/services/vrrp/__init__.py?ds=inline diff --git a/pymin/services/vrrp/__init__.py b/pymin/services/vrrp/__init__.py index 580d4e6..4739c52 100644 --- a/pymin/services/vrrp/__init__.py +++ b/pymin/services/vrrp/__init__.py @@ -1,18 +1,25 @@ # vim: set encoding=utf-8 et sw=4 sts=4 : +import os from os import path +from signal import SIGTERM from subprocess import Popen, PIPE +import logging ; log = logging.getLogger('pymin.services.vrrp') from pymin.seqtools import Sequence from pymin.dispatcher import Handler, handler, HandlerError -from pymin.services.util import Restorable, TransactionalHandler, ParametersHandler, call +from pymin.services.util import Restorable, TransactionalHandler, \ + ReloadHandler, RestartHandler, \ + ServiceHandler, ParametersHandler, call __ALL__ = ('VrrpHandler',) -class VrrpHandler(Restorable, ParametersHandler, TransactionalHandler): +class VrrpHandler(Restorable, ParametersHandler, ReloadHandler, RestartHandler, + ServiceHandler, TransactionalHandler): + handler_help = u"Manage VRRP service" - _persistent_attrs = 'params' + _persistent_attrs = ['params'] _restorable_defaults = dict( params = dict( ipaddress='192.168.0.1', @@ -22,37 +29,44 @@ class VrrpHandler(Restorable, ParametersHandler, TransactionalHandler): ), ) - def __init__(self, pickle_dir='.', config_dir='.', pid_dir='.'): - self._persistent_dir = pickle_dir - self._pid_dir = pid_dir - self._restore() - - @handler('Starts the service') - def start(self): + def _service_start(self): + log.debug(u'VrrpHandler._service_start()') if self.params['prio'] != '': - call(('/usr/local/bin/vrrpd','-i',self.params['dev'],'-v',self.params['id'],'-p',self.params['prio'],self.params['ipaddress'])) - #print ('vrrpd','-i',self.params['dev'],'-v',self.params['id'],'-p',self.params['prio'],self.params['ipaddress']) + call(('vrrp', '-i', self.params['dev'], '-v', self.params['id'], + '-p', self.params['prio'], self.params['ipaddress'])) else: - call(('/usr/local/bin/vrrpd','-i',self.params['dev'],'-v',self.params['id'],self.params['ipaddress'])) - #print ('vrrpd','-i',self.params['dev'],'-v',self.params['id'],self.params['ipaddress']) + call(('vrrp', '-i', self.params['dev'], '-v', self.params['id'], \ + self.params['ipaddress'])) - @handler('Stop the service') - def stop(self): - try : - pid = 'vrrpd' + '_' + self.params['dev'] + '_' + self.params['id'] + '.pid' - f = file(path.join(self._pid_dir, pid ), 'r') - call(('kill',f.read().strip('\n'))) - #print('kill','<',f.read()) - except IOError: - pass + def _service_stop(self): + log.debug(u'VrrpHandler._service_stop()') + try: + pid_filename = 'vrrpd_%(dev)s_%(id)s.pid' % self.params + log.debug(u'VrrpHandler._service_stop: getting pid from %r', + pid_filename) + pid = file(path.join(self._pid_dir, pid_filename )).read() + pid = int(pid.strip()) + log.debug(u'VrrpHandler._service_stop: killing pid %r', pid) + os.kill(pid, SIGTERM) + except (IOError, OSError), e: + log.debug(u'VrrpHandler._service_stop: error %r', e) - @handler('Reloads the service') - def reload(self): - self.stop() - self.start() + def __init__(self, pickle_dir='.', config_dir='.', pid_dir='.'): + log.debug(u'VrrpHandler(%r, %r, $r)', pickle_dir, config_dir, pid_dir) + self._persistent_dir = pickle_dir + self._pid_dir = pid_dir + ServiceHandler.__init__(self) if __name__ == '__main__': + + logging.basicConfig( + level = logging.DEBUG, + format = '%(asctime)s %(levelname)-8s %(message)s', + datefmt = '%H:%M:%S', + ) + v = VrrpHandler() - v.set('prio','10') + v.set('prio', '10') v.commit() +